/* CSS Document */
@import url(//fonts.googleapis.com/earlyaccess/notosansjp.css);
@import url(//fonts.googleapis.com/css?family=Oswald);
*{
    box-sizing: border-box;
    line-height: 1;
    font-weight: 400;
    font-feature-settings: 'palt';
    color: #333;
}
html {
    font-size: 62.5%; /* -> 10px; */
	
}
body ,
input {
    font-family: 'Noto Sans JP', sans-serif;
    letter-spacing: 0.1em;
}
img {
	pointer-events: none;
	-webkit-touch-callout:none;
	-webkit-user-select:none;
	-moz-touch-callout:none;
	-moz-user-select:none;
	touch-callout:none;
	user-select:none;
}
/*###########
    font
###########*/
[class^="-english"],
[class*="-english"]{
    font-family: futura-pt, sans-serif;
}

/*###########
    font
###########*/
/*###########
    root
###########*/
:root {
    --green: #24b1b3;
    --red: #df716c;
    --purple: #6f64c0;
}

/*###########
    root
###########*/
/*###########
    none
###########*/

a:hover {
    opacity: 0.6;
    text-decoration: none!important;
    transition-property: all;
    transition-duration: 0.5s;
    transition-delay: 0s
}
a.no-hover:hover {
    opacity: 1;
}
/*###########
    none
###########*/
/*###########
 共通デザイン
###########*/
/* -- 全体 -- */
body {
	margin-bottom: 43px;
}
main {
    display: block;
    margin-top: 60px;
}
main .body {
    max-width: 990px;
    width: 100%;
    margin: 30px auto 0;
}
main .body > .sidebar {
    display: none;
    width: 220px;
    margin-right: 30px;
}
main .body > .page {
    width: 100%;
    flex: 1;
    margin:  0 auto;
}
main .body > .page .narrow  {
	max-width: 580px;
	margin: auto;
}
img {
    width:100%;
    height: auto;
}
@media all and (min-width: 576px) {
	body {margin-bottom: 55px;}
}
@media all and (min-width: 768px) {
	body {margin-bottom: 0;}
}
@media all and (min-width: 992px) {
    main {
        margin-top: 195px;
    }
    main .body {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        flex-direction: row-reverse;
    }
    main .body > .sidebar {
        display: block;
    }
}
/* -- 全体 -- */
/* -- main_visual -- */
.main > [class^="visual-"] {
    width: 100%;
    height: 200px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}
.title-page  {
    font-size: 1.6rem;
    line-height: 1;
    font-weight: 600;
    text-align: center;
    color: #666;
    text-shadow: 0 0 10px rgba(0,0,0,0.3);
}
@media all and (min-width: 768px) {
    .main > [class^="visual-"] {
        height: 400px;
    }
    .title-page  {
        font-size: 3rem;
    }
}
/* -- main_visual -- */
/* -- 見出し -- */
.title-two .-english {
    display: block;
    margin-top: 1px;
    padding-bottom: 10px;
    font-size: 1.4rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-align: center;
    color: #24b1b3;
}
.title-two .jp {
    display: block;
    width:100%;
    max-width: 580px;
    padding: 20px 0;
    margin: auto;
    font-size: 1.8rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-align: center;
    color: #434343;
    border-top: 2px solid #24b1b3;
    border-bottom: 2px solid #24b1b3;
}
@media all and (-ms-high-contrast: none) {
	.title-two .jp {
		letter-spacing: 0em;
	}
}
.title-gra  ,
.title-bg  {
	width: 100%;
    padding: 5px 0;
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 1.5;
    border-radius: 10px;
    color: #fff;
    background: -moz-linear-gradient(left, #24b1b3, #6f64c0); 
    background: -webkit-linear-gradient(left, #24b1b3, #6f64c0); 
    background: linear-gradient(to right, #24b1b3, #6f64c0); 
}
.title-bg {
    text-align: center;
    background: #24b1b3; 
}
.title-bg2 {
	width: 100%;
	padding: 5px;
	font-size: 1.8rem;
	font-weight: 600;
	letter-spacing: 0;;
	color: #24b1b3;
	background-color: rgba(36,177,179,.2);
}
.title-border {
	padding-bottom: 8px;
	font-size: 2.4rem;
	font-weight: 600;
	line-height: 1.5;
	letter-spacing: .05em;
	color: #434343;
	border-bottom: 2px solid  #24b1b3;
}
@media all and (min-width: 768px) {
	  .title-two .-english {
		font-size: 1.6rem;
	}
	.title-two .jp {
		font-size: 2rem;

	}
	.title-gra  ,
	.title-bg {
		padding: 10px 0;
	}
	.title-bg2 {
		padding: 10px 15px;
		letter-spacing: .1em;
	}
}
/* -- 見出し -- */
/* -- ボタン -- */
[class^="button-"],
[class*="button-"]{
	max-width: 260px;
	width: 100%;
	height: 66px;
	margin: 0px auto;
	padding: 0px;
    font-size: 1.6rem;
    font-weight: 600;
    text-align: center;
    color: #fff;
	border-radius: 10px;
    background: #24b1b3;
	display: flex;
	justify-content: center;
	align-items: center;;
}
.contact-button {
    max-width: 490px;
    width: 100%;
    height: 100px;
    margin: 0px auto;
    padding: 20px 10px;
    background: -moz-linear-gradient(left, #24b1b3, #6f64c0); 
    background: -webkit-linear-gradient(left, #24b1b3, #6f64c0); 
    background: linear-gradient(to right, #24b1b3, #6f64c0); 
    border-radius: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
	position: relative;
}
.contact-button .min {
    display: block;
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0.075em;
    color: #fff;
}
.contact-button .big {
    display: block;
    margin-top: 10px;
    font-size: 1.9rem;
    font-weight: 600;
    line-height: 1;
    color: #fff;
}
.contact-button::after {
    display: inline-block;
    width: 40px;
    height: 40px;
    margin-left: 5px;
    content: '';
    background: url('../images/common/arrow-2.png') no-repeat;
    background-size: contain;
}
@media all and (min-width: 576px) {
    .contact-button {
		width: calc(100% - 20px);
        padding: 20px 40px;
        justify-content: flex-end;
    }
    .contact-button .big {
        display: block;
        font-size: 2.5rem;
		letter-spacing: 0.075em;
    }
    .contact-button::before {
        display: block;
        width: 160px;
        height: 160px;
        content: '';
        background: url('../images/common/contact-button.png') no-repeat;
        background-size: contain;
        position: absolute;
        top: 50%;
        left: 0;
        margin-left: -80px;
        transform: translateY(-50%);
        -webkit-transform: translateY(-50%);
    }
    .contact-button::after {
		width: 52px;
		height: 52px;
        margin-left: 20px;
    }
}
/* -- ボタン -- */

/*###########
 共通デザイン
###########*/
/*
##################
##################
      footer
##################
##################
*/
/*フッターのコンタクト*/
.footer-contact {
    margin-top: 60px;
    padding: 30px 0;
    background: -moz-linear-gradient(left, #24b1b3, #6f64c0); 
    background: -webkit-linear-gradient(left, #24b1b3, #6f64c0); 
    background: linear-gradient(to right, #24b1b3, #6f64c0); 
}
.footer-contact .container {
    max-width: 750px;
}
.footer-contact .title-fooer-link .-english {
    display: block;
    padding-bottom: 10px;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-align: center;
    color: #fff;
}
.footer-contact .title-fooer-link .jp {
    display: block;
    width:100%;
    max-width: 580px;
    padding: 20px 0;
    margin: auto;
    margin-bottom: 30px;
    font-size: 2rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-align: center;
    color: #fff;
    border-top: 2px solid #fff;
    border-bottom: 2px solid #fff;
}
.footer-contact .text {
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 1.5;
    text-align: center;
    color: #fff;
}
.footer-contact .list-link {
    margin-top: 10px;
}
.footer-contact .list-link li {
    width:100%;
    max-width: 400px;
    margin: auto;
}
.footer-contact .list-link a {
    width:100%;
    height: 60px; 
    margin-top: 20px;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-align: center;
    color: #24b1b3;
    border-radius: 10px;
    background-color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
}
.footer-contact .list-link a::before {
    display: inline-block;
    width: 30px;
    height: 30px;
    margin-right: 15px;
    content: '';
    background: url('../images/common/icon-tel.png') no-repeat;
    background-size: contain;
}
.footer-contact .list-link .contact a {
    color: #df716c;
}
.footer-contact .list-link .contact a::before {
    width: 21px;
    height: 16px;
    background: url('../images/common/icon-mail_red.png') no-repeat;
}
@media all and (min-width: 576px) {
	.footer-contact .text {
		font-size: 1.8rem;
	}
    .footer-contact .list-link a {
        font-size: 2rem;
    }
}
@media all and (min-width: 768px) {
    .footer-contact .list-link {
        display: flex;
        justify-content: space-between;
        align-items: stretch;
    }
    .footer-contact .list-link li {
        width: calc(50% - 15px);
    }
   
}
/*フッター*/

footer .container {
    max-width: 880px;
    padding: 50px 15px;
}
footer .left .logo {
    width: 100%;
    max-width: 240px;
    margin: 0 auto 30px;
}
footer .left address {
    font-size: 1.4rem;
    line-height: 1.5;
    font-weight: 400;
    letter-spacing: 0.05em;
    text-align: center;
}
footer .right {
    margin-top: 40px;
}
footer .right .list a {
    display: block;
    padding-bottom: 30px;
    font-size: 1.6rem;
    font-weight: 400;
    color: #434343;
    white-space: nowrap;
}
footer .copyright {
    padding: 10px;
    font-size: 1.2rem;
    font-weight: 300;
    text-align: center;
    color: #fff;
    background-color: #24b1b3;
}
footer .copyright .copy-mark {
    padding: 0 5px;
}
footer .scroll-top {
	 width: 30px;
     position: fixed;
     bottom: 0;
     margin-bottom: 65px;
     right: 0;
     margin-right: 15px;
}
.grecaptcha-badge {
	bottom: 110px!important;
}
/* float-link */
.float-link {
	width: 100%;
	position: fixed;
	bottom: 0;;
	right: 0;
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.float-link a {
	width: 50%;
	padding: 15px 0;
	font-size: 1.3rem;
	font-weight: 600;
	text-align: center;
	color: #fff;
	background-color: #df716c;
	display: flex;
	justify-content: center;
	align-items: center;
}
.float-link a.contact {
	background: -moz-linear-gradient(left, #24b1b3, #6f64c0); 
    background: -webkit-linear-gradient(left, #24b1b3, #6f64c0); 
    background: linear-gradient(to right, #24b1b3, #6f64c0); 
}
.float-link a img {
	display: none;
	width: 35px;
}
.float-link a span {
	padding-left: 10px;
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.float-link a span .dot {
	display: inline-block;
	width: 4px;
	height: 4px;
	padding: 2px;
	margin: 0 2px;
	border-radius: 2px;
	background-color: #fff;
}
@media all and (min-width: 576px) {
    footer .right {
        display: flex;
        justify-content: center;
        align-items: flex-start;
    }
    footer .right .list:last-child{
        padding-left: 70px;
    }
	/* float-link */
	.float-link a {
		padding: 10px 0;
	}
	.float-link a img {
		display: block;
	}
}
@media all and (min-width: 768px) {
    footer .container {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    footer .left{
        width: 42%;
    }
    footer .left .logo {
        width: 100%;
        max-width: 240px;
        margin-left: 0;
    }
    footer .left address {
        text-align: left;
    }
    footer .right {
        width: 58%;
        margin-top: 0;
        border-left: 1px solid #434343;
        justify-content: flex-end;
    }
	footer .scroll-top {
		 width: 40px;
		 margin-bottom: 15px;
	}
    .grecaptcha-badge {
        bottom: 65px!important;
    }
	/* float-link */
	.float-link {
		width: auto;
		top: 0;
		margin-top: 75px;
		bottom: auto;
		right: 0;
		margin-right: 10px;
	}
	.float-link a {
		width: 41px;
		padding: 3px 3px 15px;
		font-size: 1.7rem;
		border-radius: 21px;
		flex-direction: column;
	}
	.float-link .contact {
		margin-left: 10px;
	}
	.float-link a span {
		margin: auto;
		padding-left: 0;
		padding-top: 10px;
		-webkit-writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		-o-writing-mode: vertical-rl;
		writing-mode: vertical-rl;
		letter-spacing: .1em;
		
	}
	.float-link a span .dot {
		width: 6px;
		height: 6px;
		padding: 3px;
		margin: 3px 0;
		border-radius: 3px;
	}
}
@media all and (min-width: 992px) {
	.float-link {
		margin-top: 220px;
	}
}
/*フッター*/
/*
##################
##################
      footer
##################
##################
*/
/*
##################
##################
      sidebar
##################
##################
*/
.sidebar .download {
	display: block;
    position: relative;
}
.sidebar .download .text {
    width:100%;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: .075em;
    text-align: center;
    color: #fff;
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
}
.sidebar .download .text span {
    display: block;
}
.sidebar .download .text .big {
	padding-bottom: 7px;
    font-size: 1.8rem;
    line-height: 1;
}
.sidebar .side-menu {
    margin-top: 30px;
    border-left: 5px solid #24b1b3
}
.sidebar .side-menu .title-sidebar {
    padding: 15px 5px;
    margin-left: -1px;
    font-size: 1.4rem;
    font-weight: 600;
    text-align: center;
    color: #fff;
    border-radius: 0 10px 10px 0;
    background-color: #24b1b3;
}
.sidebar .side-menu .title-sidebar .big {
    padding-top: 5px;
    font-size: 1.6rem;
    font-weight: 900;
}
.sidebar .side-menu .item a {
    padding: 10px 0 10px 15px; 
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 2.2rem;
    letter-spacing: 0;
    color: #434343;
    border-bottom: 1px solid #24b1b3;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.sidebar .list-reason {
    counter-reset: count;
}
.sidebar .list-reason .item a::before {
    display: inline-block;
    padding-right: 15px;
    font-size: 2rem;
    font-weight: 600;
    color: #24b1b3;
    content: "0" counter(count);
    counter-increment: count;
}
.sidebar .list-service .item a::before ,
.sidebar .list-case .item a::before {
    display: inline-block;
    width: 13px;
    height: 20px;
    margin-right: 20px;
    content: '';
    background: url('../images/common/arrow.png') no-repeat;
    background-size: contain;
}
.sidebar  .side-popular {
	border: none;
}
.sidebar  .side-popular .item a {
	padding-left: 0;
}
.sidebar  .side-popular .item a::before {
	display: inline-block;
	width: 28px;
	height: 27px;
	padding-top: 28px;
	padding-right: 27px;
	margin: 0 10px;
	content: '';
	background: url("../images/common/icon-no1.png") no-repeat;
	background-size: contain;
}
.sidebar  .side-popular .item:nth-child(2) a::before {
	background: url("../images/common/icon-no2.png") no-repeat;
	background-size: contain;
}
.sidebar  .side-popular .item:nth-child(3) a::before {
	background: url("../images/common/icon-no3.png") no-repeat;
	background-size: contain;
}
.sidebar  .side-popular .item:nth-child(4) a::before ,
.sidebar  .side-popular .item:nth-child(5) a::before {
	width: 25px;
	height: 25px;
	padding: 0 8px;
	font-size: 1.2rem;
	font-weight: 600;
	text-align: center;
	line-height: 25px;
	color: #fff;
	border-radius: 50%;
	content: '4';
	background: #24b1b3;
}
.sidebar  .side-popular .item:nth-child(5) a::before {
	content: '5';
}
.sidebar .side-button {
    height: 66px;
    margin-top: 15px;
    font-size: 1.6rem;
    font-weight: 600;
    color: #434343;
    border: 2px solid #24b1b3;
    border-radius: 10px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.sidebar .side-button.column::before {
    display: inline-block;
    width: 38px;
    height: 37px;
    margin-left: 13px;
    margin-right: 10px;
    content: '';
    background-image: url('../images/common/icon-column.png');
    background-size: contain;
}
.sidebar .side-button.equipment::before {
    display: inline-block;
    width: 38px;
    height: 32px;
    margin-left: 13px;
    margin-right: 10px;
    content: '';
    background-image: url('../images/common/icon-equipment.png');
    background-size: contain;
}
.sidebar .side-button.faq::before {
    display: inline-block;
    width: 38px;
    height: 38px;
    margin-left: 13px;
    margin-right: 10px;
    content: '';
    background-image: url('../images/common/icon-faq.png');
    background-size: contain;
}
.sidebar .side-button.news::before {
    display: inline-block;
    width: 38px;
    height: 38px;
    margin-left: 13px;
    margin-right: 10px;
    content: '';
    background-image: url('../images/common/icon-news.png');
    background-size: contain;
}
.sidebar .side-button.company::before {
    display: inline-block;
    width: 38px;
    height: 38px;
    margin-left: 13px;
    margin-right: 10px;
    content: '';
    background-image: url('../images/common/icon-company.png');
    background-size: contain;
}
.side-on {
	display: none;
}
.sidebar .side-on {
	display: inline;
}
/*
##################
##################
      sidebar
##################
##################
*/
/* 
##################
##################
    main-visual
##################
##################
*/
/* top */
.top-visual {
    width:100%;
    height: 300px;
    position: relative;
}
.top-visual .slider li {
    width:100%;
    height: 300px;
}
.top-visual .slider li.one{
 	background: url('../images/header-img/header-top_1.jpg') no-repeat center center / cover;
}
.top-visual .slider li.twe {
    background: url('../images/header-img/header-top_2.jpg') no-repeat center center / cover;
}
.top-visual .slider li.three{
    background: url('../images/header-img/header-top_3.jpg') no-repeat center center / cover;
}
.top-visual .title-page {
    width:100%;
    font-size: 2.5rem;
    font-weight: 600;
    line-height: 4rem;
    letter-spacing: 0.075em;
    text-align: center;
    color: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    
}
.top-visual .title-page  .dec {
    display: inline-block;
    letter-spacing: 0.075em;
    color: #24b1b3;
    text-shadow:2px 2px 0 #FFF, -2px -2px 0 #FFF,
          -2px 2px 0 #FFF, 2px -2px 0 #FFF,
          0px 2px 0 #FFF,  0 -2px 0 #FFF,
          -2px 0 0 #FFF, 2px 0 0 #FFF;
}
.top-visual .contact-button {
    display: none;
    position: absolute;
    bottom: 0;
    margin-bottom: 60px;
    left: 50%;
    margin-left: 4px;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    z-index: 5;
}
@media all and (min-width: 768px) {
    .top-visual ,
    .top-visual .slider li {
        height: 500px;
    }
    .top-visual .title-page {
        font-size: 3rem;
        line-height: 6rem;
        top: 0;
        margin-top: 130px;
        left: 50%;
        transform: translateX(-50%);
        -webkit-transform: translateX(-50%);
    }
    .top-visual .title-page  .dec {
 
        letter-spacing: 0.075em;
    }
    .top-visual .contact-button {
        display: flex;
    }
}
@media all and (min-width: 992px) {
    .top-visual .title-page {
        font-size: 3.5rem;
	}
}
/* top以外 */
 [class^="visual-"] {
 	width: 100%;
 }
 [class^="visual-"] .title-page {
 	display: block;
 	max-width: 960px;
	width: 100%;
	height: 160px;
	margin:  auto;
	font-size: 3rem;
	font-weight: 600;
	line-height: 1.5;
	text-align: center;
	letter-spacing: 0.075em;
    color: #24b1b3;
    text-shadow:2px 2px 0 #FFF, -2px -2px 0 #FFF,
          -2px 2px 0 #FFF, 2px -2px 0 #FFF,
          0px 2px 0 #FFF,  0 -2px 0 #FFF,
          -2px 0 0 #FFF, 2px 0 0 #FFF;
	display: flex;
	justify-content: center;
	align-items: center;
}
@media all and (min-width: 992px) {
	[class^="visual-"] {
		padding-top: 30px;
	}
	[class^="visual-"] .title-page {
		font-size: 3.5rem;
	}
}

/* 
##################
##################
      main-visual
##################
##################
*/
/*
##################
##################
    ページ送り
##################
##################
*/
.pageList ul {
	text-align: center;
    max-width: 910px;
    margin: 50px auto 0;
	display: flex;
	justify-content: center;
	align-items: center;
}
.pageList li a,
.pageList .on {
	width: 40px;
	height: 40px;
    margin: 0 10px;
    font-size: 1.6rem;
    line-height: 1;
    font-weight: 400;
    text-align: center;
    color: #434343;
	background-color: #ededed;
	border-radius: 5px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.pageList .last a ,
.pageList  a.first{
	width: auto;
	padding: 0 5px;
}
.pageList li a:hover {
  	background-color: rgba(36,177,179,0.2);
    text-decoration: none;
	opacity: 1;
}
.pageList .on {
	background-color: rgba(36,177,179,0.2);
}
/*
##################
##################
    ページ送り
##################
##################
*/
/*
##################
##################
    パンクズ
##################
##################
*/
.bread {
    width: 100%;
    max-width: 990px;
    margin: 0px auto 0;
    padding: 10px 15px;
}
.bread .bread-items {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
}
.bread .bread-item{    
    display: inline-block;
    margin-right: 10px;
    font-size: 1.2rem;
    line-height: 1.5;;
    letter-spacing: 0.2em;
    color: #434343;
} 
.bread .bread-item:not(:first-child)::before {
    display: inline-block;
    font-size: 1.2rem;
    content: '>';
    vertical-align: unset; 
}
/*
##################
##################
    パンクズ
##################
##################
*/
/*
##################
##################
    エラー
##################
##################
*/
.error .contents-error .title-error {
    font-size: 2.4rem;
    font-weight: 600;
    line-height: 1.5;
    text-align: center;
}
.error .contents-error .text {
    padding: 20px 0 40px;
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.7;
	letter-spacing: .05em;
	color: #434343;
    text-align: center;
}
/*
##################
##################
    エラー
##################
##################
*/
