@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 small {
        font-size: 36px;
    }

    #index-1:before {
        left: 45px;
    }

    #index-2:before {
        right: 45px;
    }

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

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

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

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

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

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

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

    #content01:after {
        top: -140px;
        width: 181px;
        height: 260px;
    }

    #index-text-2:before {
        top: -30px;
        left: 50%;
        width: 131px;
        height: 113px;
        margin-left: -65px;
    }

    #index-2:after {
        top: 20px;
        width: 181px;
        height: 244px;
    }

    #index-blog:before {
        height: 175px;
        width: 105px;
        top: -105px;
    }

    .footer:before {
        background-size: 100px auto;
        height: 219px;
        width: 100px;
        top: -130px;
    }

    .footer:after {
        width: 181px;
        height: 188px;
    }
}

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

    .header-bar-fixed ~ .top-slider-wrapper {
        margin-top: 0;
    }

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

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

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

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

    .logo:before {
        width: 50px;
        height: 65px;
        top: -10px;
        left: -15px;
    }

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

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

    .global-nav-button {
        background-size: 25px auto;
        background-position: 15px center;
        border: none;
        display: block;
        font-size: 14px;
        height: 30px;
        line-height: 30px;
        padding: 0 15px 0 45px;
        position: static;
        width: auto;
        z-index: 1000;
    }

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

    .nav-toggle_line {
        top: 6px;
    }

    .nav-toggle_line._2 {
        top: 16px;
    }

    .nav-toggle_line._3 {
        top: 26px;
    }

}

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

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

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

    .top-slider-content-inner {
        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: 30px;
    }

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

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

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

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

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

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

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

    .content01-text address {
        font-size: 20px;
        line-height: 1.5;
    }

    .content01-text .contact-tel {
        display: block;
        font-size: 42px;
        margin-left: 0;
    }

    .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, #index-points .flex {
        flex-direction: column;
    }

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

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

    #index-text-1 .content02-button {
        margin: 15px 0 0;
    }

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

    .slider-nav {
        margin-top: -15px;
    }

    .slider-nav .slick-slide img {
        height: auto;
    }

    .concept-body, .concept-img {
        width: 100%;
    }

    .concept-body {
        margin: 15px 0 0;
    }

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

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

    #index-text-2 .content02-button {
        margin: 15px 0 0;
    }

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

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

    .content03-item:not(:first-child) {
        margin-left: 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 {
        display: none;
        font-size: 18px !important;
    }

    #content01 .content01-img{
        margin: 0 0 30px;
        text-align: center;
    }

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

    #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: 28px;
    }

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

    .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 .flex {
        flex-direction: column;
    }

    .footer-left, .footer-right {
        width: 100%;
    }

    .footer-left {
        padding-right: 0;
    }

    .footer-right {
        padding: 0;
    }

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

    .footer-contact li {
        width: 100%;
    }

    .footer-logo {
        margin-bottom: 25px;
        text-align: left;
    }	

    .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: 0 30px;
    }

    .copyright {
        font-size: 14px;
        margin: 0;
        padding:0;
        text-align: left;
    }

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

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

    #content01:after {
        top: -20px;
        width: 68px;
        height: 98px;
    }

    #index-1:before {
        left: 0;
        top: 50px;
        bottom: 50px;
    }

    #index-2:before {
        right: 0;
        top: 50px;
        bottom: 50px;
    }

    #index-2:after {
        display: none;
    }

    .footer:after {
        background-size: 186px auto;
        height: 194px;
        width: 186px;
    }
	
	.footer:before {
		top: -80px;
	}
}

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

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

.signage:not(:has(.signage-content)){
    height: 260px;
    margin-top: 60px;
}
@media only screen and (min-width: 768px){
    .signage:not(:has(.signage-content)){
        height: 360px;
        margin-top: 100px;
    }
}