@charset "UTF-8";
/* ----------------------------------------------------------------------
 基本設定
---------------------------------------------------------------------- */
@media only screen and (max-width: 1600px) {
    .top-slider-content-inner {
        padding-left: 45px;
        padding-right: 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-text h3 {
        font-size: 30px;
    }

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

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

    .content03-item .content03-title {
        font-size: 40px;
    }

    .content03-title strong {
        font-size: 56px;
    }

    .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: 1200px) {
    .header-bar-fixed ~ .top-slider-wrapper {
        margin-top: 60px;
    }

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

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

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

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

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

    .global-nav {
        display: block !important;
        position: fixed !important;
        right: 0;
        top: 0;
        width: 0;
        height: 100% !important;
        overflow-y: auto;
        z-index: 9999 !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 {
        background-position: center 10px;
        font-size: 18px;
        height: 100px;
    }

    .global-nav > ul > li > a::before {
        content: "";
    }

    .global-nav > ul > li > a span {
        display: block;
    }

    .global-nav > ul > li.menu-item-contact {
        padding: 20px 0;
    }

    .global-nav > ul > li.menu-item-contact > a {
        color: #667F57 !important;
    }
}

@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-wrapper .header-youtube, .top-slider-wrapper .header-video {
        /* height: calc(70vh - 55px); */
        height: 350px;
    }

    .top-slider-content-inner h2 {
        font-size: 40px;
    }

    .top-slider-content-inner h2 small {
        font-size: 32px;
    }

    .top-slider-logo {
        display: none;
    }
}

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

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

    .top-slider-content-inner::after, .top-slider-content-inner:before {
        display: none;
    }
    .top-slider-wrapper{
        margin-inline: 0;
    }
    .top-slider span {
        border-radius: 0;
    }

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

    .content-index {
        padding-left: 0px;
        padding-right: 0px;
    }

    .content-index .content-inner {
        border-radius: 50px;
    }

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

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

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

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

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

    .contact-text span {
        font-size: 16px;
    }

    .contact-text span.contact-title {
        font-size: 20px;
    }

    .contact-tel {
        font-size: 40px;
    }

    .contact-line {
        font-size: 20px;
    }

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

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

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

    #index-3column .content02-item:last-of-type {
        margin-bottom: 0;
    }

    .content02-button {
        font-size: 18px;
        max-width: none;
        margin: 15px 0 0 auto;
        width: 100%;
    }

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

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

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

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

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

    .content03-item .content03-title {
        font-size: 24px;
        padding-left: 30px;
    }

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

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

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

    .article03 {
        background: #f7f2de;
    }

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

    .headline-primary span {
        display: block;
    }

    .top-slider-text {
        font-size: 7.4vw !important;
        line-height: 43px;
    }

    #content01 .content01-img{
        padding-left: 0;
    }

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

    .top-blog {
        border-left: none;
        padding-left: 0;
    }

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

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

    #index-instagram .follow-btn {
        font-size: 18px;
        line-height: 42px;
        right: 15px;
        padding: 0 40px 0 10px;
    }

    #index-instagram .follow-btn:after {
        right: 10px;
        top: 6px;
    }

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

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

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

    #index-text-2 h2 {
        font-size: 7vw;
        margin: 15px 0;
    }

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

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

    .text02-button {
        padding: 0 10px 0 52px;
        background-size: 32px auto;
        background-position: 10px center;
        font-size: 24px;
        margin: 20px 0 0;
    }

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

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

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

    .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 {
        font-size: 16px;
        margin: 0;
    }

    .footer {
        padding-bottom: 80px;
    }

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

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

    .footer-left, .footer-center, .footer-right {
        border-left: none;
        padding: 0;
        width: 100%;
    }

    .footer-right {
        padding: 30px 0 0;
    }

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

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

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

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

    .footer-right h3 {
        margin-top: 40px;
    }

    .footer-menu {
        margin: 30px 0;
    }
	
	.footer-menu ul {
		justify-content: start;
	}

    .footer-menu ul li {
        padding: 10px 0;
        width: 50%;
    }

    .social-links {
        justify-content: center;
    }

    .copyright {
        margin: 10px 0 0;
        text-align: center;
    }

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

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

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

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

    .hidden-phone {
        display: none;
    }

    .visible-phone {
        display: block;
    }
	
	table.size_tbl {
		border: 2px solid #ffeba3;
		white-space: normal;
	}

	table.size_tbl, table.size_tbl tbody, table.size_tbl tr, table.size_tbl th, table.size_tbl td {
		display: block;		
		width: 100% !important;
	}
	
	table.size_tbl tr:not(:last-child) {
		border-bottom: 2px solid #ffeba3;
	}
	
	table.size_tbl th, table.size_tbl td {
		background: #fffcef !important;
		border: none !important;
		padding: 0 12px !important;
	}
	
	.slider-text {
		font-size: 7vw;
		padding: 15px;
	}
}

@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: 767px){
    .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;
    }
}

@media only screen and (max-width: 767px) {
    .contact-tel {
        background-size: 32px auto;
        font-size: 24px;
        padding-left: 40px;
    }

    .footer-logo a.social-nav-instagram {
        right: -50px;
    }
	.header-bar-fixed ~ .top-slider-wrapper {
		height: 300px;
		min-height: 0;
	}
		.top-slider-wrapper .scroll-infinity {
	  background: #fff;
	  padding: 10px;
	}
	.top-slider-wrapper .slider-left {
	  width: 70px;
	}
	.top-slider-wrapper .slider-right {
	  width: 70px;
	}
	.scroll-infinity__item {
	  width: calc(100vw / 3);
	}
}