@charset "UTF-8";
/* ----------------------------------------------------------------------
 基本設定
---------------------------------------------------------------------- */
@media only screen and (max-width: 1600px) {
	.logo {
		width: 300px;
	}
	
	.top-slider {
		margin: 0 45px;
	}
	
	.top-slider-content-inner {
		padding: 15px 15px 20px 45px;
	}
	
	.top-slider-logo { 
		font-size: 56px;
	}
	
	.top-slider-logo span {
		font-size: 26px;
	}
	
	.content01-inner {
		padding: 100px 45px;
	}
	
	.content02-inner {
		padding: 0 45px 180px;
	}

	.content01-title {
		font-size: 50px;
	}
	
	.contact-text .contact-tel {
		font-size: 50px;
	}
	
	.content02-title {
		font-size: 24px;
	}
	
	.content02-button {
		font-size: 20px;
	}
	
	.content03-item .content03-title {
		font-size: 40px;
		margin: 0 0 20px;
	}
	
	.content03-item .content03-body {
		padding: 0 30px;
	}
	
	#index-text-2 .content01-inner {
		padding-left: 45px;
		padding-right: 45px;
	}
	
	#index-text-2 h2 {
		font-size: 45px;
	}
	
	#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 {
		position: fixed;
		right: 0;
		top: 0;
		width: 0;
		height: 100vh !important;
		z-index: 50;
		align-items: center;
		justify-content: center;
		display: flex !important;
		transition: all 0.3s;
		opacity: 0;
		visibility: hidden;
		background: rgba(255, 255, 255, 0.8);
	}
	
    .global-nav-button {
		display: block;
        z-index: 1000 !important;
    }

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

    .global-nav-button.active .nav-toggle_line:nth-of-type(1) {
        transform: translateY(12px) rotate(-45deg);
    }

    .global-nav-button.active .nav-toggle_line:nth-of-type(3) {
        transform: translateY(-15px) rotate(45deg);
    }

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

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

    .content01-inner {
        padding: 40px 15px;
    }
	
	.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;
	}
	
	.nav-toggle_line {
		width: 40px;
	}
	
	.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: 12px;
        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 > li > a:before {
        content: none !important;
    }
    .global-nav .menu-item-has-children > a span::before {
        color: #463722;
    }
	.header-bar-fixed .global-nav {
		top: 0;
	}
	.global-nav > ul > li > a {
		height: 100px;
	}
	.global-nav > ul > li > a::before, .global-nav .current-menu-item > a::before { 
		top: 45px;
	}
	
	.contact-text {
		flex-direction: column;
	}
}

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

    .top-slider-content {
        display: flex;
        align-items: flex-end;
		top: auto;
		bottom: -180px;
    }

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

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

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

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

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

    .content01-text {
        padding-top: 20px;
        padding-left: 0;
    }
	
	.contact-text {
		flex-direction: column;
	}
	
	.contact-text .contact-tel {
        font-size: 42px;
    }
	
	.content02-inner {
        padding: 0 15px 90px;
    }
	#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 .content02-item:not(:last-child) {
        margin-bottom: 78px;
    }

    .content02-button {
        height: 48px;
		line-height: 48px;
        max-width: none;
        margin: 0;
        position: absolute;
		width: auto;
    }

    #index-text-2 {
        padding-bottom: 50px;
    }
	
	.content03-item:not(:last-child) {
	  padding: 0 0 50px;
	}

    .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 h2 em {
        font-size: 80px;
		margin-top: -60px;
		margin-left: -10px;
    }
	
	.content03-item h2 span {
		font-size: 20px;
		margin-left: -10px;
	}
	
	.content03-item:nth-child(even) .content03-img {
		padding-left: 0;
	}
	
	.content03-item .content03-title {
		font-size: 24px;
		margin: 0 0 20px;
	}
	
	.content03-item h3 span {
	  font-size: 16px;
	  letter-spacing: 1px;
	}

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

    .article03 {
        background: #fff !important;
    }

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

    .headline-primary span {
        display: block;
    }
	
    .top-slider-text {
        font-size: 12px !important;
    }

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

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

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

    #index-blog{
        padding-top: 30px;
    }
	
    #index-blog .headline-primary{
        margin: 0 0 24px;
    }
	
	#index-text-2 .content01-inner {
        padding-left: 15px;
        padding-right: 15px;
		padding-bottom: 100px;
		background: rgba(0,0,0,0.3);
    }
	
	#index-text-2 .flex {
		flex-direction: column;
	}
	
	#index-text-2 h2 {
        font-size: 34px;
    }
	
	#index-text-2 h2 strong {
        font-size: 36px;
    }
	
	#index-text-2 .concept-left, #index-text-2 .concept-right {
		width: 100%;
	}
	
	#index-text-2 .content01-title {
		font-size: 30px;
	}
	
	#index-text-2 h3 {
		font-size: 18px;
		margin-top: 50px;
		writing-mode: horizontal-tb;
	}
	
	.text02-button {
		padding: 15px;
	}
	
	.text02-button span {
        font-size: 16px;
		padding-right: 24px;
    }
	
	.text02-button strong {
		background-size: 18px auto;
        font-size: 18px;
		padding-left: 24px;
    }
	
	.content02-button {
		width: auto;
	}
	
	.content02-item h3 {
		font-size: 18px;
	}
	
	.footer-menu ul li {
		width: 50%;
	}
	
	.content01-title {
		font-size: 32px;
		margin-bottom: 24px;
	}
	
	.content03-item .content03-text {
		flex-direction: column;
	}
	
	.content03-item .content03-img {
		margin-bottom: 20px;
	}
	
	.content03-item .content03-body {
		border-left: none;
	}
	
	.footer {
        margin-top: 0;
    }
	
	.footer-inner {
		display: flex;
		flex-direction: column-reverse;
	}
	
	.footer-left-inner {
		flex-direction: column;
	}
	
	.footer-left {
		padding: 60px 15px 30px;
	}
	
	.footer-widgets {
		margin: 0 0 20px;
	}
	
	.copyright {
		padding:0;
	}
	
	.top-slider-wrapper:before,
	.top-slider-wrapper:after,
	#index-text-2:after, #index-blog:after {
		background-size: 100% auto;
		width: 60px;
		height: 160px;
	}
	
	.top-slider-wrapper:after {
		bottom: 0;
	}
}

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