*,
*::before,
*::after {
	box-sizing: border-box;
}
html,
body {
	margin: 0;
	padding: 0;
}
body {
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	background: rgb(243, 243, 243);
	color: #3E3E3E;
	font-family: "游ゴシック体", "游ゴシック", Montserrat, "Yugothic", "Yu Gothic";
	font-size: 16px;
	font-weight: 500;
}

article,
aside,
footer,
header,
nav,
section,
main {
	display: block;
}

h1,
h2,
h3,
h4,
h5,
h6,
a,
p,
span,
em,
small,
strong,
sub,
sup,
mark,
del,
ins,
strike,
abbr,
dfn,
blockquote,
q,
cite,
code,
pre,
ol,
ul,
li,
dl,
dt,
dd,
div,
section,
article,
main,
aside,
nav,
header,
hgroup,
footer,
img,
figure,
figcaption,
address,
time,
audio,
video,
canvas,
iframe,
details,
summary,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td 
{
	border: 0;
	margin: 0;
	padding: 0;
}


img {
	border: none;
	height: auto;
	max-width: 100%;
	vertical-align: top;
}

code,
kbd,
pre,
samp {
	font-family: inherit;
	font-size: inherit;
}

ul,
ol {
	list-style: none;
}

table{
  width: 100%;
   border-collapse: collapse; 
	font-size: 20px;
	font-weight: bold;
}

th,
td {
	padding: 20px 6px;
}

blockquote,
q {
	quotes: none;
}

blockquote::after,
blockquote::before,
q::after,
q::before {
	content: "";
	content: none;
}

input,
textarea {
	-webkit-appearance: none;
	background-image: none;
	border: 1px solid #707070;
	border-radius: 0;
	font-family: inherit;
	font-size: inherit;
	padding: 8px;
}

input:focus,
textarea:focus {
	outline: none;
}


input[type="submit"] {
	border: none;
	cursor: pointer;
}

input[type="submit"]:hover,
input[type="submit"]:focus {
	border: none;
	outline: none;
}

input[type="submit"] ::-moz-focus-inner {
	border: none;
	padding: 0;
}

input[type="radio"] {
	display: none;
}

input[type="radio"] + span {
	cursor: pointer;
	display: inline-block;
	margin: 0 60px 0 0;
	padding: 0 0 0 1.2em;
	position: relative;
}

input[type="radio"] + span::before {
	-webkit-transform: translateY(-50%);
	background: #fff;
	border: 1px solid #707070;
	border-radius: 50%;
	content: "";
	display: block;
	height: 1em;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 1em;
}

input[type="radio"] + span::after {
	opacity: 0;
	transition: opacity 0.3s ease 0s;
}

input[type="radio"] + span:focus,
input[type="radio"] + span:checked {
	background: #3B69FF;
	border: 1px solid #fff;
	box-shadow: none;
	outline: none;
}

/* チェックボックスの中の丸 */
input[type="radio"]:checked + span::after {
	-webkit-transform: translateY(-50%);
	background: #3B69FF;
	border-radius: 50%;
	content: "";
	display: block;
	height: 6px;
	left: 0.15em;
	opacity: 1;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 6px;
}

input[type="checkbox"] {
	display: none;
}

input[type="checkbox"] + span {
	cursor: pointer;
	display: inline-block;
	margin: 0 0.2em 0;
	padding: 0 0 0 1.2em;
	position: relative;
	transition: all 0.3s ease 0s;
}

input[type="checkbox"] + span::before {
	-webkit-transform: translateY(-50%);
	background: #fff;
	border: 1px solid #707070;
	border-radius: 2px;
	content: "";
	display: block;
	height: 1em;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 1em;
}

input[type="checkbox"] + span:hover::before{
	box-shadow: 1px 1px 5px 1px rgba(73, 115, 225,0.3);
	border: 1px solid #3B69FF;
}

input[type="checkbox"] + span::after {
	opacity: 0;
	transition: opacity 0.3s ease 0s;
}

input[type="checkbox"]:checked + span::after {
	-webkit-transform: translateY(-50%) rotate(-45deg);
	border-bottom: 3px solid #3B69FF;
	border-left: 3px solid #3B69FF;
	content: "";
	display: block;
	height: 0.6em;
	left: 0;
	margin-top: -0.1em;
	opacity: 1;
	position: absolute;
	top: 40%;
	transform: translateY(-50%) rotate(-45deg);
	width: 1em;
}

h1{
  font-size: 30px;
}

p{
  font-size: 18px;
}

.orange-button{
  background: #FFAA3B;
	font-size: 18px;
	text-decoration: none;
	cursor: pointer;
}

.section-title h2, .section-title{
	font-size: 36px;
	letter-spacing: normal;
}

.news-title{
	padding: 60px 0;
}

/* 初期設定終わり */
.drawer-hamburger{
	z-index: 7;
	right: 20px;
}
.drawer-hamburger-icon{
	z-index: 7;
}
.drawer-hamburger-icon{
	z-index: 6;
	margin-top: 0;
}
.drawer-toggle.drawer-hamburger{
	width: 26px;
	padding-right: 20px;
	padding-top: 24px;
}
.drawer-hamburger{
	width: 30px;
}
/* drawerの幅 */
.drawer-nav{
	z-index: 6;
	width: 300px;
	right:-300px;
}
.drawer--right.drawer-open .drawer-hamburger {
  right: 300px;
}
.drawer--left .drawer-nav {
  left: -300px;
}
.drawer--right .drawer-nav {
  right: -300px;
}

.drawer-menu{
	margin-top: 187px;
}
.drawer-menu-item{
	line-height: 22px;
	padding: 10px 0;
	text-align: center;
	font-size: 18px;
	color: #3E3E3E;
}

.drawer-hamburger-icon{
	width: 26px;
	height: 20px;
	background-image:url(../img/hamburger.png);
	background-repeat: no-repeat;
	width: 26px;
}

.drawer-open .drawer-hamburger-icon{
	background-image:url(../img/batsu.png);
	background-repeat: no-repeat;
	width: 21.21px;
}

.drawer-overlay{
	background-color: rgba(0,0,0,0.7);
}

.drawer-hamburger-icon, .drawer-hamburger-icon:after, .drawer-hamburger-icon:before {
	background-color: rgba(0,0,0,0);
}

.drawer{
	display: none;
}




#header{
	position: fixed;
	right: 0;
	left: 0;
	z-index: 5;
}

.header-logo{
 display: none;
}

.list{
  background: rgba(255, 255, 255, 0.1);
	letter-spacing: -0.025rem;

}
.list li{
  display: inline-block;
  line-height: 19px;
  margin: 30px 18px;
	cursor: pointer;
}

.list a{
	text-decoration: none;
	color: #3E3E3E;
}

.list li:first-child{
	margin-left: 25.2562%;
}

.li-active{
	border-bottom: solid 1px #3e3e3e;
}

.header-cover{
    background: url(../img/mv.png) no-repeat;
		height: 648px;
    background-size: cover;
}

.header-text{
  margin-left: 53.6%;
	padding-top: 220px; 
}

.header-text h1{
	line-height: 42px;
}

.header-text p{
  padding: 40px 0;
	width: 82%;
	letter-spacing: 0.03rem;
	line-height: 25px;
}

.header-button{
  width: 280px;
  height: 51px;
  border-radius: 10px;
  box-shadow: 0 3px 5px rgba(62, 62, 62, 0.2);
  font-weight: bold;
	border-width: 0;
	line-height: 51px;
	text-align: center;
}

.header-button:hover{
	background: rgb(236, 144, 24);
	transition: .5s
}

.header-button a{
	text-decoration: none;
	color: #fff; 
	letter-spacing: 0.025em;
}

.inner{
	width: 1180px;
	margin: 0 auto;
}

.news{
	background: #F3F3F3;
}

.news > .inner{
	padding: 130px 0;
}

.news-wrapper{
	background: #fff;
	box-shadow: 0 5px 12px rgba(62,62,62,0.2);
	padding: 0;
	padding-bottom: 40px;
}

.news h2{
	text-align: center;
}

.news-item{
	display: flex;
	border-top: 1px solid #CECDCD;
	padding: 40px 50px;
	letter-spacing: .025em;
	text-decoration: none;
}

.news-item:hover{
	background: rgb(233, 243, 252);
	transition: .5s
}

.news-meta{
	display: flex;
	width: 32.8%;
	align-items: center;
}

.content-wrapper{
	width: 66%;
}

.last-news-item{
	border-bottom: 1px solid #CECDCD;
}

.news-date{
	font-size: 18px;
	padding-left: 9.67px;
	color: #3E3E3E;

}

.news-text{
	height: 28px;
	margin-left: 60px;
	display: block;
	text-decoration: none;
	border-radius: 50px;
	border: 2px solid #3B69FF;
	padding: 3px 32px;
	font-size: 14px;
	text-align: center;
	line-height: 18px;
	color: #3E3E3E;

}

.news-content{
	line-height: 1.4;
	width: 100%;
	padding-right: 50px;
	text-decoration: none;
	letter-spacing: 0.025rem;
	position: relative;
	font-size: 18px;
	color: #3E3E3E;
}

.news-content::after{
	content: "";
	display: block;
	border-top: solid 3px #3e3e3e;
	border-right: solid 3px #3e3e3e;
	transform: translateY(-50%) rotate(45deg);
	height: 18px;
	width: 18px;
	position: absolute;
	top: 50%;
	right: 0;
}

.news-arrow{
	display: block;
}


.news-arrow img{
	vertical-align: middle;
	height: 30px;
}

.button-more{
	text-align: center;
	width: 248px;
	margin: 0 auto;
	height: 64px;
	line-height: 63px;
}

.button-more a:hover{
	background: #3E3E3E;
	color: #fff;
	transition:0.3s ease;
}

.button-more a{
	display: block;
	border: 1px solid #707070;
	font-size: 20px;
	text-decoration: none;
	font-weight: 600;
	letter-spacing: 0.2em;
	margin: 37px 0 40px;
	color: #3E3E3E;
}

.service{
	position: relative;
	background: #F3F3F3;
	height: 655px;
}

.service-title{
	height: 400px;
	background: #3E3E3E;
	color: #FFFFFF;
	text-align: center;
	padding-top: 80px;
}

.outer{
	width: 70%;
	margin: 0 auto;
	background: #fff;
	box-shadow: 0 5px 12px rgba(62,62,62,0.2);
	position: absolute;
	top: 31%;
	left: 50%;
	-webkit-transform: translateX(-50%);
}

.service-container{
	display: flex;
	width: 100%;
}

.design-block{
	width: 24%;
	margin: 54px 42px 56px 46px;
	text-align: center;
}

.design-block:nth-child(1) .service-fig{
background: url(../img/service1.svg)center center no-repeat;
}
.design-block:nth-child(2) .service-fig{
background: url(../img/service2.svg)center center no-repeat;
}
.design-block:nth-child(3) .service-fig{
background: url(../img/service3.svg)center center no-repeat;
}

.service-fig{
	padding-top: 44px;
}

figure{
	margin-block-end: 26px;
	margin-inline-start: 40px;
	margin-inline-end: 40px;
}

.design-block img{
	margin-bottom: 27px;
}

.design-block h2{
	font-size: 20px;
	letter-spacing: 0.2em;
	line-height: 28px;
}
.design-block:last-child{
margin-bottom: 40px;
}

.design-block p{
	font-size: 14px;
	margin-top: 18px;
	color: #3E3E3E;
	text-align: left;
	line-height: 23px;
}

.results{
	background: #3E3E3E;
	margin: 0 0 0 93px;
	padding: 80px 0 80px 110px;
}

.results-title{
	color: #fff;
}

/* swiper */
  html, body {
     position: relative;
    height: 100%;
    }
  .swiper-container {
    width: 100%;
	  height: 70%;
	}
	
  .swiper-slide {
    font-size: 18px;
	  margin-top: 80px;
	  position: relative;
	  background: #fff;


      /* Center slide text vertically */
      display: -webkit-box;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: flex;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      -webkit-justify-content: center;
      justify-content: center;
      -webkit-box-align: center;
      -ms-flex-align: center;
      -webkit-align-items: center;
      align-items: center;
	}
	
	.swiper-img{
		position: absolute;
		top:0;
		left: 0;
		right: 0;

	}
	.swiper-img img{
		width: 100%;
		height: 100%;
	}

	.swiper-slide > .view-box{
		margin-top: 53%;
		padding-left: 20px;
		padding-right: 20px;
		background: #fff;
		padding-bottom: 20px;
	}

	.view-box h3{
		margin: 23px 0 13px 0;
		font-size: 20px;
	}

	.view-box p{
		line-height: 24px;
	}

	.swiper-pagination{
		margin-top: 52px;
		margin-left: 5px;
		text-align: left;
	}

	.swiper-pagination-bullet{
		width: 12px;
		height: 12px;
		background: #fff;
		opacity: 1;
		margin-right: 20px !important;
		position: relative;
	}

	.swiper-pagination-bullet-active:after {
		content: '';
		display: block;
		width: 20px;
		height: 20px;
		border: solid 1px #fff;
		border-radius: 50%;
		position: absolute;
		top: 50%;
		left: 50%;
		-webkit-transform: translate(-50%, -50%);
		-ms-transform: translate(-50%, -50%);
		transform: translate(-50%, -50%);
	}

	.view-btn{
		width: 301px;
		border: solid 1px #fff;
		margin-top: 116px;
		z-index: 1;
	}
	
	.view-btn a{
		color: #fff;
		padding: 20px 86px;
		display: block;
		text-decoration: none;
		font-size: 20px;
		letter-spacing: 0.2rem;
		font-weight: bold;
		text-align: center;
	}

	.view-btn a:hover {
		background: #fff;
		transition: 0.5s ease;
		color: #3e3e3e;

	}
	.map-btn a:hover {
		background: #fff;
		transition: 0.5s ease;
		color: #3e3e3e;
	}

	/* price */
	.price-title{
		padding: 80px 0;
		text-align: center;
	}

	.inner-price{
		margin-left: 15%;
		margin-right: 15%;
	}

	table{
		border: 1px solid #707070;
	}

	.table1{
		background:#3E3E3E;
		text-align: center;
		color: #fff;
		border: 1px solid #707070;

	}

	.table2{
		text-align: left;
		padding-left: 39px;
		background: #fff;
		border: 1px solid #707070;

	}

	.price p{
		font-size: 12px;
		padding-top: 24px;
		padding-bottom: 127px;
	}

th,td{
	padding: 15px 17px;
}

tr{
	font-size: 25px;
}


/* comments */
	.comments{
		position: relative;
	}

	.comments-title{
		padding-bottom: 80px;
	}

	.comments-box{
		margin-left: 93px;
		z-index: 3;
		position: absolute;
		top: 0px;
		display: flex;
	}

	.comments-wrapper{
		background: #fff;
		width: 50.5%;
		padding: 80px 40px;
		box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
		z-index: 5;
		height: 616px;
	}
	
	.comments-img{
		margin-top: 126px;
	}

	.comment p{
		line-height: 26px;
	}

	.comments-bg-blank{
		width: 100%;
		height: 150px;
	}
	.comments-bg{
		background: #3E3E3E;
		width: 71.7%;
		height: 597px;
		z-index: -1;
	}

	.comment{
		display: flex;
		padding-bottom: 80px;
	}

	.comment p{
		font-size: 16px;
		padding-left: 50px;
	}

	.comment img{
		width: 100px;
		height: 100px;	
	}

/* Q&A */
.qa{
	background-image: url(../img/sunyu-kim-1053375-unsplash.png);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
}

.qa h2{
	text-align: center;
	padding: 80px 0;
}

.qaa{
	margin-left: 640px;
	width: 45%;
	padding-bottom: 80px;
}

.qaa-list-item {
  position:relative;
  cursor:pointer;
  text-align: left;
	background: #fff;
	border-radius: 7px;
	margin-bottom: 40px;
	}
	
	.qaa-list-item:last-child {
		margin-bottom: 0;
	}
.question{
	background: #fff;
	border-radius: 13px;
  }

.question p{
	position: relative;
  }

.question-text{
	padding:20px;
	font-weight: bold;
	font-size: 16px;
	letter-spacing: 0.025rem;
  }
  
.answer {
  padding: 0 18px 18px 18px;
  display: none;   
  }

.answer p{
  display: inline-block;
  }

.answer-text {
  width: 100%;
	background: rgba(59, 105, 255, 0.2);
	padding: 16px 14px;
	border-radius: 7px;
	display: inline-block;
	font-size: 16px;
  }

.question-text::before {
	content: "Q" ;
	background: rgba(59, 105, 255, 1);
	border-radius: 16px;
	color: #fff;
  text-align: center;
	font-weight: bold;
	padding: 3px 7px 4px 6px;
	margin-right: 13px;
	vertical-align: top;
}

.question-after{
  display: block;
	font-size:34px;
	font-weight: bold;
	color: rgba(59, 105, 255, 1);
	position: absolute;
	top: 12px;
	right: 14px;
}

.qt{
	display: inline-block;
} 

/* access */
.access{
	position: relative;
}

.access-container{
	display: flex;
	padding-left: 93px;
}

.access-bg{
	width: 71.7%;
	height: 570px;
	background: #3E3E3E;
	position: absolute;
	top: 0;
	z-index: -1;
}

.access-address{
	width: 100%;
	color: #fff;
}

.access-address p{
	font-size: 16px;
	line-height: 26px;
	letter-spacing: normal;
}

.access-title{
	padding-top: 128px;
	padding-bottom: 40px;
	line-height: 44px;
}

.map-btn{
	padding-left: 93px;
	position: absolute;
	top: 327px;
}

.map-btn a{
	color: #fff;
	text-decoration: none;
	font-size: 20px;
	display: block;
	width: 326px;
	padding: 20px 0;
	border: 1px solid #fff;
	font-weight: bold;
	line-height: 1.2;
	letter-spacing: 0.1em	;
	text-align: center;
}

.google-map{
	height: 0;
	overflow: hidden;
	padding-bottom: 57.9%;
}

.google-map iframe{
	box-shadow:0 0 10px rgba(62, 62, 62, 0.2);
	position: absolute;
	left: 40.5%;
	top: 130px;
	height: 70%;
	width: 52.7%;
} 


/* contact */
.contact{
	background-size: cover;
	background-image: url(../img/alex-blajan-159378-unsplash.png);
	padding-top: 80px;
	font-size: 0;
	padding-bottom: 80.5px;
	margin-top: 38px;
}

.contact-container{
	margin: 0 auto;
	color: #fff;
	text-align: center;
	box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
}

.contact-title-bg{
	background-image: url(../img/contact1.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-size: cover;
	background-position: center center;
	width: 100%;
	border-radius:10px 10px 0 0;
}

.contact-title{
	padding-top: 61.5px;
	margin-bottom: 10px;
}

.contact-title-wrapper p{
	padding-bottom: 61.5px;
	font-size: 16px;
}

/* contact-form */
.form-wrapper{
	z-index: 10;
	width: 70%;
	margin: 0 auto;
	background: #fff;
	border-radius:12px;
}

.contact-form{
	width: 81.2%;
	margin: 0 auto;
	padding-top: 40px;
}

.contact-dl{
	font-size: 0;
	letter-spacing: 0;
	margin-top: 38px;
}

.contact-label{
	font-size: 22px;
	display: inline-block;
	width: 275px;
	line-height: 29px;
}

.contact-label-massage{
	margin-bottom: 9px;
}


/* contact-select */
.contact-select select {
	width: 100%;
	cursor: pointer;
	text-indent: 0.01px;
	text-overflow: ellipsis;
	border: none;
	outline: none;
	background: transparent;
	background-image: none;
	box-shadow: none;
	-webkit-appearance: none;
	appearance: none;
	line-height: 22.5px;
}

.contact-select.cp_sl01 {
	display: inline-block;
	border: 1px solid #707070;
	width: 261px;
	margin: 0;
}

.contact-select.cp_sl01 select {
	padding: 5px 38px 3px 20px;
	color: #666666;
	font-size: 18px;
} 

.contact-select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
	background: transparent url(../img/yajirusisita.png) no-repeat center right 8px/16px 16px;
	border: 1px solid rgba(0, 0, 0, 0.16);
  border-radius: 0;
  color: inherit;
  cursor: pointer;
  font-family: inherit;
  font-size: 1em;
  padding: 0.4em 0.8em;
	width: 90%;
	text-align: center;
}

.contact-select::-ms-expand {
  display: none;
}

.contact-select:focus {
  border: 1px solid rgba(0, 0, 0, 0.32);
  box-shadow: none;
  outline: none;
}

.contact-select:hover{
	box-shadow: 0 0 10px rgba(59, 105, 255,0.3);
	transition: 0.5s;
}

.contact-required{
	background: #FF4646;
	border-radius: 5px;
	color: #FFFFFF;
	width: 46px;
	text-align: center;
	font-size: 16px;
	height: 22px;
	line-height: 22px;
	margin-top: 6px;
	padding: 2px 12px;
}

.cr1{
	margin-left: 96px;
}
.cr2{
	margin-left: 53px;
}

.contact-input,.contact-input-select,.contact-message{
	display: inline-block;  
	font-size: 22px;
	margin-bottom: 41.5px;
}

.contact-mail{
	margin-bottom: 38px;
}

.contact-massage{
	margin-bottom: 20px;
}

.contact-input{
	width: calc(100% - 275px);
}

.contact-input input{
	width: 100%;
	border:none;
	border-bottom: 1px solid #707070;
	font-size: 22px;
}

input:focus,
input:hover {
	border-color: #3B69FF;
	box-shadow: 0 8px 5px -1px rgba(59, 105, 255, 0.1);
}


/* radio */
.radio {
  display: none;
}

.radio + span {
  cursor: pointer;
  display: inline-block;
  margin: 0 0.2em 0;
  padding: 0 0 0 1.2em;
  position: relative;
}

.radio + span::before {
  -webkit-transform: translateY(-50%);
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.16);
  border-radius: 50%;
  content: "";
  display: block;
  height: 10px;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
}

input[type="radio"] + span::before{
	width: 12px;
	height: 12px;
}

input[type="radio"] + span:hover::before {
	box-shadow: 1px 1px 5px 1px rgba(73, 115, 225,0.3);
	border: 1px solid #3B69FF;
}


.radio + span::after {
  -webkit-transform: translateY(-50%);
  background: rgba(0, 0, 0, 0.32);
  border: 1px solid transparent;
  border-radius: 50%;
  content: "";
  height: 8px;
  left: 4px;
  opacity: 0;
  padding: 2px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.3s ease 0s;
  width: 8px;
}

.radio:checked + span::after {
  opacity: 1;
}

.contact-input input,.contact-mssage input{
	line-height: 29px;
	padding: 0 11px;
}

.contact-input textarea, .contact-message textarea{
	padding: 10px 16px;
}

.contact-message{
	font-size: 22px;
	height: 213px;
	width: 100%;
}

.contact-message:hover{
	box-shadow: 1px 1px 5px 1px rgba(73, 115, 225,0.3);
	transition: 0.5s;
}

.contact-message textarea{
	height: 213px;
	border: 1px solid #707070;
	width: 100%;
}

.contact-message textarea:hover,
.contact-message textarea:focus{
	border: 1px solid #3B69FF;
	box-shadow: 1px 1px 5px 1px rgba(73, 115, 225,0.3)inset;
	transition: 0.5s;
}

.contact-input select{
	background: transparent url(../img/select-arrow.svg) no-repeat center right 17px/24px 16px;
	border: 1px solid #707070;
	height: 60px;
	line-height: 60px;
	padding: 0 16px;
	width: 100%;
}

.contact-input-box{
	border: 1px solid #707070;
}

.contact-agreement input[type="checkbox"] + span {
margin: 0;
padding-left: 50px;
}

.contact-agreement input[type="checkbox"] + span::before {
border-radius: 0;
height: 20px;
width: 20px;
}

.contact-agreement input[type="checkbox"]:checked + span::after{
	border-bottom-width: 2px;
	border-left-width: 2px;
	height: 9px;
	left: 2px;
	width: 16px;
}

.underline{
	font-size: 18px;
}

.contact-send{
	margin-top: 25px;
	transition: all 0.3s ease 0s;
}

.contact-send input[type="submit"]:hover{
		background: rgb(236, 144, 24);
		transition: .5s
	}


.contact-send input[type="submit"]{
	-webkit-appearance: none;
	background: #FFAA3B ;
	border-radius: 12px;
	box-shadow: 0 3px 6px 0 rgba(0,0,0,0.16);
	color: #fff;
	display: inline-block;
	font-size: 20px;
	font-weight: 700;
	height: 56px;
	line-height: 50px;
	max-width: 100%;
	padding: 0;
	position: relative;
	text-decoration: none;
	width: 174px;
	margin-bottom: 60px;
}

footer{
	background: #3E3E3E;
}
.footer-inner{
	margin-left: 93px;
	margin-right: 93px;
	display: flex;
}

.footer-left{
	width: 66.6%;
	padding-top: 120px;
	color: #fff;
}

.footer-right{
	padding-top: 163px;
	color: #E3E3E3;
}

.footer-list{
	font-size: 18px;
	font-weight: 500;
}

.footer-list a{
	text-decoration: none;
	color: #fff;
}

.sitemap, .privacy{
padding-bottom: 20px;
}

.footer-title{
	font-size: 40px;
	white-space: nowrap;
	line-height: 77px;
	color: #E3E3E3;
	text-decoration: none;
	font-family: "Berlin Sans FB","Berlin Sans FB";
}

.footer-copy{
	font-size: 12px;
	padding-bottom: 170.5px;
	text-align: right;
}

.fat{
	font-size: 2.25em;
	opacity: 0.6;
	margin-right: 20px;
	margin-bottom: 40px;
	color: #FFFFFF;
}

#page_top{
  width: 50px;
  height: 50px;
  position: fixed;
  right: 93px;
  bottom: 38.5px;
  transition: all 0.3s ease 0s;
	z-index: 20;
	background-image: url(../img/totop.svg);
}

#page_top:hover{
	opacity: 0.8;
}

#page_top a{
  position: relative;
  display: block;
  width: 60px;
  height: 60px;
  text-decoration: none;
}

/* タブレット */
@media(max-width: 1179px){
	.header-cover >.header-inner{
		margin: 0 19.5px;
	}

  .header-text{
		margin-left: 40%;
	}

	.header-cover{
		background-position: 30%;
	}

	.list li:first-child {
		margin-left: 20%;
	}

	.inner{
		width: 90%;
		margin: 0 auto;
	}

	.news > .inner{
		padding: 50px 0;
	}

	.news-meta{
		width: 30%;
	}

	.news-date{
		font-size: 14px;
		padding-top: 5px;
		width: 50%;
	}

	.news-text{
		margin-left: 20px;
		padding: 3px 4px;
	}

	.news-text a{
		padding: 2px 16px;
	}

	.news-content{
		margin-left: 20px;
	}

	.service-container{
		display: block;
	}

	.design-block{
		width: 100%;
		margin: 54px 0;
	}

	.design-block p{
		padding-top: 24px;
		font-weight: normal;
	}
	
	.outer{
		width: 90%;
		top: 15%;
	}

	.outer p{
		width: 311px;
		margin: 0 auto;
		line-height: 24px;
	}
	.service{
		height: 928px;
	}
	
	.comments-wrapper{
		display: block;
		width: 91%;
		padding: 40px 20px;
		margin: 0 auto;
		height: 10%;
	}

	.comments-bg-blank{
		height: 60px;
	}

	.qaa{
		margin-left: 50%;
	}

	.google-map{
		width: 500px;
	}
	
}

/* すまほ sumaho*/
@media(max-width: 768px){
	.section-title, .section-title h2{
		font-size: 30px;
		text-align: center;
		line-height: 37px;
	}

	.section-title{
		padding-top: 40px;
		padding-bottom: 40px;
	}

	.header-logo{
		display: block;
		text-align: left;
	}

	.header-logo img{
		padding: 21.5px 0 21.5px 16px;
	}

	.list{
		height: 68px;
	}

	.list li{
		display: none;
	}

	h1{
		font-size: 24px;
		line-height: 45px;
	}

	.header-text{
		margin: 0;
		padding-top: 200px;
	}

	.header-cover{
		background-position: 23%; /* header背景写真の位置 */
		height: 667px;
	}

	.header-text h1{
		line-height: 44px;
	}

	.header-text h2{
		font-size: 24px;
	}

	.header-text p{
		width: 100%;
		font-size: 16px;
		padding-top: 32px;
		letter-spacing: 0.01rem;
	}

	 .header-button{
		 margin: 0 auto;
		 width: 232px;
		 height: 50px;
	 }

	 .news > .inner{
		padding: 0;
		position: relative;
		top:-40px;
	}

	 .news-item{
		 display: block;
		 padding-top: 11px;
	}

	.news-meta{
		display: flex;
		width: 100%;
	}

	.news-date{
		font-size: 14px;
		width: 26%;
		margin-left: 14px;
		padding: 0;
	}

	.news-text{
		width: 27%;
		padding: 2px 0;
		margin-left: 7px;
		height: 24px;
		font-size: 12px;
	}

	.news-text a{
		padding: 2px 16px;
		font-size: 12px;
	}

	.content-wrapper{
		display: flex;
		width: 100%;
	}

	.news-content{
		font-size: 14px;
		width: 100%;
		margin-left: 14px;
		padding-right: 43px;
		margin-top: 8px;
		line-height: 1.6;
		letter-spacing: -0.4px;
	}

	.news-content::after{
		top: 22%;
		right: 11px;
	}

	.news h2{
		font-size: 30px;
	}

	.news-item{
		margin: 0;
		padding: 14px 0;
	}

	.arrow-wrapper{
		margin-left: 22px;
		margin-right: 10px;
	} 

	.button-more{
		width: 311px;
		margin: 0 auto;
		height: 54px;
		line-height: 54px;
	}

	.button-more a{
		font-size: 18px;
	}

	.service-title{
		margin-top: 20px;
		height: 483px;
	}

	.design-block{
		margin-top: 42px;
	}

	.design-block h2{
		line-height: 24px;
		letter-spacing: 0.1em;
	}

	.design-block p{
		padding-top: 19px;
		padding-bottom: 4px;
	}

	.outer{
		top: 117px;
	}
	
	.results{
		background: #3E3E3E;
		margin: 0;
		padding-bottom: 40px;
		padding-left: 16px;
		padding-top: 0px;
	}

	.results-title{
		padding-right: 16px;
	}

	.view-box{
		width: 500px;
		padding-bottom: 15px;
	}

	.view-box h3{
		font-size: 15px;
		margin-bottom: 7px;
		margin-top: 4px;
	}
	.view-box p{
		font-size: 12px;
		line-height: 20px;
	}


	.swiper-slide {
		margin-bottom: 0;
		padding-bottom: 0;
		margin-top: 0;
	}

	.swiper-pagination{
		text-align: center;
		position: static;
		margin-top: 28px;
	}

	.swiper-slide > .view-box{
		margin-top: 56%;
	}

	.swiper-img img> .view-box{
		width: 100%;
	}

	.swiper-slide,.swiper-slide-active{
		width: 276px;
	}

	.swiper-pagination{
		padding-top: 0px;
		margin-top: 21px;
		margin-bottom: 40px;
	}


.view-btn{
	width: 343px;
	padding-top: 0;
	padding-bottom: 0;
	margin: 0 auto;
}

.view-btn a{
	padding-top: 13px;
	padding-bottom: 13px;
	letter-spacing: 0.15rem;
}

td{
	font-size: 21px;
}

th, td {
	padding: 17px 12px;
}

	.inner-price{
		width: 91%;
		margin: 0 auto;
	}

	.price-title{
		padding: 40px 0;
	}

	.table2{
		padding-left: 19px;
	}

	.price p{
		padding-top: 14px;
		padding-bottom: 58px;
	}

	.comments-title h2{
		text-align-last: left;
	}

	.comments-img{
		display: none;
	}

	.comments-wrapper{
		padding-top: 0;
		height: 450px;

	}

	.comments-box{
		margin: 0;
	}

	.comment{
		padding-bottom: 31px;
	}

	.comment p{
		padding-left: 24px;
		font-size: 14px;
		line-height: 22px;
	}

	.comment img{
		width: 56px;
		height: 56px;	
	}

	.comment:first-child{
		padding-bottom: 30px;
	}
	.comment:last-child{
		padding-bottom: 10px;
	}

	.comments-title{
		padding-bottom: 40px;
	}

	.comments-bg{
		width: 100%;
		height: 450px;
	}
	.comments-bg-blank{
		height: 60px;
	}

	.qa-title{
		height: 115px;
	}
	.qaa{
		width: 90%;
		margin: 0 auto;
		padding-bottom: 40px;
	}
	
	.qa h2{
		padding: 0 0 40px 0;
	}
	.qaa-list-item{
		margin-bottom: 30px;
	}
	.qaa-list-item:last-child{
		margin-bottom: 0;
	}

	.answer-text{
		line-height: 26px;
	}

	.access-title{
		padding-top: 40px;
		text-align-last: left;
	}

	.access-address p{
		font-size: 12px;
		line-height: 21.3px;
	}

	.access-address p:last-child{
		padding-bottom: 19px;
	}

	.access-bg{
		width: 100%;
		height: 100vh;
	}

	.access-container{
		padding-left: 16px;
		display: block;
		position: static;
	}
	
	.google-map{
		height: 241px;
		padding-bottom: 63%;
		margin: 0 auto;
		width: 100%;
	}
	
	.google-map iframe{
		position: static;
		height: 100vh;
		width: 100%;
		padding-right: 16px;
		min-height: 241px;
	} 

	.map-btn{
		position: static;
		padding: 0;
		margin: 40px 16px;
		text-align: center;
	}
	
	.map-btn a{
		width: 100%;
		padding: 14px 86px;
		letter-spacing: 0;
	}
	
	.form-wrapper{
		width: 91%;
	}

	.contact{
		padding-top: 40px;
		padding-bottom: 40px;
	}

	.contact-title{
		padding-top: 32px;
		padding-bottom: 0;
	}

	.contact-title-wrapper p{
		font-size: 14px;
		padding-bottom: 36px;
		line-height: 23px;
	}

	.contact-container p{
		text-align: left;
	}

	.contact-title-wrapper{
		width: 91%;
		margin: 0 auto;
	}

	.contact-title p{
		padding-bottom: 32px;
	}

	.contact-form{
		padding-top: 40px;
		width: 90%;
	}

	.contact-select.cp_sl01 ,.contact-input{
		display: block;
		width: 100%;
	}

	.contact-select.cp_sl01{
		margin: 0 0 41px 0;
	}

	.contact-select.cp_sl01 select{
		font-size: 16px;
		padding-top: 4px;
		padding-bottom: 4px;
		padding-left: 7px;
	}

	.contact-input-select{
		margin: 0;
	}

	input[type="radio"] + span {
		margin-right: 100px;
	}

	.contact-label{
		display: block;
		margin: 0 0 6px 0;
		line-height: 21px;
	}

	.contact-label span{
		margin-left: 20px;
	}

	.contact-label, .contact-input input{
		font-size: 16px;
	}

	.contact-input input,.contact-message input{
		line-height: 23px;
		padding: 0 10px;
	}

	.contact-input{
		font-size: 16px;
	}

	.contact-input input{
		padding-bottom: 2.5px;
	}

	.contact-message{
		height: 0;
	}

	.contact-message textarea{
		height: 160px;
		margin-top: 9px;
	}

	.contact-agreement{
		margin-top: 20px;
	}

	.contact-agreement input[type="checkbox"] + span {
    padding-left: 36px;
}


	.contact-send{
		margin-top: 16.5px;
		text-align: center;
	}

	.contact-send input[type="submit"]{
		/* margin: 0 auto; */
		font-size: 18px;
		padding: 13.4px 24px;
		line-height: 0;
		width: 121px;
		margin-bottom: 40px;
	}

	.underline{
		font-size: 16px;
	}

	.contact-agreement input[type="checkbox"] + span::before {
    height: 18px;
    width: 18px;
	}


.contact-agreement input[type="checkbox"]:checked + span::after{
	border-bottom-width: 2px;
	border-left-width: 2px;
	height: 7px;
	left: 3px;
	width: 12px;
}

.input[type="checkbox"]:checked + span::after {
	position: absolute;
	top: 45%;
	transform: translateY(-45%) rotate(-45deg);
}

.contact-send input[type="submit"] {
	padding-top: 5px;
	padding-bottom: 5px;
	height: 52px;
}

.footer-inner{
	display: block;
	width: 91%;
	margin: 0 auto;
}

.footer-title{
	font-size: 34.4px;
	text-align: center;
}
.footer-copy{
	text-align: center;
}

.footer-left{
	text-align: center;
	width: 100%;
	padding-top: 60px;
}

.footer-right{
	padding-top: 40px;
}

.sitemap, .privacy{
	padding-bottom: 0px;
	}
	
	.fab .fa-twitter .fat{
		margin-bottom: 37px;
	}
    
	.fat{
		margin: 0 67px 40px 63px;
	}

	.footer-title{
		height: 62px;
	}

	.footer-list{
		font-size: 14px;
	}
	
	.sitemap, .privacy{
		display: inline-block;
		padding: 0 34px 20px 34px;
	}

	.footer-right{
		padding-top: 150px;
	}

	.footer-copy{
		padding-bottom: 92px;
	}

	.drawer,.drawer-hamburger-icon, .drawer-hamburger{
		display: block;
	}

	#page_top{
		right: 16px;
		bottom: 16px;
	}

	.footer-copy{
	letter-spacing: 0.05rem;
	}

}