@charset "utf-8";
/*================================================
 CSS Ver.2.00
=================================================*/

body {
	color: #333333;
	background-color: #FFFFFF;
	font-size: 75%;
	font-family: "游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN",メイリオ,Meiryo,sans-serif;
	border: none;
	counter-reset: titleNum;
	background-image: url("../image_common/bg_01.png");
}

body {
}

html>/**/body {
font-size: 12px;
}

p {
	font-size: 1.6em;
	line-height:150%;
}

@media (max-width: 640px) {
p {
	font-size: 1.5em;
}
}


/*------------------------------------------------
	背景
-------------------------------------------------*/

.bg_01 {
	background-image: url("../image_common/bg_02.png");
}

.bg_02 {
	background-image: url("../image_common/bg_03.png");
}

.bg_03 {
	background-image: url("../image_common/bg_04.png");
}

.bg_04 {
	background-color: #FFFFFF;
}

.ptn_01 {
	background-image: 
	url("../image_common/ptn_01.png");
}



/*------------------------------------------------
	PC / スマートフォン
-------------------------------------------------*/

.pc {
	display: block;
}

@media (max-width: 640px) {
.pc {
	display: none;
}
}

.smp {
	display: none;
}

@media (max-width: 640px) {
.smp {
	display: block;
}
}


/*------------------------------------------------
	Header
-------------------------------------------------*/

header {
	width: 100%;
	display: flex;
	justify-content: space-between;
	padding-bottom: 10px;

}

header div {
	width: 33.3%;
	padding: 10px 10px 0 10px;
}

@media (max-width: 640px) {
header div {
	width: 50%;
}
}

header img {
	max-width: 580px;
	margin: 0 auto;
}

@media (max-width: 640px) {
header img {
	max-width: 200px;
	margin: 0 auto;
}
}


/*------------------------------------------------
	Main Image
-------------------------------------------------*/

#main {
	width: 100%;
	text-align: center;
	padding-bottom: 20px;
}

#main h1, h2 {
	max-width: 1580px;
	margin: 0 auto;
	padding: 10px;
	border-bottom: none;
}

#main h2 {
	max-width: 1580px;
	margin: 0 auto;
}




/*------------------------------------------------
	Tab
-------------------------------------------------*/

.tabs_wrap {
	max-width: 960px;
	margin: 0 auto;
}

.tabs{
  display: flex;
  gap: 1em;
  margin-bottom: 1em;
  background: none;
  border-bottom: 2px solid transparent;
  font-size: 1.3em;
}

@media (max-width: 640px) {
.tabs{
  font-size: 1.0em;
}
}

.tab {
  padding: 0.5em 2.0em;
  border: none;
  cursor: pointer;
}

.tab.active{
}

.tab-content{
  display: none;
}

.tab-content.active{
  display: block;
}


/*------------------------------------------------
	コンテンツ
-------------------------------------------------*/

section {
	width: 100%;
	padding: 0;
	box-sizing: border-box;
}

@media (max-width: 640px) {
section {
	width: 100%;
	padding: 0;
	box-sizing: border-box;
}
}

section h1 {
	font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN",HGS明朝E,メイリオ,Meiryo,serif;
	color: #a92927;
	font-size: 1.8em;
	font-weight: bold;
	border-bottom: 2px solid #a92927;
	width: 100%;
	box-sizing: border-box;
	text-align: center;
	margin-bottom: 1.0em;
}

.box {
	max-width: 960px;
	margin: 0 auto;
	padding: 0 0.8em;
	box-sizing: border-box;
	overflow: auto;
}

.box h2 {
	color: #FFFFFF;
	font-size: 1.8em;
	font-weight: bold;
	width: 100%;
	background-color: #a92927;
	padding: 0.3em 0.5em;
	margin-bottom: 0.8em;
	box-sizing: border-box;
}

@media (max-width: 640px) {
.box h2 {
	font-size: 1.4em;
}
}

.box h3 {
	color: #a92927;
	font-size: 1.8em;
	font-weight: bold;
	padding: 0 0.5em;
	margin-bottom: 0.4em;
	box-sizing: border-box;
	border-left: 4px solid #a92927;
}


.border_box {
	color: #333333;
	width: 100%;
	padding: 1.0em;
	box-sizing: border-box;
	background-color: #FFFFFF;
	border-radius: 5px;
}

.border_box2 {
	width: 100%;
	padding: 1.0em;
	box-sizing: border-box;
	background-color: #D8D8D8;
	border-radius: 5px;
}



.border_box3 {
	width: 100%;
	padding: 1.0em;
	box-sizing: border-box;
	background-image: url("../image_common/bg_01.png");
	border-radius: 5px;
}

.border_box3 h1 {
	font-size: 2.8em;
	border: none;
	padding: 0;
}

.tb {
	border-top: 10px solid #A09F9F;
}

.center {
	text-align: center;
}

.left {
	text-align: left;
}

.right {
	text-align: right;
}


/*------------------------------------------------
	フッター
-------------------------------------------------*/

footer {
	color: #FFFFFF;
	width: 100%;
	padding: 0.5em 0;
	background-color: #a92927;
	text-align: center;
}



/*------------------------------------------------
	余白調整
-------------------------------------------------*/

.margin_5 {
	margin-bottom: 0.5em;
}

.margin_10 {
	margin-bottom: 1.0em;
}

.margin_20 {
	margin-bottom: 2.0em;
}

.margin_30 {
	margin-bottom: 3.0em;
}

.padding_5 {
	padding-bottom: 0.5em;
}

.padding_10 {
	padding-bottom: 1.0em;
}

.padding_20 {
	padding-bottom: 2.0em;
}

.padding_30 {
	padding-bottom: 3.0em;
}



/*------------------------------------------------
	画像
-------------------------------------------------*/

.image_radius {
	border-radius: 50%;
}

.image_r45 {
	width: 45%;
	float: right;
	padding: 0 0 1.0em 1.0em;
}

@media (max-width: 640px) {
.image_r45 {
	width: 100%;
	float: none;
	padding: 0 0 1.0em 0;
}
}

.image_r30 {
	width: 30%;
	float: right;
	padding: 0 0 1.0em 1.0em;
}

@media (max-width: 640px) {
.image_r45 {
	width: 70%;
	float: none;
	padding: 0 15% 1.0em 15%;
}
}

.infoimage_border {
	border: 2px solid #583017;
	border-radius: 5px;
	box-sizing: border-box;
	margin: 15px auto;
}



/*------------------------------------------------
	フォント
-------------------------------------------------*/

.font_min {
	font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN",HGS明朝E,メイリオ,Meiryo,serif;
}

.color_red {
	color: #a92927;
	font-weight: bold;
}

.color_yellow {
	color: #F8FF89;
	font-weight: bold;
}

.color_blue {
	color: #1e2e78;
	font-weight: bold;
}

.bold {
	font-weight: bold;
}

.itaric {
	font-style: italic;
}

.font_s {
	font-size: 1.4em;
}

@media (max-width: 640px) {
.font_s {
	font-size: 1.1em;
}
}

.font_m {
	font-size: 1.6em;
	font-weight: bold;
}

.font_l {
	font-size: 2.0em;
}

@media (max-width: 640px) {
.font_l {
	font-size: 1.5em;
}
}

.duration {
	border-bottom: #333333 1px solid;
	width: 100%;
	text-align: left;
}

.font_sub {
	font-size: 0.8em;
}

.font_bh {
	font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN",HGS明朝E,メイリオ,Meiryo,serif;
}

.al_right {
	text-align: right;
}

.underline_red {
border-bottom: 2px solid #a92927;
border-left: 5px solid #a92927;
width: 100%;
padding: 0 0.5em;
margin-bottom: 0.3em;
box-sizing: border-box;
}


/*------------------------------------------------
	動画
-------------------------------------------------*/

.video-container {
 	position: relative;
 	padding-bottom: 56.25%;
 	padding-top: 30px;
 	height: 0;
 	overflow: hidden;
}

.video-container iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}



/*------------------------------------------------
	Flex Box
-------------------------------------------------*/

.flex_box {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 0;
}

@media (max-width: 640px) {
.flex_box {
	display: block;
}
}

.flex_basis2 {
	text-align: center;
	flex-basis: 49.95%;
	margin-bottom: 0;
	padding: 0;
}

.flex_basis2 h2 {
	font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN",HGS明朝E,メイリオ,Meiryo,serif;
	color: #333333;
	font-size: 1.8em;
	font-weight: bold;
	border-bottom: 1px solid #333333;
	width: 98%;
	margin: 0 1%;
	box-sizing: border-box;
}

.flex_basis2 p {
	width: 98%;
	margin: 1%;
}

.flex_basis3 {
	text-align: center;
	flex-basis: 33.3%;
	margin-bottom: 0;
	padding: 0;
}

.flex_basis3 h2 {
	font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN",HGS明朝E,メイリオ,Meiryo,serif;
	color: #333333;
	font-size: 1.8em;
	font-weight: bold;
	border-bottom: 1px solid #333333;
	width: 98%;
	margin: 0 1%;
	box-sizing: border-box;
}

.flex_basis3 p {
	width: 98%;
	margin: 1%;
}

.flex_txt {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 0;
}

.flex_txtbasis {
	text-align: center;
	flex-basis: 49%;
	font-size: 1.5em;
	color: #FFFFFF;
	background-color: #A09F9F;
	border-radius: 4px;
	margin-bottom: 0.5em;
	padding: 0.5em;
	box-sizing: border-box;
}

@media (max-width: 640px) {
.flex_txtbasis {
	text-align: center;
	flex-basis: 100%;
}
}

.flex_photo {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 0;
}

.flex_photobasis {
	flex-basis: 25%;
}
@media (max-width: 640px) {
.flex_photobasis {
	flex-basis: 50%;
}
}



/*------------------------------------------------
	Table
-------------------------------------------------*/
table {
	border-collapse: separate;
	border-spacing: 3px;
}

th {
	width: 20%;
	color: #FFFFFF;
	font-size: 1.6em;
	font-weight: bold;
	padding: 0.2em;
	background-color: #A09F9F;
	text-align: center;
}

td {
	font-size: 1.6em;
	padding: 0.5em;
}

.th2 {
	width: auto;
}

/*------------------------------------------------
	Map
-------------------------------------------------*/

.gmap {
	width: 100%;
	height: 100%;
	overflow: hidden;
	padding-bottom: 56.25%;
	position: relative;
}

.gmap iframe {
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
}



/*------------------------------------------------
	Buton
-------------------------------------------------*/

.button a {
    position: relative;
    overflow: hidden;
    text-decoration: none;
    display: block;
    background: #eee;
    padding: 0.3em 0.5em;
    outline: none;
    transition: ease .2s;
	font-size: 1.6em;
	font-weight: bold;
	max-width: 350px;
}

.button a span {
    position: relative;
    z-index: 3;
    color:#333;
}

.button a:hover span{
    color:#fff;
}

.bgleft:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  background:#a92927;
  width: 100%;
  height: 100%;
  transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transform: scale(0, 1);
  transform-origin: right top;
}

.bgleft:hover:before{
  transform-origin:left top;
  transform:scale(1, 1);
}



/*------------------------------------------------
	Link
-------------------------------------------------*/

a:link {
	color: #333333;
	text-decoration: none;
}

a:visited {
	color: #333333;
	text-decoration: none;
}

a:hover {
	color: #333333;
	font-weight: bold;
	text-decoration: none;
}

a:active {
	color: #333333;
	font-weight: bold;
	text-decoration: none;
}

footer a:link, a:visited, a:hover, a:active {
	color: #FFFFFF;
	font-weight: normal;
	text-decoration: none;
}
