/* css構造説明

★★カラムはflexboxを使用

■CSS構造
    共通部

    トップページA（767px以下）
    トップページA（768-991px）
    トップページA（992px以上）

    トップページB（767px以下）
    トップページB（768-991px）
    トップページB（992px以上）

    トップページC（767px以下）
    トップページC（768-991px）
    トップページC（992px以上）

    トップページD（767px以下）
    トップページD（768-991px）
    トップページD（992px以上）

    トップページE（767px以下）
    トップページE（768-991px）
    トップページE（992px以上）

■ブロック説明
    共通：体裁関連（全ページ共通）
    A:トップバー
    B:ヘッダー
    C:カルーセル
    D:コンテンツ（main、sub）
    E:フッター
    F:オフキャンバスメニュー

■htmlルール
・要素は全てdivを使用すること
・/divの最後はdiv名を記載すること　<!-->
*/


/* 共通部 */
* {
    box-sizing: border-box;
}

.container {
    max-width: 100%;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
}

/* トップページA（767px以下） */

.navbar {
    background-color: #a52a2a !important;
}

.grobal-nav {
    display: none;
}

.nav-title {
    background-color: #a52a2a;
}

.nav-title a {
    color: #fff !important;
}

.offcanvas-collapse {
    padding-left: 0px !important;
    padding-right: 0px !important;
}

.nav-item {
    padding: 0 1rem 0 1rem;
    border-bottom: 1px solid #aaa;
}

/* トップページA（768-991px） */
@media screen and (min-width:768px)  and (max-width:991px) {
    .bg-light {
        padding-top: 0px;
    }

    .navbar {
        display: none;
    }

    .grobal-nav {
        background-color: #a52a2a;
        display: flex;
        justify-content: space-between;
        padding: 15px 0 15px 0;
    }
    
    .header-title h1 {
        color: #fff;
        padding-left: 20px;
        font-size: 12px;
    }
    
    .nav-list li {
        list-style: none;
        display: inline-block;
    }
    
    .nav-list li a {
        text-decoration: none;
        color: #fff;
        font-size: 10px;
        padding: 15px 5px 15px 5px;
    }

    .nav-list li a:last-child {
        margin-right: 10px;
    }

    .nav-list li a:hover {
        background-color: #5c1313;
        /* display: block; */
    }
}


/* トップページA（992px以上） */
@media screen and (min-width:992px) {
    .bg-light {
        padding-top: 0px;
    }

    .navbar {
        display: none;
    }

    .grobal-nav {
        background-color: #a52a2a;
        display: flex;
        justify-content: space-between;
        padding: 10px 0 10px 0;
    }
    
    .header-title h1 {
        color: #fff;
        padding-left: 20px;
    }
    
    .nav-list li {
        list-style: none;
        display: inline-block;
    }
    
    .nav-list li a {
        text-decoration: none;
        color: #fff;
        font-size: 14px;
        padding: 10px 10px 10px 10px;
    }

    .nav-list li a:last-child {
        margin-right: 10px;
    }

    .nav-list li a:hover {
        background-color: #5c1313;
        /* display: block; */
    }

}


/* トップページB（767px以下） */
    .header {
        text-align: center;
        padding: 20px 0 10px 0;
    }

    .header h1 {
        margin: 0;
        font-size: 26px;
        line-height: 1;
    }

    .header h1 a {
        text-decoration: none;
        color: #000;
    }

    .header p {
        margin: 8px 0 0 0;
        font-size: 12px;
        line-height: 1;
    }

    .header .logo {
        margin: 0 0 10px 0;
        border: none;
        vertical-align: bottom;
    }
/* トップページB（768-991px） */
/* トップページB（992px以上） */


/* トップページC（767px以下） */
.carousel {
    margin-bottom: 30px;
}

.carousel-caption {
    left: 0%;
    top: -20px
    bottom: 40px;
    text-align: left;
    padding: 0px;
    background-color: rgba(255, 255, 255, 0.6);
    width: 100%;
}

.carousel-caption h3 {
    font-size: 24px;
    color: #000;
}

.carousel-caption p {
    font-size: 18px;
    color: #000;
    padding-bottom: 10px;
}

.carousel-indicators li {
    border-radius: 10px;
    display: inline-block;
}

.carousel-inner>.carousel-item>img {
    /* min-width: 500px; */
    display: block;
    width: 100%;
    height: auto;
}

.carousel-control-prev,
.carousel-control-next {
        width: 20px;
    }

.carousel-item {
    padding-bottom: 40px;
}

/* .carousel-inner {
    padding: 50px 20px 20px 20px;
} */

/* トップページC（768-991px） */
@media screen and (min-width:767px) and (max-width:991px) {
    .carousel-caption {
        padding: 20px;
    }
    
    .carousel-inner>.carousel-item>img {
        /* min-width: 500px; */
        display: block;
        width: 100%;
        height: 200px;
        object-fit: cover;
    }
}



/* トップページC（992px以上） */
@media screen and (min-width:992px) {
    .carousel-caption {
        padding: 20px;
    }

    .carousel-inner>.carousel-item>img {
        min-width: 500px;
        display: block;
        width: 100%;
        height: 300px;
        object-fit: cover;
    }
}



/* トップページD（767px以下） */
.sidemenu {
    margin-bottom: 10px;
}

.sidemenu h3 {
    background-color: #dfc27e;
    font-size: 14px;
    padding: 5px;
}

.sidemenu ul li {
    list-style: none;
    background-color: #faedcf;
    padding: 5px;
}

.sidemenu ul li a {
    text-decoration: none;
    color: #000;
    font-size: 12px;
}

.group {
    margin-bottom: 30px;
    padding: 0;
}

.group h2 {
    margin: 0 0 10px 0;
    font-size: 14px;
    padding: 0 0 0 5px;
    border-left: 5px solid #a52a2a;
}

.entry {
    display: flex;
    justify-content: flex-start;
    padding: 20px 20px;
    background-color: #faedcf;
    margin-bottom: 10px;
    max-width: 100%;
}

.entry img {
    width: 80%;
}

/* .contents-img {
    width: 1%;
    height: auto;
} */

.content-kiji {
    width: 80%;
}

.content-kiji h3 {
    font-size: 20px;
    border-bottom: 1px solid #a52a2a;
    padding: 0 0 10px 0;
    margin-bottom: 10px;
}

.content-kiji p {
    font-size: 14px;
    line-height: 1.4;
    margin-bottom: 20px;
}


.entry .text-right a {
    color: #fff;
    background-color: #a52a2a;
    padding: 10px 20px;
}

.news ul li {
    list-style: none;
}

.news ul li a {
    text-decoration: none;
    color: #000;
    display: flex;
    justify-content: flex-start;
    line-height: 1.4;
    margin-bottom: 20px;
}

.news-time {
    margin-right: 20px;
}

.news {
    border: 2px solid #dfc27e;
    padding: 30px 20px;
}

.shopping {
    text-align: center;
    background-color: #afda64;
    padding: 50px 20px;
    margin-bottom: 20px;
    border-radius: 10px;
}

.shopping p {
    font-size: 20px;
    line-height: 1.4;
}

.shopping .fa {
    font-size: 30px;
    color: #a52a2a;
    margin-bottom: 20px;
}

.shopping .button {
    color: #fff;
    background-color: #73ab12;
    padding: 10px 30px;
}

/* トップページD（768-991px） */
/* トップページD（992px以上） */


/* トップページE（767px以下） */
.footer {
    background-color: #444;
    padding: 20px 0 20px 0;
}

.footer p {
    color: #fff;
    font-size: 14px;
}

/* トップページE（768-991px） */
/* トップページE（992px以上） */