@charset "UTF-8";
/* ----------------------------------------------------------------------
 基本設定
---------------------------------------------------------------------- */
@media only screen and (max-width: 1600px) {
	.top-slider {
		margin: 0 45px;
	}
	
	.top-slider-content-inner {
		padding: 15px 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: 45px;
	}
	
	.contact-text .contact-tel {
		font-size: 50px;
	}
	
	.content02-title {
		font-size: 24px;
		padding-top: 5px;
		padding-bottom: 5px;
	}
	
	.content02-button {
		font-size: 20px;
	}
	
	#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;
	}
	
	.footer-inner {
		padding: 70px 45px;
	}
	
	.global-nav > ul > li {
	  padding: 0 15px;
	}
	
	.logo {
		width: 210px;
	}
	
	.scrolled .logo {
	  width: 210px;
	}
	
	.admin-bar .header-bar-fixed ~ .top-slider-wrapper, .header-bar-fixed ~ .top-slider-wrapper {
		margin-top: 80px;
	}
	
	.header-bar-fixed ~ .signage {
		margin-top: 76px;
	}
	.contact-text {
		flex-direction: column;
	}
}

@media only screen and (min-width: 1201px) and (max-width: 1439px) {
	.global-nav > ul {
		margin: 0 -10px;
	}
	.global-nav > ul > li {
		padding: 0 10px;
	}
	.global-nav > ul > li > a {
		background-size: 30px auto;
		font-size: 18px;
	}
	.global-nav > ul > li > a span {
		font-size: 14px;
	}
}

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

    .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;
		overflow-y: scroll;
		z-index: 50;
		align-items: flex-start;
		justify-content: center;
		display: flex !important;
		transition: all 0.3s;
		opacity: 0;
		visibility: hidden;
		background: rgba(255, 255, 255, 0.8);
	}
	.global-nav ul#menu-main-menu{margin:30px 0;}
	
    .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: 50px 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, .global-nav .current-menu-item > a::before {
		opacity: 0.25;
	}
    .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 {
		background-position: left 38px;
		height: 100px;
		padding: 0 0 0 44px;
	}
	.global-nav > ul > li > a::before, .global-nav .current-menu-item > a::before { 
		top: 45px;
	}
}

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

    .top-slider-content {
        position: static;
    }
	
    .top-slider-content-inner {
		align-items: start;
        height: auto !important;
        padding: 15px 15px 20px 15px;
		width: 100% !important;
    }

    .top-slider-wrapper .header-youtube, .top-slider-wrapper .header-video {
        /* height: calc(70vh - 55px); */
        height: 230px;
    }
	
	.top-slider {
        margin: 0 15px;
    }
	
	.top-slider-logo {
		max-width: 100%;
	}
}

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

    .content02-button {
        height: 40px;
		line-height: 40px;
        max-width: none;
        margin: 20px auto 0;
		width: 190px;
    }

    #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: 20px 0;
	}
	
	.content03-item .content03-title 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: 16px !important;
    }

    #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;
    }
	
	#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 .concept-left {
		padding-right: 0;
	}
	
	#index-text-2 .content01-title {
		font-size: 30px;
	}
	
	#index-text-2 h3 {
		font-size: 18px;
		margin-top: 50px;
		writing-mode: horizontal-tb;
	}
	
	.content02-item h3 {
		font-size: 18px;
	}
	
	.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;
	}
	
	.content03-item:nth-child(2n) .content03-text {
		padding-right: 0;
	}
	
	.footer {
        margin-top: 0;
    }
	
	.footer-inner {
		flex-direction: column-reverse;
	}
	
	.footer-left-inner {
		flex-direction: column;
		padding: 70px 15px;
	}
	
	.footer-left, .footer-center, .footer-right {
		width: 100%;
	}
	
	.footer-center {
		border: none;
	}
	
	.footer-center, .footer-right {
		padding: 0;
	}
	
	.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: 92px;
		height: 253px;
	}
	
	.blog-inner .headline-primary {
		line-height: 1;
	}
	
	.blog-inner .headline-primary img {
		height: 30px;
		width: auto;
	}
	
	#index-blog .article03-title {
		font-size: 14px;
		height: 45px;
	}
	
	.copyright {
		text-align: center;
	}
}

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

@media screen and (max-width: 767px){
    .pcbr { display:none; }
    .spbr { display:block; }
	.header {
	  position: relative;
	  max-height: calc(100vh - 68px);
	  z-index: 999999999;
	}
	#global-nav{height:calc(100vh - 68px) !important;align-items: flex-start;}
	ul#menu-main-menu{margin:30px 0;}
	.footer_phone_nmber {
	  display: flex;
	  flex-direction: column;
	}
	.content03-item .content03-text::before {
	  bottom: -30px;
	  width: 30px;
	  height: 81px;
	  background-size: cover;
	}
	body .dp-footer-bar {z-index: 99999999999;}
}

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