@charset "UTF-8";
/* ----------------------------------------------------------------------
 基本設定
---------------------------------------------------------------------- */
@media only screen and (max-width: 1600px) {
	.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: 40px;
	}
	
	.content02-title {
		font-size: 24px;
	}
	
	.content02-button {
		font-size: 20px;
	}
	
	.content03-item .content03-title {
		font-size: 32px;
		line-height: 1.2;
	}
	
	.content03-item .content03-body {
		margin: 30px 0 auto;
	}
	
	.contact-text .contact-tel {
		font-size: 36px;
	}
	
	#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;
	}
	
	#index-text-2 h3, #index-text-2 .contact-text .contact-tel {
		font-size: 48px;
	}
	
	.concept-text {
		width: 60%;
	}
}

@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;
		box-shadow: none;
    }

    .header-bar-inner {
        display: flex !important;
        padding: 10px 15px;
    }
	
	.footer {
		background: #5774a8 ;
		position: relative;
		z-index: 1;
	}
	
	.footer-left {
		padding: 60px 45px 30px 45px;
		width: 100%;
	}
	
	.logo, .logo img {
		max-height: none;
	}
	
	.logo {
		margin-left: 0;
		width: 120px;
	}
	
	.scrolled .logo {
		width: 80px;
	}

	body:not(.home) .logo {
		width: 80px;
	}
	
	.global-nav-button {
		border-left: none;
		font-size: 16px;
		height: auto;
		right: 15px;
		width: auto;
		line-height: normal;
	}
	
	.concept-text {
        width: 100%;
    }
	
	.content03-item .content03-text {
		padding-left: 30px;
	}
	
	.content01-text {
		padding-left: 30px;
	}
	
	.contact-text .contact-tel {
        font-size: 28px;
        padding-bottom: 5px;
    }
	
	#topics-feed h2 {
		padding: 0;
	}
}

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

    .top-slider-content {
        display: flex;
        align-items: flex-end;
    }

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

    .top-slider-wrapper .header-youtube, .top-slider-wrapper .header-video {
        height: calc(36vh - 55px);
    }
	
	.top-slider {
        margin: 0 15px;
    }
}

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

    #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;
		margin-bottom: 15px;
    }
	
	.content02-inner {
        padding: 0 15px 90px;
    }

    #index-3column .content02-item:not(:last-child) {
        margin-bottom: 50px;
    }
	
	.content02-item {
		padding-bottom: 20px;
	}

    #index-text-2 {
		background: url(img/concept-bg-mobile.png) no-repeat center top;
		background-size: cover;
    }
	
	.content03-item .flex {
		flex-direction: column;
	}
	
	.content03-item:not(:last-child) {
	  padding-bottom: 50px;
	}

    .content03-item .content03-img, .content03-item .content03-text {
		padding-left: 0;
        width: 100%;
    }
	
	.content03-item h2 {
		font-size: 24px;
		line-height: normal;
		margin: 0 0 20px;
	}
	
	.content03-item h2 span {
		display: block;
	}
	
	.slider-nav, .slider-nav-2, .slider-nav-3 {
	  margin: 20px 0 0;
	}
	
	.point-number em {
		font-size: 120px;
		margin: 0 0 0 -10px;
	}
	
	.content03-item:nth-child(even) .content03-img {
		padding-left: 0;
	}
	
	.content03-item .content03-title {
		font-size: 24px;
		margin: 20px 0;
	}
	
	.content03-item h3 span {
	  font-size: 16px;
	  letter-spacing: 1px;
	}

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

    .article03 {
        background: #fff !important;
		width: 100%;
    }
	
	.article03:nth-of-type(odd) {
        margin-right: 0;
    }

    .article03 .article03-content {
        padding: 10px !important;
    }
	
	#index-blog .article03-title {
		height: auto;
	}

    .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;
    }
	
	#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: 32px;
		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 {
		margin: 20px 0 0;
		width: auto;
	}
	
	.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 {
		margin: 0px 0 auto;
	}
	
	.footer {
        margin-top: 0;
    }
	
	.footer-inner {
		display: flex;
		flex-direction: column-reverse;
	}
	
	.footer-left-inner {
		flex-direction: column;
	}
	
	.footer-left {
		padding: 60px 15px 30px;
		width: 100%;
	}
	
	.footer-widgets {
		margin: 0 0 20px;
	}
	
	.copyright {
		padding:0;
	}
	
	.footer .content02-button {
		margin: 0;
	}
	
	.footer .social-nav {
		margin: 0 0 0 20px;
	}
	
	.top-slider-wrapper:before,
	.top-slider-wrapper:after,
	#index-text-2:after, #index-blog:after {
		background-size: 100% auto;
		width: 92px;
		height: 253px;
	}
	
	.concept-text {
		width: 100%;
	}
	
	#index-text-2 .contact-text .contact-tel {
		background-size: 24px auto;
		font-size: 40px;
		padding-left: 30px;
	}
	
	#index-text-2 .contact-text .open-title {
	  padding-left: 30px;
	}
	
	#topics-feed .flex {
		flex-direction: column;
	}
	
	#topics-feed h2 {
		border-right: none;
		font-size: 40px;
		margin: 0 0 30px;
	}	
	
	#topics-feed h2, #topics-feed .top-blog {
		padding: 0;
		width: 100%;
	}
	
	.passive-design-balance {
		margin: 0;
		padding: 2em;
	}
	
	.footer-menu {
		padding-left: 0;
	}
	
	.visible-phone {
		display: inherit;
	}
	
	.hidden-phone {
		display: none;
	}
	
	.post-content p:empty {
		margin-bottom: 0;
	}
	
	.passive-design-intro, .passive-design-detail {
	  margin-bottom: 0;
	}
	
	.third-box {
		margin-bottom: 1em;
	}
	
	.passive-design-detail-img {
		margin: 0;
	}
	
	.passive-design-close {
		padding: 0 0 2em;
	}
}

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

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