@charset "utf-8";

/****************************************

        For PC General Setting

*****************************************/
.sp {
	display: none;
}

body {
	font-family: 'Noto Sans', sans-serif , 'Noto Serif',"Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", serif;
	font-size: 0.96em;
	line-height: 1.6;
}

#contents {
	width: 100%;
	margin: 0;
	background-color: #FFFFFF;
	/****旧ブラウザ対応****/
}

.centering {
	text-align: center;
	display: block;
	/****テキスト中央寄せ****/
}

.lefter {
	text-align: left;
	/****テキスト左寄せ****/
}

.righter {
	text-align: right;.
	/****テキスト右寄せ****/
}

.flt_r {
	float: right;
	/****右寄せ****/
}

.flt_l {
	float: left;
	/****左寄せ****/
}

	@media only screen and (max-width: 768px) {
		.flt_r,
		.flt_l {
			float: none;
			/****SPではFloatなし****/
		}
	}/*** Media Queries ***/

.std1 {
	padding: 0 32px 24px;
	background-color: #FFCC99;
}

.std2 {
	padding: 24px 32px;
	background-color: #FFCC99;
}

@media only screen and (max-width: 768px) {
	.std1 {
		padding: 0 2% 4%;
		font-size: 80%;
	}

	.std2 {
		padding: 4% 2%;
	}
}/*** Media Queries ***/

/****************************************

          Link

*****************************************/
	@media only screen and (min-width: 768px) {
		a {
			color: #666666;
			transition: 0.6s;
			text-decoration: none;
		}

		a:hover {
			color: #FFA500;
			text-decoration: underline;
			opacity: 0.7;
		}

		a.underbar {
			color: #666666;
			display: inline-block;
			position: relative;
		}

		.underbar:before {
			width: 0;
			height: 2px;
			content: "";
			display: block;
			background-color: #FF0000;
			position: absolute;
			bottom: -2px;
			left: 0;
			transition: .24s ease 0s;
		}

		a.underbar:hover {
			text-decoration: none;
		}

		a.underbar:hover:before {
			width: 100%;
		}
	}/*** Media Queries ***/


	@media only screen and (max-width: 768px) {
		a {
			color: #666666;
			text-decoration: underline;
		}
	}/*** Media Queries ***/

/****************************************

          Layout

*****************************************/
#container {
	width: 100%;
	margin: 0;
}

header {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
}

aside {
	width: 100%;
	max-width: 27%;
	margin: 0;
	padding: 0;
	float: right;
	/*** Side MENU ***/
}

	@media only screen and (max-width: 768px) {
		aside {
			max-width: 100%;
			margin: 0;
			padding: 0;
			/*** Side MENU ***/
			background-color: #F2F2F2;
		}
	}/*** Media Queries ***/

main {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
}

.general_container {
	width: 99%;
	max-width: 1290px;
	margin: 0 auto;
	padding: 0;
}

	@media only screen and (max-width: 768px) {
		.general_container {
			width: 98%;
		}
	}/*** Media Queries ***/

	@media only screen and (max-width: 480px) {
		.general_container {
			width: 96%;
		}
	}/*** Media Queries ***/

footer {
	width: 100%;
	height: auto;
	margin: 104px 0 0;
	padding: 0;
}


/****************************************

          Typography

*****************************************/
* h1,
* h2,
* h3,
* h4,
* h5,
* h6 {
	font-family:
		Georgia,
		游明朝,
		"Yu Mincho",
		YuMincho,
		"Hiragino Mincho ProN",
		HGS明朝E,
		メイリオ,
		Meiryo,
		serif;
		display: block;
}
	/** 見出し共通設定 **/

h1 {

}

h2 {

}

h3 {

}

h4 {

}

h5 {

}

h6 {

}

.petit {
	font-size: 80%;
}

.fat {
	font-size: 110%;
	font-weight: 600;
}


/****************************************

          Breadcrumb

*****************************************/
#breadcrumb {
	width: 100%;
	max-width: 1290px;
	margin: 0 auto 56px;
	padding: 0;
	font-size: 90%;
	color: #666666;
}

#breadcrumb a {
	text-decoration: none;
}

	@media only screen and (min-width: 768px) {
		#breadcrumb a:hover {
			text-decoration: underline;
		}
	}/*** Media Queries ***/


/****************************************

          Navigation

*****************************************/
#header_navigation {
	width: 100%;
	max-width: 1290px;
	margin: 0 auto;
	padding: 0;
	font-weight: 600;
}

#header_navigation li {
	width: 12.5%;
	/**widthはメニュー数に合わせて変動**/
	margin: 0;
	padding: 0;
	display: block;
	float: left;
}

#header_navigation li a {
	padding: 6px 0 5px;
	color: #222222;
	text-align: center;
	text-decoration: none;
	display: block;
}

#header_navigation li a:hover {
	color: #FFA500;
}

#toggle {
	display: none;
}

	@media only screen and (max-width: 768px) {
		/**タブレットの段階で切り替え**/
		#header_navigation {
			display: none;
		}

		#header_navigation li {
			width: 100%;
			height: 48px;
			line-height: 48px;
			border-bottom: 1px solid #222222;
		}

		#header_navigation li a,
		#header_navigation li a:hover {
			padding: 0;
			color: inherit;
			display: block;
		}

		#toggle {
			width: 100%;
			display: block;
			position: relative;
		}

		#toggle a {
			padding: 12px 0 10px;
			color: #222222;
			text-align: center;
			text-decoration: none;
			display: block;
			position: relative;
			border-top: 1px solid #222222;
			border-bottom: 1px solid #222222;
		}
	}/*** Media Queries ***/


/****************************************

          Navigation2

*****************************************/
#list_navigation {
	width: 100%;
	max-width: 1290px;
	/**ナビゲーションの全幅はここで決まる**/
	margin: 0 auto;
}

#list_navigation ul {
	margin: 0;
	padding: 0;
	text-align: center;
}

#list_navigation li {
	display: inline-block;
	margin: 0 3% 0 0;
	padding: 0;
	vertical-align: top;
background-color: #00FF00;
}

#list_navigation li:last-child {
	margin: 0;
}


/****************************************

          Main Contents

*****************************************/
	/**コンテンツ共通**/
	/**ChangePhotoの設定**/
.main_photo {
	width: 62%;
	padding-right: 2%;
	height: auto;
	float: left;
}

.main_photo img {
	width: 100%;
	height: auto;
}

.thumbnail_container {
	width: 38%;
	height: auto;
	float: right;
}

	@media only screen and (max-width: 768px) {
		.main_photo,
		.thumbnail_container {
			width: 100%;
			float: none;
		}

		.main_photo {
			padding-right: 0;
		}
	}/*** Media Queries ***/
	/**ChangePhotoの設定**/

	/** Tab Menu **/
.flex_container_tab {
	display: flex;
	flex-flow:         row nowrap;
	justify-content:         flex-start;
	/**タブメニュー専用**/
}

.flex_container_tab {
	width: 100%;
	height: auto;
	padding: 0;
	overflow: hidden;
}

.flexbox_tab {
	width: 25%;
	/**個数に応じて変動**/
	margin: 0;
	padding: 8px 0;
	text-align: center;
	border-radius: 4px 4px 0 0;
	display: block;
	background: #DFDFDF;
	cursor: pointer;
}

	@media only screen and (min-width: 768px) {
		.flexbox_tab:hover {
			transition: 0.6s;
			opacity: 0.7;
		}
	}/*** Media Queries ***/

.select {
	background: #00FF00;
	/**選択中のタブの色**/
}

.tab_contents {
	width: 100%;
	margin: 0;
	padding: 16px;
	border-right: 1px solid #DFDFDF;
	border-left: 1px solid #DFDFDF;
	border-bottom: 1px solid #DFDFDF;
	border-radius: 0 0 4px 4px;
}

.hide {
	display: none;
}
	/** Tab Menu **/

	/** SNS **/
.flex_container_sns {
	display: flex;
	flex-flow:         row nowrap;
	/**数が増える場合には｢wrap｣で処理**/
	justify-content:         flex-start;
	/**SNS専用**/
}

.flexbox_sns {
	width: 20%;
	/**個数に応じて変動**/
	margin: 0;
	font-size: 90%;
	text-align: center;
}

	@media only screen and (min-width: 768px) {
		.flexbox_sns a {
			padding: 8px 0;
			color: #FFFFFF;
			display: block;
			cursor: pointer;
		}

		.flexbox_sns a:hover {
			opacity: 0.6;
			text-decoration: none;
		}
	}/*** Media Queries ***/

	@media only screen and (max-width: 768px) {
		.flexbox_sns a {
			padding: 8% 0;
			color: #FFFFFF;
			display: block;
			cursor: pointer;
		}
	}/*** Media Queries ***/

.share_icon {
	padding-left: 8px;
}

.twitter {
	background-color: #55ACEE;
}

.facebook {
	background-color: #3B5998;
}

.google {
	background-color: #DD4B39;
}

.instagram {
	background-color: #D93177;
}

.tumblr {
	background-color: #35465C;
}

	@media only screen and (max-width: 480px) {
		.share_icon {
			display: none;
		}
	}/*** Media Queries ***/
	/** SNS **/

	/*** News Topics Information ***/
.information_wrap ul {
	width: 100%;
	margin: 0;
	padding: 0;
	border-top: 1px solid #DFDFDF;
	font-size: 0;	/*** inline-block隙間埋め ***/
}

.information_wrap li {
	position: relative;
}

.information_wrap a {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 16px 0;
	display: inline-block;
	cursor: pointer;
	background-color: #FFFFFF;
	border-bottom: 1px solid #DFDFDF;
	font-size: 15px;	/*** inline-block隙間埋め ***/
	text-decoration: none;
}

.information_wrap a:hover {
	color: #FFA500;
	background-color: #FDFDFD;
	border-bottom: 1px solid #DFDFDF;
}

	@media only screen and (max-width: 768px) {
		.information_wrap a:hover {
			color: inherit;
			background-color: inherit;
		}
	}/*** Media Queries ***/

.information_date {
	width: 20%;
	/**width: 9%;**/
	height: auto;
	margin: 0;
	padding: 0;
	font-weight: 600;
	float: left;
}

.information_title {
	width: 72%;
	/**width: 83%;**/
	height: auto;
	margin: 0;
	padding-right: 8%;
	text-align: left;
	float: right;
}

	@media only screen and (max-width: 768px) {
		.information_date {
			width: 100%;
			height: auto;
			margin-bottom: 8px;
			padding: 0;
			display: block;
		}

		.information_title {
			width: 100%;
			height: auto;
			margin: 0;
			padding-right: 8%;
			display: block;
		}
	}/*** Media Queries ***/

.information_wrap li a:after {
	margin-top: -8px;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f054";
	line-height: 1;
	position: absolute;
	top: 50%;
	right: 8px;
}
	/*** News Topics Information ***/

	/*** News Topics Information Move Ver. ***/
.information_wrap_mv ul {
	width: 100%;
	margin: 0;
	padding: 0;
	border-top: 1px solid #DFDFDF;
	font-size: 0;	/*** inline-block隙間埋め ***/
}

.information_wrap_mv li {
	position: relative;
}

.information_wrap_mv a {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 16px 0;
	display: inline-block;
	cursor: pointer;
	background-color: #FFFFFF;
	border-bottom: 1px solid #DFDFDF;
	font-size: 15px;	/*** inline-block隙間埋め ***/
	text-decoration: none;
}

	@media only screen and (min-width: 768px) {
		.information_wrap_mv a:hover {
			transform: translateX(4px);
		}
	}/*** Media Queries ***/

.information_mv_date {
	width: 9%;
	height: auto;
	margin: 0;
	padding: 0;
	float: left;
}

.information_mv_title {
	width: 83%;
	height: auto;
	margin: 0;
	padding-right: 8%;
	text-align: left;
	float: right;
}

	@media only screen and (max-width: 768px) {
		.information_mv_date {
			width: 100%;
			height: auto;
			margin-bottom: 8px;
			padding: 0;
			display: block;
		}

		.information_mv_title {
			width: 100%;
			height: auto;
			margin: 0;
			padding-right: 8%;
			display: block;
		}
	}/*** Media Queries ***/

.information_wrap_mv li a:after {
	margin-top: -8px;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f054";
	line-height: 1;
	position: absolute;
	top: 50%;
	right: 8px;
}
	/*** News Topics Information Move Ver. ***/

	/*** Carousel ***/
ul.carousel {
	padding: 0;
}
	/*** Carousel ***/

	/*** Accordion ***/
.accordion_wrap {
	border-top: 1px solid #C6C6C6;
}

.accordion {
	margin: 0;
	padding: 0;
}

.accordion dt{
	width: 100%;
	height: auto;
	margin: 0;
	padding: 24px 0;
	border-bottom: 1px solid #C6C6C6;
	cursor: pointer;
	display: block;
	position: relative;
}

.accordion dt:after {
	margin-top: -8px;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f13a";
	line-height: 1;
	position: absolute;
	top: 50%;
	right: 24px;
	transition: transform .16s linear;
}

.accordion dt.rlt:after {
	transform: rotate(180deg);
}

.accordion dd{
	width: 100%;
	height: auto;
	margin: 0 0 24px;
	padding: 24px 0;
	color: #888888;
	border-bottom: 1px dashed #A9A9A9;
	display: none;
}
	/*** Accordion ***/
	/**コンテンツ共通**/

.keyvisual {
	width: 100%;
	height: 640px;
	/**高さは必須**/
	padding: 0;
	background: url("./img/dummy_visual.jpg") no-repeat top right;
	/*background-size: contain;*/
	background-size: cover;
	color: #FFFFFF;
}

	@media only screen and (max-width: 768px) {
		.keyvisual {
			height: 480px;
			padding: 0;
			background-position: top right;
		}
	}/*** Media Queries ***/

	@media only screen and (max-width: 480px) {
		.keyvisual {
			height: 360px;
		}
	}/*** Media Queries ***/

	/**GoogleMap / Youtube**/
.iframe_container,
.youtube {
	height: 0;
	position: relative;
	padding-top: 56.25%;
	/**数値変更で高さ調整**/
	overflow: hidden;
}

.iframe_container iframe,
.iframe_container object,
.iframe_container embed,
.youtube iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
}
	/**GoogleMap / Youtube**/

	/**Youtube LightBOX**/
#colorbox iframe {
	width: 560px;
	height: 315px;
}
	/**Youtube LightBOX**/

.footer_nav_button {
	margin-right: 16px;
	padding: 4px 8px;
	font-size: 0.8em;
	font-weight: bold;
	border: 3px solid #FFFFFF;
	border-radius: 3px;
	display: inline-block;
}

a.footer_nav_button,
a.footer_nav_button:hover {
	color: #FFFFFF;
	text-decoration: none;
}

.sb_big {
	font-size: 1.2em;
}

a.footer_nav,
a.footer_nav:hover {
	color: #FFFFFF;
	text-decoration: none;
}

.bbrd {
	border-bottom: 24px solid #222222;
}

.ssbr {
	font-size: 0.9em;
}

/****************************************

          Footer

*****************************************/
	/**ページトップ設定**/
.pagetop {
	display: none;
	position: fixed;
	bottom: 0;
	right: 8px;
	/**GoogleMap下への入り込み防止**/
	z-index: 99;
}

.pagetop a {
	display: block;
	width: 48px;
	height: 48px;
	background: url("./img_common/gotop.png");
}
	/**ページトップ設定**/

#footer_base {
position:fixed;
left:0;
bottom:0;
width:100%;
	padding: 20px 0 20px;
	background-size: auto auto;
	background-color: rgba(251, 176, 59, 1);
	background-image: repeating-linear-gradient(138deg, transparent, transparent 4px, rgba(252, 200, 117, 1) 4px, rgba(252, 200, 117, 1) 5px );
}

@media only screen and (max-width: 768px) {
	#footer_base {
		padding: 8% 0 4%;
	}

	#footer_base img {
		max-width: 80%;
	}
}/*** Media Queries ***/

#copy_base {
	padding: 24px 0 48px;
	background-color: #000000;
	color: #FFFFFF;
}

/****************************************

          IMAGE Setting

*****************************************/
img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
	/****画像直下の空白消し****/
}

.img_right {
	margin: 0 0 1.2% 1.2%;
	padding: 0;
	float: right;
	/****画像右寄せ****/
}

.img_left {
	margin: 0 1.2% 1.2% 0;
	padding: 0;
	float: left;
	/****画像左寄せ****/
}

.img_centering {
	display: block;
	margin: 0 auto;
	/*** 画像を絶対的に中央に配置 ***/
}

.img_lengthwise {
	vertical-align: middle;
	/*** 画像の縦位置を中央に配置 ***/
}

img.i_radius {
	border-radius: 4px;
}

	@media only screen and (min-width: 768px) {
		.scaler_wrap {
			/*width: 100%;*/
			width: 320px;
			height: auto;
			overflow: hidden;
		}

		.g_scaler {
			transition: .24s linear;
			transform: scale(1);
		}

		.g_scaler:hover {
			transform: scale(1.08);
		}
	}/*** Media Queries ***/


/****************************************

          Footer Setting

*****************************************/
footer {
	clear: both;
}

/****************************************

          ClearFix

*****************************************/
	/*** clearfix ***/
#container:after,
.clearfix:after {
	display: block;
	visibility: hidden;
	clear: both;
	height: 0;
	content: " ";
	font-size: 0;
}

	/* clearfix for ie7 */
#container,
.clearfix {
	display: inline-block;
}

#container,
.clearfix {
	display: block;
}
	/*** clearfix ***/


/****************************************
     For Smart Phone General Setting
            Width from 768px
*****************************************/
	@media only screen and (max-width: 768px) {
		.pc {
			display: none;
		}

		.sp {
			display: block;
		}

		body {
			-webkit-text-size-adjust: 100%;
			line-height: 1.6;
		}

		html, body, div, span, applet, object, iframe,
		/*h1, h2, h3, h4, h5, h6,*/ blockquote, pre,
		a, abbr, acronym, address, big, cite, code,
		del, dfn, em, font, img, ins, kbd, q, s, samp,
		small, strike, strong, sub, sup, tt, var,
		b, u, i, center,dl, dt, dd, ol, ul, li,
		fieldset, form, label, legend,
		table, caption, tbody, tfoot,footer, thead, tr, th, td {
			margin: 0;
			padding: 0;
			background: transparent;
			border: 0;
			outline: 0;
			font-size: 1em;
			vertical-align: baseline;
		}

		* h1,
		* h2,
		* h3,
		* h4,
		* h5,
		* h6 {
			margin: 0;
			padding: 0;
			background: transparent;
			border: 0;
			outline: 0;
			vertical-align: baseline;
		}
		/** 見出し共通設定 **/

		body,
		table,
		input, textarea, select, option {
			font-family: 'Noto Sans', sans-serif , 'Noto Serif', serif;
			font-size: 1em;
		}

		article, aside, canvas, details, figcaption, figure,
		footer, header, hgroup, menu, nav, section, summary,
		header,hgroup {
			display: block;
		}

		ol, ul {
			list-style: none;
		}

		:focus {
			outline: 0;
		}

		ins {
			text-decoration: none;
		}

		del {
			text-decoration: line-through;
		}

		blockquote, q {
			quotes: none;
		}

		blockquote:before,
		blockquote:after,
		q:before,q:after {
			content: '';
			content: none;
		}

		table {
			border-collapse: collapse;
			border-spacing: 0;
		}

/****************************************

          Layout

*****************************************/
		#container {
			width: 100%;
			margin: 0;
		}

		header {
			width: 100%;
			height: auto;
			margin: 0;
			padding: 0;
		}

		main {
			width: 100%;
			height: auto;
			margin: 16px 0 56px;
			padding: 0;
			/*** Main Contents ***/
		}

		footer {
			width: 100%;
			height: auto;
		}
	}/*** Media Queries ***/

	@media only screen and (max-width: 768px) {
		#floatingmenu {
			display: block;
			width: 100%;
			position: fixed;
			left: 0px;
			bottom: 0px;
			z-index: 9999;
			text-align: center;
			padding: 0 auto;
			background-color: #228b22;
			color: #FFFFFF;
		}

		.fb_inner {
			padding: 8px 0;
			font-size: 120%;
			line-height: 1;
		}

		.fb_inner a,
		.fb_inner a:hover {
			color: #FFFFFF;
		}
	}/*** Media Queries ***/
	
/*price*/
#price{
	background-color:#ffcc9a;
	padding:20px;
	margin-top:40px;
}
#price h2{
	display:flex;
	justify-content:space-between;
	align-items:center;
	margin:0 0 20px 0;
}
#price h2:before,#price h2:after{
	content:'';
	display:block;
	width:49%;
	height:1px;
	background-color:#003794;
}
#price h2 span{
	font-family:sans-serif;
	font-size:36px;
	flex-shrink:0;
	margin:0 20px;
	white-space:nowrap;
	color:#003794;
	text-shadow:1px 1px 0 #fff,-1px -1px 0 #fff;
}
#price>div table{
	min-width:100%;
	border-top:1px solid #999;
	border-left:1px solid #999;
}
#price>div table th,td{
	border-bottom:1px solid #999;
	border-right:1px solid #999;
	background-color:#fff;
	padding:10px;
	white-space:nowrap;
	text-align:center;
	vertical-align:center;
}
#price>div table th{
	background-color:#eee;
}
#price>div table td br{
	display:none;
}
#price>div table thead th{
	background-color:#f60;
	color:#fff;
}
#price>div table tbody tr:nth-child(1) th,
#price>div table tbody tr:nth-child(2) th,
#price>div table tbody tr:nth-child(3) th{
	background-color:#fec;
}
#price>div table tbody tr:nth-child(5) th,
#price>div table tbody tr:nth-child(6) th{
	background-color:#fce;
}
#price>div table tbody tr:nth-child(n+7) th{
	background-color:#cef;
}
@media only screen and (max-width: 768px) {
#price h2 span{
	font-size:6vw;
}
#price>div table td br{
	display:block;
}
}
