@charset "utf-8";
@import url("bootstrap-grid.min.css");
@import url('https://use.fontawesome.com/releases/v5.13.0/css/all.css');
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
/* -----------------------------------------------
 PC用index CSS
-------------------------------------------------- */
* {box-sizing: border-box} 
main .container-fluid .responsive {
}
.container-fluid {
  position: relative;
  padding: 0;
}
.container {
  position: relative;
  padding: 3% 8%;
  margin: auto;
  z-index: 20;
}
.pt0 {
  padding-top: 0;
}
h2[ttl]{
	background-color: rgba(249,140,100,1.00);
	font-size: 24px;
	text-shadow: none;
	letter-spacing: 1px;
	border-radius: 3px;
	margin-bottom: 1em
}
@media screen and (min-width: 1200px) {
  .container {
    padding: 3% 15%;
    margin: auto;
  }
  #cover .slick-slide img {
    width: 100%;
    height: 540px;
    max-height: 540px;
    border-radius: 10px;
    object-fit: cover
  }
}
/*fb-res*/
.facebook_wrap {
  margin: 0 auto;
  width: 100%;
  text-align: center;
  margin-bottom: 1em
}
.fb-page, .fb-page span, .facebook_wrap iframe {
  height: 620px !important;
}
/*index-banner*/
.bn-list {
  display: flex;
  flex-wrap: wrap;
}
.bn-list li {
  list-style: none;
  width: 48%;
  padding: 1%;
  text-align: center
}
.bn-list li img {
  width: 100%;
}
/*video*/
div.vid_contents {
  width: 100%; /*背景色を横幅いっぱいに広げる*/
  max-width: 1000px; /*PC版での最大幅*/
  text-align: center;
  margin: 0 auto 10px auto;
  padding: 0; /*ここで動画の周りの余白を調整*/
  background: #fff; /*余白の背景色*/
}
video.vid_main {
  width: 100%;
}
/*---cover---*/
#cover {
  position: relative;
  width: 100%;
  text-align: center
}
#cover .slick-slide {
  position: relative;
}
#cover .slick-slide img {
  width: 100%;
  height: auto;
  border-radius: 10px
}
#cover .slick-slide::after {
  content: '';
  width: 100%;
  height: 100%;
  background-color: #172a2c;
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  opacity: .4;
  z-index: 3;
  border-radius: 10px
}
#cover .center-item {
  width: 100%;
}
#cover .center-item .slick-slide {
  margin: 0 10px;
}
#cover .center-item .slick-slide:not(.slick-center) {
  -webkit-filter: opacity(70%);
  -moz-filter: opacity(70%);
  -o-filter: opacity(70%);
  -ms-filter: opacity(70%);
  filter: opacity(70%);
  transition: 0.2s linear;
}
#cover .catch {
  width: 60%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}
#cover .catch h2 {
  text-shadow: none;
  font-size: 3vw;
  margin: 0;
  padding: 0;
  letter-spacing: 1px;
}
#cover .catch h3 {
  display: inline-block;
  font-size: 20px;
  letter-spacing: 1px;
  background-color: rgba(239, 135, 25, 1.00);
  color: white;
  padding: 15px 50px;
  width: auto;
  margin: 10px
}
#cover .catch img {
  position: relative;
  width: 130px
}
/*---service---*/
#service {
	padding-top: 0;
	margin-top: 0;
	display: flex;
	flex-wrap: wrap;
}
#service div {
	width: 25%;
}
#service a{
	text-decoration: none;
	color: black;
	font-weight:bold
}
#service a h2{
	margin: 10px;
	padding: 0;
	text-align: center
}
#service a img{
	display: inline-block;
	width: 70px;
	margin: 0 auto
}
#service a ul{
	margin-left: 1em;
	padding: 0
}
#service a ul li{
	margin: 0;
	padding: 0
}
#service .cleaning a,
#service .aircon a,
#service .electric a,
#service .work a{
	display: block;
	height: 100%;
	padding: 10px 20px;
	border-radius: 15px;
	border: 2px solid #fff;
	transition: 0.3s;
	margin-bottom: 1em;
}
#service .cleaning a{background-color: rgba(241,229,245,1.00);}
#service .aircon a{background-color: rgba(204,231,244,1.00)}
#service .electric a{background-color: rgba(245,233,214,1.00)}
#service .work a{background-color: rgba(250,227,233,1.00)}

#service .cleaning a:hover{border: 2px solid #D07EE1}
#service .aircon a:hover{border: 2px solid #51ADD7}
#service .electric a:hover{border: 2px solid #ECAF4B}
#service .work a:hover{border: 2px solid #F588A4}

/* -----------------------------------------------
 お知らせ（サムネイル付）
-------------------------------------------------- */

.responsive ul {
	width: 100%;
	display: flex;
}
.responsive ul li {
  width: 32%;
	background-color: white;
 margin: 10px;
  transition: .1s all ease;
	border-radius: 10px;
	box-shadow: 2px 2px 2px 2px rgba(0,0,0,0.1)
}
.responsive ul li div {
  display: block;
  padding: 1.5em;
}
.responsive ul a {
  color: #000;
  text-decoration: none;
  font-size: 16px;
}
.responsive ul li a:hover {
  color: #40403F;
}
.responsive ul li span.date {
  display: block;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 2px;
  color: #939393;
  margin-bottom: .5em
}
.responsive ul li span.photo {
  display: block;
  text-align: center;
  z-index: 100;
  width: 100%;
  border-radius: 10px 10px 0 0;

  overflow: hidden;
}
.responsive ul li img {
  width: 100%;
	min-width: 100%;
  border-radius: 10px 10px 0 0;
  transition: 0.3s;
		object-fit: cover

	
}
.responsive ul li:hover img {
  transform: scale(1.15);
}
.responsive ul li span.date.new {
  background-image: url(../images/icon_new.svg);
  background-size: 43px 30px;
  background-repeat: no-repeat;
  background-position: left 8em top -3px;
}
.responsive ul li span.title {
  display: block;
  width: 100%;
  font-size: 14px;
  line-height: 2;
}
/*---サムネイル写真のリサイズ---*/
.resize {
  object-fit: cover;
  width: 100%;
  height: 220px;
  object-position: 50% 0; /* 他のブラウザ用(＝通常の指定) */
  font-family: 'object-fit: cover; object-position: 50% 0;' /* IE・Edge対応 */
}
@media screen and (max-width: 992px) {
#service div {
	width: 50%;
}
}
@media screen and (max-width: 769px) {
  #cover .catch {
    width: 95%;
  }
  #cover .catch h2 {
    text-shadow: none;
    font-size: 4vw;
  }
  #cover .catch h3 {
    font-size: 13px;
    letter-spacing: 0;
    padding: 8px 30px;
  }
  #cover .catch img {
    position: relative;
    width: 60px
  }
}
@media screen and (max-width: 576px) {
  .center-item .slick-slide {
    margin: 20px 3px 0 0;
  }
  #cover .catch h2 {
    font-size: 5vw;
  }
#service a ul li{
	font-size: 13px
}
}
