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

    .top-slider-content-inner {
        padding: 15px 45px 20px 45px;
    }

    .top-slider-logo { 
        font-size: 56px;
    }

    .top-slider-logo strong {
        font-size: 94px;
    }

    .top-slider-logo small {
        font-size: 36px;
    }

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

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

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

    .content02-button {
        font-size: 20px;
    }

    .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;
    }

    .footer-inner {
        padding: 0 45px;
    }

    .content03-item:not(:first-child) .content03-img {
        margin-top: 0px;
    }
}

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

    .header-bar-fixed ~ .signage {
        margin-top: 65px;
    }

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

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

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

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

    .header-bar-fixed .global-nav {
        position: fixed;
        top: 0;
    }

    .global-nav-button {
        border: none;
        display: block;
        font-size: 14px;
        height: auto;
        line-height: 1;
        padding: 18px 0 0;
        position: relative;
        width: auto;
        z-index: 1000;
    }

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

    .nav-toggle_line {
        width: 8px;
        height: 8px;
    }

    .nav-toggle_line._2 {
        margin-left: -4px;
    }

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

    .global-nav > ul {
        align-items: center;
        justify-content: center;
        flex-direction: column;
        min-height: 100%;
    }

    .global-nav > ul > li > a {
        height: 100px;
    }

    .global-nav > ul > li > a::after, .global-nav .current-menu-item > a::after {
        bottom: 15px;
    }

    .global-nav > ul > li > a{
        overflow: visible;
    }
    .global-nav .menu-item-has-children > a span::before{
        top: 50%;
        right: 0;
        color: #666;
        transform: translate(50%, -50%);
    }
    .global-nav .sub-menu li a{
        font-size: 16px;
    }
}

@media only screen and (max-width: 991px) {
    .top-slider-wrapper {
        display: block;
    }

    .top-slider {
        height: calc(50vh - 55px) !important;
        width: 100%;
    }

    .top-slider-content {
        width: 100% !important;
    }

    .top-slider-content-inner {
        height: 100% !important;
        padding: 15px 15px 20px 15px;
        width: 100% !important;
    }

    .top-slider-text {
        position: static;
    }

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

    .top-slider-logo {
        margin: 0;
        font-size: 36px;
    }

    .top-slider-logo strong {
        font-size: 50px;
    }

    .top-slider-logo small {
        font-size: 24px;
    }
}

@media only screen and (max-width: 767px) {	
    .top-slider-logo {
        margin: 0;
        width: 152px;
    }

    .global-nav-button.active + .global-nav {
        width: 100%;
    }

    .top-slider-content-inner::after, .top-slider-content-inner:before {
        display: none;
    }

    p {
        font-size: 16px;
        line-height: 2;
    }

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

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

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

    .content01-text {
        padding-bottom: 20px;
        padding-right: 0;
    }

    .contact-text {
        flex-direction: column;
    }

    .contact-text .contact-tel {
        font-size: 42px;
    }

    .contact-text .contact-line {
        margin: 10px 0 0;
    }

    .content01-img img {
        width: 50%;
    }

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

    #index-points .content02-inner {
        padding: 0 15px;
    }

    #index-text-2 .contact-text .contact-tel {font-size: 32px;}
    #index-text-2 .contact-text {
        font-size: 18px;
        margin-top: 30px;
    }
    #index-text-2 .open-title {
        padding: 0 20px;margin-top: 24px;
    }

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

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

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

    .content02-button {
        height: auto;
        line-height: inherit;
        max-width: none;
        margin: 15px auto 0;
        width: auto;
    }

    .concept-slider {
        padding: 0 0 50px;
    }

    .concept-slider .slick-slide p {
        margin: 0 10px;
    }

    .concept-img {
        margin: 0 0 40px;
    }

    #index-text-2 h4 {
        font-size: 24px;
    }

    .content03-item {
        flex-direction: column;
        padding: 0;
    }

    .content03-item:not(:first-child) {
        margin-top: 0;
    }

    .content03-item:not(:last-child) {
        padding: 0 0 40px;
    }

    .content03-item:nth-child(even) {
        flex-direction: column;
    }

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

    .content03-item:nth-child(even) .content03-img {
        padding-left: 0;
    }

    .content03-item h3 {
        margin: 20px 0 0;
    }

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

    .content03-text p {
        font-size: 16px;
    }

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

    .article03 {
        background: #f9f7df;
    }

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

    .headline-primary span {
        display: block;
    }

    .top-slider-text {
        font-size: 18px !important;
    }

    #content01 .content01-img{
        text-align: center;
    }

    #index-blog{
        padding-top: 30px;
    }

    #index-blog .headline-primary, #index-instagram .headline-primary {
        font-size: 32px;
        margin: 0 0 24px;
    }

    #index-instagram {
        padding: 0 0 50px;
    }

    #index-instagram .follow-btn {
        right: 15px;
    }

    #index-text-2 .content01-inner {
        padding-left: 15px;
        padding-right: 15px;
    }

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

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

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

    .text02-button {
        font-size: 20px;
        padding: 15px 15px 15px 110px;
    }

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

    .content01-title {
        font-size: 24px;
        margin-bottom: 20px;
    }

    .content01-title small {
        font-size: 24px;
    }

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

    .content03-item:nth-child(2n+1) .content03-text {
        padding-left: 0;
        padding-right: 0;
    }

    .content03-item:not(:first-child) .content03-img {
        margin-top: 0;
    }

    .content03-item .content03-body {
        border-left: none;
    }

    .content03-item:nth-child(2n) .content03-text {
        padding-right: 0;
    }

    .article03-title {
        margin: 0;
    }

    .footer {
        margin-top: 0;
    }

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

    .footer-logo img {
        width: 200px;
    }	

    .footer .footer_address, .footer .footer_phone {
        display: block;
    }

    .footer .footer_address {
        font-size: 18px;
    }

    .footer .footer_phone {
        margin-left: 0;
    }

    .footer-menu {
        margin: 50px 0 0;
    }

    .footer-menu ul li {
        padding: 10px 30px;
    }

    .copyright {
        margin: 0;
        padding:0;
    }

    .top-slider-wrapper:before,
    .top-slider-wrapper:after,
    #index-text-2:after, #index-blog:after {
        background-size: 100% auto;
        width: 92px;
        height: 253px;
    }

    .blog-inner .headline-primary {
        line-height: 1;
    }

    .blog-inner .headline-primary img {
        height: 30px;
        width: auto;
    }

    .admin-bar .header-bar-fixed {
        top: 46px;
    }

    .contact-text > span {
        flex-direction: column;
    }

    .contact-text .contact-tel {
        letter-spacing: 1px;
    }

    #index-instagram .flex {
        flex-direction: column;
        align-items: start;
    }

    .hidden-phone {
        display: none;
    }

    .visible-phone {
        display: block;
    }
}

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

@media screen and (max-width: 767px){
    .pcbr { display:none; }
    .spbr { display:block; }
    .footer_phone_nmber {
        display: flex;
        flex-direction: column;
    }
    .content03-item .content03-text::before {
        bottom: -30px;
        width: 30px;
        height: 81px;
        background-size: cover;
    }
    .signage:not(:has(.signage-content)){
        height: 260px;
    }
}

@media only screen and (max-width: 575px) {
    .global-nav > ul > li > a {
        line-height: 80px;
        height: 80px;
    }

    .global-nav > ul > li > a::after, .global-nav .current-menu-item > a::after {
        bottom: 5px;
    }
}
@media only screen and (max-width: 767px){
    #index-3column .content02-item{
        margin-bottom: 20px;
    }
    .content02-title{
        margin-top: 20px;
    }
    .front-original02__text {
        max-width: none;
    }
    .accordion-box {
        position: relative;
    }
    .accordion-box input {
        display: none;
    }
    .accordion-box label {
        height: 140px;
        cursor: pointer;
        text-align: center;
        font-size: 12px;
        position: absolute;
        bottom: -80px;
        width: 100%;
    }
    .accordion-box label:before {
        content: "↓";
        font-weight: 700;
        position: absolute;
        bottom: 30px;
        left: 50%;
        -webkit-transform: translate(-140px, 0);
        transform: translate(-140px, 0);
        background-color: #fff;
        z-index: 1;
        -webkit-border-radius: 100%;
        -moz-border-radius: 100%;
        border-radius: 100%;
        width: 20px;
        height: 20px;
        line-height: 20px;
    }
    .accordion-box label:after {
        content: "続きをよむ";
        letter-spacing: .05em;
        line-height: 2.5rem;
        position: absolute;
        bottom: 20px;
        left: 50%;
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0);
        color: #fff;
        background-color: #b1a28f;
        width: 18.75rem;
        -webkit-border-radius: 20px;
        -moz-border-radius: 20px;
        border-radius: 20px;
    }
    .accordion-box .accordion-container {
        overflow: hidden;
        height: 200px;
        -webkit-transition: all 0.1s;
        -moz-transition: all 0.1s;
        -ms-transition: all 0.1s;
        -o-transition: all 0.1s;
        transition: all 0.1s;
    }
    .accordion-box input:checked ~ .accordion-container {
        height: auto;
        padding-bottom: 80px;
        -webkit-transition: all 0.1s;
        -moz-transition: all 0.1s;
        -ms-transition: all 0.1s;
        -o-transition: all 0.1s;
        transition: all 0.1s;
    }
}

@media only screen and (min-width: 768px) {
    .spshow {
        display: none;
    }
}