@charset "utf-8";
h1,
h2,
h3 {
    text-align: center;
}

p {
    text-align: left;
    color: #383838
}

#main {
    width: 75%;
    max-width: 750px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 50px;
    margin-bottom: 50px;
}

footer {
    text-align: center;
    margin-top: 60px;
    padding-top: 25px;
    padding-bottom: 25px;
    background-color: #383838;
    color: #F5F5F5;
}

.nav,
.navbar-default {
    border-width: 0px;
    border-radius: 0px;
    background-color: #FFFFFF;
    margin-top: 20px;
}

.image-fill {
    width: 100%;
}

#wrapper {
    padding-left: 0px;
    padding-right: 0px;
}

.text-left {
    text-align: left;
}

.text-center {
    text-align: center;
}

.sub {
    width: 90%;
    max-width: 750px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 5px;
    margin-bottom: 20px;
}

.button {
    width: 100px;
    font-size: 14px;
    font-weight: bold;
    text-decoration: none;
    display: block;
    text-align: center;
    padding: 8px 0 10px;
    color: #2c3e50;
    background-color: #ecf0f1;
    border-radius: 5px;
    box-shadow: 2px 2px #2c3e50;
    margin: 20px;
    float: left;
}

.button2 {
    width: 200px;
    font-size: 18px;
    font-weight: bold;
    text-decoration: none;
    display: block;
    text-align: center;
    padding: 8px 0 10px;
    color: #2c3e50;
    background-color: #ecf0f1;
    border-radius: 5px;
    box-shadow: 2px 2px #2c3e50;
    margin: 20px;
    float: left;
}

.clear {
    clear: both
}

.floatleft {
    float: left;
}

.floatleft span {
    margin: 5px;
}

.ggmap {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
}

.ggmap iframe,
.ggmap object,
.ggmap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.ggmap2 {
    width: 100%;
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    padding-bottom: 500px;
    padding-top: 30px;
    overflow: hidden;
}

.ggmap2 iframe,
.ggmap2 object,
.ggmap2 embed {
    position: absolute;
    top: 0;
    left: 0%;
    width: 100%;
    height: 100%;
}

table {
    text-align: left;
    margin-top: 10px;
    margin-bottom: 10px;
    cellspacing: 1;
    cellpadding: 5;
    border: 0;
    width: 100%;
    background: #cccccc;
}

.heading {
    background-color: #2c3e50;
    width: 200px;
    padding: 8px;
}

@media screen and (max-width:768px) {
    .heading {
        width: 110px;
        padding: 8px;
    }
}

.headingtx {
    color: #ffffff;
    font-weight: bold;
}

.item {
    background-color: #ffffff;
    padding: 8px;
}

.shop_tbl {
    border-collapse: separate;
    border-spacing: 1px;
    font-size: 14px;
}

.center-bl {
    width: 100%;
    text-align: center;
}

.center-bl div {
    width: 85%;
    margin: 0 auto;
}

#pageTop {
    position: fixed;
    bottom: 20px;
    right: 20px;
}

#pageTop a {
    display: block;
    z-index: 999;
    padding: 8px 0 0 8px;
    border-radius: 25px;
    width: 30px;
    height: 30px;
    background-color: #F8BB6D;
    color: #fff;
    font-weight: bold;
    text-decoration: none;
    text-align: left;
}

#pageTop a:hover {
    text-decoration: none;
    opacity: 0.7;
}

.social_btn {
    margin: 10px;
}


/*トップページ内「ニュースリリース」ブロック
---------------------------------------------------------------------------*/


/*ブロック全体の設定*/

#new dl {
    padding-left: 15px;
    margin-bottom: 15px;
    height: 110px;
    /*高さ*/
    overflow: auto;
    /*高さの設定を超えるとスクロールが自動で出る設定。全部表示させていたいならこの行と上の行を削除。*/
}


/*日付設定*/

#new dt {
    font-weight: bold;
    /*太字にする設定。標準がいいならこの行削除。*/
    float: left;
    width: 8em;
}


/*記事設定*/

#new dd {
    padding-left: 8em;
}


/*トップページ内「ニュースリリース」ブロック
---------------------------------------------------------------------------*/

section#new h3.open {
    background: #383838 url(../images/btn_minus.png) no-repeat right center/34px 34px;
}

section#new h3.close {
    background: #383838 url(../images/btn_plus.png) no-repeat right center/34px 34px;
}


/*トップページのNEWアイコン
---------------------------------------------------------------------------*/

.newicon {
    background: #F00;
    /*背景色*/
    color: #FFF;
    /*文字色*/
    font-size: 10px;
    /*文字サイズ*/
    padding: 0px 5px;
    border-radius: 2px;
    margin: 0px 5px;
}


/*コンテンツ
---------------------------------------------------------------------------*/

.contents {
    clear: both;
    max-width: 1200px;
    /*最大幅。#header、#menubar、#pagetopと数字を合わせる*/
    margin: 0 auto;
    overflow: auto;
    padding: 40px 0;
}


/*h3タグ*/

.contents h3 {
    clear: both;
    margin-bottom: 15px;
    padding: 8px 20px;
    /*上下、左右への余白*/
    background: #383838;
    /*背景色（古いブラウザ用）*/
    color: #fff;
    /*文字色*/
    border-radius: 10px;
    /*角丸のサイズ*/
}

.youtube {
    width: 100%;
    max-width: 600px;
    margin: 30px auto;
}

.frame {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}

.youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
}

.map iframe {
    width: 100%;
}

@media screen and (max-width:768px) {
    .map iframe {
        height: 300px;
    }
}

.carousel .item .main-link {
    position: absolute;
    top: 50%;
    left: 50%;
    margin-right: -50%;
    transform: translate(-50%, -50%);
    z-index: 9;
}

.carousel .item .main-link a {
    display: block;
    background-color: #000;
    color: #fff;
    border-radius: 16px;
    text-align: center;
    padding: 5px 30px;
}

.carousel .item .main-link a:hover {
    opacity: 0.8;
    text-decoration: none;
}

.flex {
	display: flex;
}

.logo-pc{
	width: 250px;
	margin-left: 10px;
}

.logo-sp{
	max-width: 200px;
	margin-left: 10px;
}

.navi-right{
	display: flex;
	margin-left: auto;
}


/* パソコンで見たときは"pc"のclassがついた画像が表示される */
.pc { display: block !important; }
.sp { display: none !important; }
 
/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media only screen and (max-width: 780px) {
    .pc { display: none !important; }
    .sp { display: block !important; }
}