@charset "UTF-8";

html{
  scroll-behavior: smooth;
}

body{
  font-family:     "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", Osaka, sans-serif;
  line-height: 1;
}


/*header*/
header{
	background-color: #fff;
	padding: 10px 0;
	text-align: center;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
	position: relative;
	z-index: 2;
}
header img{
	width: auto;
	max-width: 50%;
	height: 68px;
}


/*main*/
main{
	width: 100%;
	max-width: 1000px;
	margin: auto;
	padding: 20px 0;
	background-color: #fff;
}

.main_bar {
    width: 100%;
    margin: 10px 0;
}


/*nav*/
nav{
    float: left;
    width: 10%;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-lr;
    position: sticky;
    top: 0;
}
nav ul{
	display: flex;
}
nav ul li a{
	display: block;
    margin: 0 0 10px;
    padding: 5px 10px;
    border-left: solid 3px #565656;
    letter-spacing: 2px;
}
nav ul li a p{
	font-size: 10px;
	line-height: 10px;
}


/*main_cont*/
.main_cont{
	float: right;
  width: 90%;
  border-left: solid 1px #ccc;
}
.main_cont p,.main_cont p span{
	font-size: 16px;
	line-height: normal;
}

.main_cont_full{
  width: 100%;
}
.main_cont p,.main_cont p span{
  font-size: 16px;
  line-height: normal;
}

/*item*/
.item_cont{
  width: 44%;
  max-width: 320px;
  margin: 0 3% 3%;
  display: inline-block;
  vertical-align: top;

}
.item_cont_2{
  width: 100%;
  padding: 0 3% 5%;
  margin-bottom: 5%;
  border-bottom: solid 1px #ccc;
  display: inline-block;
  vertical-align: top;
}
.item_cont_2 .f_left{
  width: 48%;
}
.item_cont_2 .f_right{
  width: 48%;
}
/*
.item_cont,.item_cont_btn {
    width: 29%;
    max-width: 320px;
    margin: 0 2% 3%;
    display: inline-block;
}
*/
.item_cont p,.item_cont p span,.item_cont_2 p,.item_cont_2 p span{
  font-size: 14px;
  line-height: normal;
  font-weight: bold;
  text-align: center;
}
.item_cont img,.item_cont_2 img{
  padding: 3px;
  border: solid 1px #333;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}
.item_cont_btn{
  width: 94%;
  height: 150px;
  overflow: hidden;
  position: relative;
  padding: 3px;
  border: solid 1px #333;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
  margin: 3% 3% 3%;
}
.item_cont_btn img{
  width: 100%;
  margin-top: -50%;
}
.item_cont_btn_word{
  position: absolute;
  top: 25%;
  right: 0;
  left: 0;
  margin: auto;
}
.item_cont_btn_word p,.item_cont_btn_word p span{
  font-size: 22px;
  line-height: 40px;
  font-weight: bold;
  background-color: #fff;
  display: inline;
}

@media screen and (min-width:781px){
  .item_cont_btn{
    max-width: 700px;
    margin: 1% auto;
  }
  .item_cont_2{
    width: 50%;
    padding: 0 2% 0;
    border-bottom: none;
  }
}





/*link*/
.link{
  margin: 3%;
  font-size: 0;
}
.link img{
  padding: 1%;
}

.link_mini{
  color: #000;
}
.link_mini a{
  font-size: 12px;
  line-height: 14px;
  border: solid 1px #000;
  border-radius: 30px;
  padding: 5px 10px;
  display: inline-block;
  margin: 5px 3px;
}
@media screen and (min-width:781px){
  .link{
    margin: 3% auto;
    max-width: 700px;
  }
}

/*footer*/
footer{
  text-align: center;
  background-color: #fff;
  color: #000;
  padding: 30px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}





/**/
a,p,a:hover,a p:hover{
  transition: all 0.2s;
}
a:hover,a p:hover{
  opacity: 0.6;
}

p,p span{
  font-size: 14px;
  line-height: normal;
}
h1,h2,h3{
  font-size: 24px;
  line-height: 24px;
  font-weight: bold;
  margin: 10px 0;
}
h2::before,h2::after{
  padding: 0 0.5em;
  color: #555;
}
h3{
  padding: 3%;
  font-weight: lighter;
}
.cont{
  border-bottom: solid 1px #ccc;
    padding: 3%;
}
.cont_no_border{
  padding: 3%;
}
.cont_top_border{
  border-bottom: solid 1px #ccc;
  border-top: solid 1px #ccc;
  padding: 3%;
}
img.shadow{
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}




/*パンくず*/
.breadcrumb {
  margin: 0 10px;
  padding: 0;
  list-style: none;
}

.breadcrumb li {
	display: inline;/*横に並ぶように*/
	list-style: none;
	font-size: 12px;
	line-height: 12px;
}

.breadcrumb li:after {/* >を表示*/
	content: '>';
	padding: 0 0.5em;
	color: #555;
}

.breadcrumb li:last-child:after {
	content: '';
}

.breadcrumb li a {
	text-decoration: none;
}
.breadcrumb li a span {
	font-size: 12px;
	line-height: 12px;
}
.breadcrumb li a:hover {
	text-decoration: underline;
}



/*モーダルウィンドウ*/
*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-size: 0;
}
.content{
    margin: 0 auto;
    padding: 40px;
}
.modal{
    display: none;
    height: 100vh;
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    z-index: 99999;
}
.modal__bg{
    background: rgba(0,0,0,0.8);
    height: 100vh;
    position: absolute;
    width: 100%;
}
.modal__content{
    background: #fff;
    left: 50%;
    padding: 15px;
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%);
    width: 90%;
    max-width: 1000px;
}

/*タブ切り替え*/
.tab-group{
    display: flex;
    justify-content: center;
}
.tab-group .tab{
    flex-grow: 1;
    padding:5px;
    list-style:none;
    border:solid 1px #CCC;
    text-align:center;
    cursor:pointer;
}
.panel-group{
    border-top:none;
    height:auto;
}
.panel-group .panel{
    display:none;
}
.panel-group .panel.is-show{
    display:block;
}
.panel-group .tab.is-active{
  transition: all 0.2s ease-out;
}


/*ボタン*/
a.btn01 p{
  width: 100%;
  max-width: 700px;
  border: solid 1px #565656;
  border-radius: 50px;
  padding:20px 0;
  margin: 1% auto;
  text-align: center;
  font-weight: bold;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}
a.btn01 p::before{
  content: '▶';
  padding: 0 0.5em;
  color: #555;
}

a p.btn02 {
    width: 100%;
    max-width: 700px;
    border: solid 1px #565656;
    border-radius: 50px;
    padding: 5px 0;
    margin: 1% auto;
    text-align: center;
    font-weight: bold;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
    font-size: 12px;
}
a.btn02 p::before{
  content: '▶';
  padding: 0 0.5em;
  color: #555;
}





/*common*/
.clearfix::after {
   content: "";
   display: block;
   clear: both;
}
.f_none {	float:none !important;	}
.f_left {	float:left;	}
.f_right {	float:right;	}
.clear {	clear:both;	}

.txt_left{	text-align: left;	}
.txt_right{	text-align: right;	}
.txt_center{	text-align: center;	}

.size_11 { font-size: 11px; }
.size_12 { font-size: 12px; }
.size_13 { font-size: 13px; }
.size_14 { font-size: 14px; }
.size_15 { font-size: 15px; }
.size_16 { font-size: 16px; }
.size_17 { font-size: 17px; }
.size_18 { font-size: 18px; }
.size_19 { font-size: 19px; }
.size_20 { font-size: 20px; }
.size_21 { font-size: 21px; }
.size_22 { font-size: 22px; }

.weight_normal { font-weight: normal; }
.weight_bold   { font-weight:   bold; }

.w_auto { width: auto !important; }

.wp_100 { max-width: 100% !important; }
.wp_98  { max-width:  98% !important; }
.wp_90  { max-width:  90% !important; }
.wp_80  { max-width:  80% !important; }
.wp_70  { max-width:  70% !important; }
.wp_60  { max-width:  60% !important; }
.wp_50  { max-width:  50% !important; }
.wp_40  { max-width:  40% !important; }
.wp_30  { max-width:  30% !important; }
.wp_20  { max-width:  20% !important; }
.wp_15  { max-width:  15% !important; }
.wp_10  { max-width:  10% !important; }
.wp_8   { max-width:   8% !important; }
.wp_5   { max-width:   5% !important; }
.wp_4   { max-width:   4% !important; }
.wp_3   { max-width:   3% !important; }
.wp_2   { max-width:   2% !important; }
.wp_1   { max-width:   1% !important; }

.wp_100_mx_700{ max-width: 700px; width: 100% !important;}


.pa0  { padding: 0px  !important; }
.pa5  { padding: 5px !important; }
.pa10 { padding: 10px !important; }
.pa15 { padding: 15px !important; }
.pa20 { padding: 20px !important; }

.pt0  { padding-top:  0px !important; }
.pt5  { padding-top:  5px !important; }
.pt7  { padding-top:  7px !important; }
.pt10 { padding-top: 10px !important; }
.pt15 { padding-top: 15px !important; }
.pt20 { padding-top: 20px !important; }
.pt25 { padding-top: 25px !important; }
.pt30 { padding-top: 30px !important; }
.pt35 { padding-top: 35px !important; }
.pt40 { padding-top: 40px !important; }
.pt45 { padding-top: 45px !important; }
.pt50 { padding-top: 50px !important; }

.pr0  { padding-right:  0px !important; }
.pr5  { padding-right:  5px !important; }
.pr10 { padding-right: 10px !important; }
.pr15 { padding-right: 15px !important; }
.pr20 { padding-right: 20px !important; }
.pr25 { padding-right: 25px !important; }
.pr30 { padding-right: 30px !important; }
.pr35 { padding-right: 35px !important; }
.pr40 { padding-right: 40px !important; }
.pr45 { padding-right: 45px !important; }
.pr50 { padding-right: 50px !important; }

.pb0  { padding-bottom:  0px !important; }
.pb5  { padding-bottom:  5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb25 { padding-bottom: 25px !important; }
.pb30 { padding-bottom: 30px !important; }
.pb35 { padding-bottom: 35px !important; }
.pb40 { padding-bottom: 40px !important; }
.pb45 { padding-bottom: 45px !important; }
.pb50 { padding-bottom: 50px !important; }

.pl0  { padding-left:  0px !important; }
.pl5  { padding-left:  5px !important; }
.pl10 { padding-left: 10px !important; }
.pl15 { padding-left: 15px !important; }
.pl20 { padding-left: 20px !important; }
.pl25 { padding-left: 25px !important; }
.pl30 { padding-left: 30px !important; }
.pl35 { padding-left: 35px !important; }
.pl40 { padding-left: 40px !important; }
.pl45 { padding-left: 45px !important; }
.pl50 { padding-left: 50px !important; }

.ma0  { margin:  0px !important; }
.ma5  { margin:  5px !important; }
.ma10 { margin: 10px !important; }
.ma15 { margin: 15px !important; }
.ma20 { margin: 20px !important; }

.mt0  { margin-top:  0px !important; }
.mt5  { margin-top:  5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt35 { margin-top: 35px !important; }
.mt40 { margin-top: 40px !important; }
.mt45 { margin-top: 45px !important; }
.mt50 { margin-top: 50px !important; }

.mr0  { margin-right:  0px !important; }
.mr5  { margin-right:  5px !important; }
.mr10 { margin-right: 10px !important; }
.mr15 { margin-right: 15px !important; }
.mr20 { margin-right: 20px !important; }
.mr25 { margin-right: 25px !important; }
.mr30 { margin-right: 30px !important; }
.mr35 { margin-right: 35px !important; }
.mr40 { margin-right: 40px !important; }
.mr45 { margin-right: 45px !important; }
.mr50 { margin-right: 50px !important; }

.mb0  { margin-bottom:  0px !important; }
.mb5  { margin-bottom:  5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb35 { margin-bottom: 35px !important; }
.mb40 { margin-bottom: 40px !important; }
.mb45 { margin-bottom: 45px !important; }
.mb50 { margin-bottom: 50px !important; }

.ml0   { margin-left:   0px !important; }
.ml5   { margin-left:   5px !important; }
.ml10  { margin-left:  10px !important; }
.ml15  { margin-left:  15px !important; }
.ml20  { margin-left:  20px !important; }
.ml25  { margin-left:  25px !important; }
.ml30  { margin-left:  30px !important; }
.ml35  { margin-left:  35px !important; }
.ml40  { margin-left:  40px !important; }
.ml45  { margin-left:  45px !important; }
.ml50  { margin-left:  50px !important; }
.ml120 { margin-left: 120px !important; }

.ma_auto { margin-left: auto; margin-right: auto; }

.border_right,.border_right_sp{
  border-right: solid 1px #ccc;
}
.border_bottom,.border_bottom_sp{
  border-bottom: solid 1px #ccc;
}
.border_kakomi{
  border: solid 1px #ccc;
  padding: 3% 5%;
  margin: 3%;
}
.red{
  color: red;
}
.yellow{
  color: yellow;
}
.white{
  color: white;
}
.black{
  color: black;
}
.green{
  color: green;
}
.melon_green{
  color: #338a41;
}
.light_gray{
  color: #ccc;
}
.dark{
  color: #333;
}
.gray{
  color: #656565;
}
@media screen and (max-width:781px){
  .border_right{
    border-right: none;
  }
  .border_bottom{
    border-bottom: none;
  }
}


/*responsib*/
.sp{
  display: block;
}
.pc{
  display: none;
}
@media screen and (min-width:781px){
  .sp{
    display: none;
  }
  .pc{
    display: block;
  }
}


/*googlemap*/
#googleMaps iframe {
    width: 100%;
}




/*sne*/
.sns_btn{
    position: fixed;
    left: 0;
    right: 0;
    text-align: left;
    bottom: 10px;
    z-index: 999;
    max-width: 1000px;
    margin:auto;
    padding-left: 5px;
}
.sns_btn .twitter {
    max-width: 42px;
    width: 100%;
    display: block;
    margin-left: -5px;
    margin-bottom: 5px;
}
.sns_btn .twitter img {
  width: 100%;
}
@media screen and (min-width:781px){
}
