@charset "UTF-8";
/* ----------------------------------------------------------------------
 基本設定
---------------------------------------------------------------------- */
@media only screen and (max-width: 1600px) {
    .content-inner {
        padding: 0 45px;
    }

    .content01-title {
        font-size: 46px;
    }

    .content01-text h3 {
        font-size: 30px;
    }

    .content02-title {
        font-size: 36px;
    }

    .content03-title {
        font-size: 32px;
    }

    #index-text-2 h2 {
        font-size: 60px;
    }

    #index-text-2 h2 strong {
        font-size: 50px;
    }

    .text02-button strong {
        font-size: 22px;
    }

    .text02-button span {
        font-size: 18px;
    }

    #index-text-2 .concept-left {
        padding-right: 30px;
        width: 60%;
    }

    #index-text-2 .concept-right {
        width: 40%;
    }

    #index-text-2 .open-title {
        padding: 0 10px;
    }
}

@media only screen and (max-width: 1200px) {
    .header-bar-fixed ~ .top-slider-wrapper, .header-bar-fixed ~ .signage {
        margin-top: 0 !important;
    }

    .header-bar {
        border-bottom: 0 !important;
        height: auto !important;
    }

    .header-bar-inner {
        display: flex !important;
        padding: 10px 15px;
    }

    .global-nav-button {
        display: block;
        z-index: 1000 !important;
    }

    .global-nav-button::before {
        display: none !important;
    }

    .global-nav {
        position: fixed !important;
        right: 0;
        top: 0;
        width: 0;
        height: 100% !important;
        z-index: 9999;
        display: block !important;
        overflow-y: scroll;
        transition: all 0.3s;
        opacity: 0;
        visibility: hidden;
        background: rgba(255, 255, 255, 0.8);
    }

    .header-bar .logo {
        line-height: 40px;
        margin-left: 0;
        width: auto;
    }

    .header-bar .logo img {
        max-height: 41px;
    }

    .content01-inner {
        padding: 40px 15px;
    }

    .content02-inner	{
        padding: 0 15px 40px;
    }

    .global-nav-button {
        border-left: none;
        font-size: 15px;
        height: auto;
        line-height: 1;
        padding: 25px 0 0;
        position: relative;
        width: 40px;
    }

    .global-nav-button::before, .global-nav-button::after {
        display: none;
    }

    .global-nav a {
        background: none;
    }
    .global-nav .sub-menu li:first-child a {
        border-top-left-radius: 0;
        border-top-right-radius: 0;
    }
    .global-nav .sub-menu li:last-child a {
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
    }
    .global-nav .sub-menu a {
        font-size: 14px;
        line-height: 51px;
        color: #463722 !important;
        background: #fff !important;
        padding: 0 25px;
    }
    .global-nav a:hover, .global-nav .sub-menu a:hover {
        color: #8C7E64 !important;
        background: #fff !important;
    }
    .global-nav > ul {
        align-items: center;
        justify-content: center;
        flex-direction: column;
        min-height: 100%;
    }

    .global-nav .menu-item-has-children > a span::before {
        color: #463722;
    }
    .header-bar-fixed .global-nav {
        top: 0;
    }
}

@media only screen and (min-width: 992px) and (max-width: 1199px) {
    .contact-text {
        flex-direction: column;
        align-items: start;
    }
}

@media only screen and (max-width: 991px) {
    .top-slider {
        height: 35vh !important;
    }

    .top-slider-content {
        background: rgba(0, 0, 0, 0.1);
        display: flex;
        align-items: flex-end;
        padding: 50px 15px 10px;
    }

    .top-slider-content-inner {
        height: auto !important;
        padding: 0;
    }

    .top-slider-wrapper .header-youtube, .top-slider-wrapper .header-video {
        /* height: calc(70vh - 55px); */
        height: 230px;
    }
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    .contact-text {
        flex-direction: column;
    }

    .contact-text .open-hour {
        font-size: 24px;
    }
}

@media only screen and (max-width: 767px) {
    .global-nav-button.active + .global-nav {
        width: 100%;
    }

    .content-inner {
        padding: 0 13px;
    }

    #index-text-1 {
        padding: 40px 0;
    }

    #index-text-1 .flex, #index-3column .flex {
        flex-direction: column;
    }

    .content01-img, .content01-text {
        width: 100%;
    }

    .content01-text {
        padding-top: 0px;
        padding-left: 0;
    }

    .content01-title {
        font-size: 5.4vw;
    }

    .content01-text h3 {
        font-size: 4.5vw;
    }

    .contact-text {
        align-items: start;
        flex-direction: column;
    }

    .content02-item .content02-body {
        padding: 0;
    }

    #index-3column .content02-item {
        margin-bottom: 20px;
    }

    .content02-item:nth-child(2) {
        flex-direction: column;
    }

    .content02-title {
        font-size: 6.1vw;
        margin-top: 0.5em;
    }

    #index-text-2 {
        background: url(img/concept-bg-m.png) no-repeat center / cover;
        padding: 70px 5px 150px;
        position: relative;
        z-index: 1;
    }

    #index-text-2:before {
        content: "";
        background: rgba(255,255,255,0.5);
        position: absolute;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        z-index: -1;
    }

    #index-points .flex {
        flex-direction: column;
        margin: 0;
    }

    #index-3column {
        padding: 0 0 20px;
    }

    .content03-item {
        padding: 0 0 50px;
        width: 100%;
    }

    .content03-item, .content03-item:nth-child(2n) {
        flex-direction: column;
    }

    .content03-item .content03-img, .content03-item .content03-text {
        padding-left: 0;
        width: 100%;
    }

    .content03-item .content03-title {
        font-size: 24px;
        margin: 0 0 20px;
    }

    #index-text-2 h2 {
        font-size: 5.3vw;
    }

    #index-text-2 .flex-button {
        flex-direction: column;
    }

    #index-text-2 .line-button {
        background-size: 44px auto;
        margin-left: 0;
        padding-left: 55px;
    }

    #index-blog .inner, #index-instagram .inner {
        padding: 0 15px;
    }

    .article03 {
        width: calc(50% - 15px/2);
        background: #f2f3ee !important;
    }

    .article03 .article03-content {
        padding: 10px !important;
    }

    .headline-primary span {
        display: block;
    }

    .top-slider-text {
        font-size: 14px !important;
        text-shadow: -1px -1px 0 #fff,
            1px -1px 0 #fff,
            -1px  1px 0 #fff,
            1px  1px 0 #fff;
    }

    .top-slider-logo {
        font-size: 6.1vw !important;
        line-height: 31px;
        font-weight: 900;
        margin-bottom: 0 !important;
        text-shadow: -1px -1px 0 #fff,
            1px -1px 0 #fff,
            -1px  1px 0 #fff,
            1px  1px 0 #fff;
    }

    .top-slider-logo::before, .top-slider-logo em::after {
        background-size: 100% auto;
        height: 28px;
        width: 37px
    }

    #index-points {
        z-index: 0;
        padding: 0 0 20px;
    }

    #topics-feed {
        padding: 50px 0;
    }

    #index-instagram {
        padding-top: 20px;
    }

    #topics-feed .flex {
        flex-wrap: wrap;
    }

    #topics-feed .blog-title, #topics-feed .top-blog {
        margin-bottom: 0;
        padding: 0;
        width: 100%;
    }

    #topics-feed .blog-title {
        border-right: none;
        margin: 0 0 30px;
    }

    #content01 .content01-img{
        max-width: 50%;
        margin-inline: auto;
        margin-top: 0;
        text-align: center;
    }

    #index-blog .headline-primary{
        margin: 0 0 24px;
    }

    #index-text-2 .flex {
        flex-direction: column;
    }

    #index-text-2 .concept-left, #index-text-2 .concept-right {
        width: 100%;
    }

    #index-text-2 .content01-title {
        font-size: 30px;
    }

    .content02-item h3 {
        font-size: 18px;
    }

    .footer-menu ul li {
        width: 50%;
    }

    .content01-title {
        margin-top: 20px;
        margin-bottom: 4px;
    }

    .footer-nav ul li {
        padding: 10px;
        width: 50%;
        text-align: center;
    }

    .blog .footer {
        margin-top: 0;
    }

    .footer {
        padding-bottom: 120px;
    }

    .footer .inner { 
        padding: 0 15px;
    }
}

@media screen and (min-width: 768px){
    .pcbr { display:block; }
    .hidepc,.spbr { display:none !important; }
}

@media screen and (max-width: 767px){
    .hidesp,.pcbr { display:none !important; }
    .spbr { display:block; }
    #menu-main-menu {
        width: 100%;
        padding: 30px 0;
    }
    .global-nav > ul#menu-main-menu > li > a {padding: 0; height: 100px;} 
}

@media screen and (max-width: 480px){
    .contact-text {
        font-size: 16px;
    }
    .contact-text .contact-tel {
        font-size: 9vw;
    }
    .contact-text .open-hour {
        font-size: 16px;
    }
}

@media only screen and (max-width: 767px) {
    p {
        font-size: 16px!important;
        line-height: 2;
    }
}