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

	.content01-title {
		font-size: 36px;
	}
	
	.content01-text h3 {
		font-size: 20px;
		line-height: 30px;
	}
	
	.content02-title {	
		font-size: 36px;
	}
	
	.content02-item h4 {
		font-size: 24px;
	}

	.concept-img {
		margin: 0 -45px;
	}
	
	.text02-button strong {
		font-size: 22px;
	}
	
	.text02-button span {
		font-size: 18px;
	}
	
	#index-text-2 .open-title {
		padding: 0 10px;
	}
	
	.global-nav > ul > li {
	  padding: 0 15px;
	}
	
	.header-bar-fixed ~ .signage {
		margin-top: 76px;
	}
	
	.footer-inner .footer-left {
		padding: 60px 45px;
	}
	
	.contact-left p {
		font-size: 18px;
	}
	
	.section-title h2 {
		font-size: 48px;
	}
	
	.work-item p {
		line-height: 1.6;
	}
	
	#index-area .contact-text {
		padding: 20px;
	}
}

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

    .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: auto;
		z-index: 50;
		align-items: center;
		justify-content: center;
		display: flex !important;
		transition: all 0.3s;
		opacity: 0;
		visibility: hidden;
		background: rgba(0, 0, 0, 0.8);
	}
	
	.global-nav ul#menu-main-menu {
		flex-direction: column;
		margin:30px 0;
	}
	
    .global-nav-button {
		display: block;
        z-index: 1000 !important;
    }

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

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

    .header-bar .logo img {
        max-height: 31px;
    }
	
	.content-inner {
		padding: 0 15px;
	}

    .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::before, .global-nav .current-menu-item > a::before { 
		top: 45px;
	}
	.footer-inner > .flex {
		flex-direction: column;
	}
}

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

    .top-slider-content {
		padding: 20px 15px;
    }

    .top-slider-wrapper .header-youtube, .top-slider-wrapper .header-video {
        /* height: calc(70vh - 55px); */
        height: 230px;
    }
	
	.top-slider-text {
		color: #000 !important;
		display: none;
	}
}

@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-img p {
	  margin: 0;
	}

    .content01-text {
        padding-top: 20px;
        padding-left: 0;
    }
	
	.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-item:nth-child(2) {
		flex-direction: column;
	}
	
	.content02-item .content02-body {
		padding: 20px;
	}

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

    #index-text-2 {
        padding-bottom: 50px;
    }
	
	#index-points .flex, #index-3column .flex {
		flex-direction: column;
	}
	
	.content03-item {
		margin-left: 0;
		width: 100%;
	}
	
	.content03-item:not(:last-child) {
	  padding-bottom: 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;
	}

    #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: 15px !important;
		padding-top: 0;
		width: 100%;
    }
	
	.top-slider-text strong {
		font-size: 32px;
		line-height: 1.4;
		margin: 0 0 5px;
	}
	
	.top-slider-text small {
		font-size: 18px;
	}

    #content01 .content01-img{
        text-align: center;
    }
	
	#index-text-1 .text-right {
		margin-right: 0;
	}

    #index-area {
        padding: 50px  0 0;
    }
	
	#index-blog {
	  padding: 50px 0;
	}
	
	#index-instagram {
		padding: 0 0 50px;
	}
	
	#index-bottom h2.headline-primary {
		font-size: 30px;
	}
	
	#index-text-2 .flex {
		flex-direction: column;
	}
	
	#index-text-2 h2 {
        font-size: 26px;
    }
	
	#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;
	}
	
	#index-3column {
		padding: 50px 0;
	}
	
	#index-text-1, #index-points {
		padding: 50px 0;
	}
	
	#index-works, #index-price {
		padding: 50px 0;
	}
	
	#index-points .content02-button {
		margin: 20px 0 0 auto;
	}
	
	#index-3column h2 b {
		font-size: 60px;
	}
	
	#index-3column h2 strong {
		font-size: 32px;
	}
	
	.content02-item h3 {
		font-size: 24px;
	}
	
	.content01-title {
		font-size: 28px;
		margin-bottom: 24px;
		line-height: 37px;
	}
	
	.content02-title span {
		font-size: 16px;
		line-height: 30px;
		width: 80px;
	}
	
	.content02-item h4 {
		font-size: 22px;
		        line-height: 30px;
	}
	
	.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;
	}
	
	#index-area .contact-text {
		flex-direction: column;
		padding: 20px;
	}
	
	.contact-text .contact-left, .contact-text .contact-right {
		padding-right: 0;
		width: 100%;
	}
	
	.contact-left p {
		font-size: 16px;
	}
	
	.contact-text .contact-tel {
		background-size: 25px auto;
		font-size: 30px;
		margin-top: 10px;
		padding-left: 30px;
	}
	
	.contact-text .contact-tel small {
		font-size: 14px;
	}
	
	.contact-buttons {
		align-items: stretch;
		flex-direction: column;
		gap: 10px;
	}
	
	.section-title h5 {
		font-size: 16px;
	}
	
	.section-title h2 {
		font-size: 6.4vw;
	}
	
	.section-title h4 {
	  font-size: 22px;
		        line-height: 30px;
	}
	
	.area-text strong {
	  font-size: 18px;
	}
	
	.area-img {
		margin-top: 20px;
		position: static;
		width: auto;
	}
	
	.table-wrap {
		overflow-x: auto;
	}
	
	table.custom-table {
		font-size: 16px;
	}
	
	table.custom-table tr th, table.custom-table tr td {
		padding: 15px;
		text-wrap: nowrap;
	}
	
	table.custom-table tr th {
		font-size: 18px;
	}
	
	table.custom-table tr td:first-child {
		font-size: 16px;
	}
	
	table.custom-table tr th.price, table.custom-table tr td.price {
		font-size: 20px;
	}
	
	table.custom-table tr th.supports {
		font-size: 20px;
	}
	
	table.custom-table tr th.supports small {
		font-size: 16px;
	}
	
	table.custom-table tr td.price-reference {
		font-size: 16px;
	}
	
	table.custom-table tr td.support {
		background-position: 50px center;
		background-size: 35px auto;
		padding-left: 100px;
	}
	
	table.custom-table tr th.supports::before {
		width: 400px;
	}
	
	table.custom-table tr th.price::before {
		right: 210px;
		width: 170px;
	}
	
	.work-item h3 {
		font-size: 20px;
	}
	
	.work-item h3 span {
		font-size: 16px;
	}
	
	.work-item .arrow {
		margin-top: 20%;
	}
	
	.footer-inner .flex {
		flex-direction: column;
	}
	
	.footer-left, .footer-center, .footer-right {
		width: 100%;
	}
	
	.footer-inner .footer-left {
        padding: 50px 15px;
    }
	
	.footer-center {
		border: none;
	}
	
	.footer-center, .footer-right {
		padding: 0;
	}
	
	.footer-logo {
		margin: 0 0 30px;
	}
	
	.social-nav-item.social-nav-contact a {
		width: 180px;
	}
	
	.footer-menu ul {
		margin: 30px 0 0;
	}
	
	.copyright {
		height: auto;
		line-height: normal;
	}
	
	.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;
	}
	
	.header-video::after, #index-text-2::after {
		height: 25px;
	}
	
	.footer::before {
		top: -25px;
		height: 25px;
	}
	
	.visible-phone {
		display: block;
	}
	
	.hidden-phone {
		display: none;
	}
}

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

	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;}
        .footer{
            padding-bottom: 67px;
        }
}

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

@media only screen and (max-width: 767px) {
    p {
        font-size: 15px;
        line-height: 2;
    }
}
