@charset "UTF-8";

.topnone {
	display:none;
}


#loading {
	background: #fff url(../images/loadingbg.jpg) 50% 50% no-repeat;
	background-size:cover;
}

#loadingmainlogo {
	position:absolute;
	top:50%;
	left:50%;
	margin-left:-400px;
	margin-top:-120px;
	width:800px;
}


/* スクロールダウンアニメーション */
.container_04 {
	position:absolute;
	bottom:10px;
	left:50%;
/*
	height: 250px;
	background-color: #cdb5b5;
*/
}

.scrollbar-text_04 {
	display: inline-block;
	position: absolute;
	bottom: 0;
	padding: 10px 10px 110px;
	color: #fff;
	font-size: 13px;
	font-family: serif;
	line-height: 1;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	writing-mode: vertical-lr;
	left: 50%;
	transform: translateX(-50%);
}

.scrollbar_04 {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 1px;
}

.scrollbar_04::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 1px;
	height: 100px;
	background: #fff;
}

.scrollbar_04::before {
	content: "";
	position: absolute;
	bottom: 0;
	left: -4px;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #fff;
	animation: circlemove 3s ease-in-out infinite,
	  cirlemovehide 3s ease-out infinite;
}

@keyframes circlemove {
	0% {
		bottom: 95px;
	}
	100% {
		bottom: 0px;
	}
}

@keyframes cirlemovehide {
	0% {
		opacity: 0;
	}
	50% {
		opacity: 1;
	}
	80% {
		opacity: 0.9;
	}
	100% {
		opacity: 0;
	}
}




.topbg {
	position:relative;
	width:100%;
	min-height:600px;
	height:100svh;
	overflow:hidden;
	background:#fff url(../images/topbg.jpg) 50% 50% no-repeat;
	background-size:cover;
	background-attachment:fixed;
}


.mainlogo {
	position:absolute;
	top:50%;
	left:50%;
	margin-left:-400px;
	margin-top:-120px;
	width:800px;
	z-index:10;
	transition: all 0.5s;
}


.mainicatch {
	display:flex;
	justify-content:center;
	width:600px;
	margin-top:50px;
}


.pickupwaku {
	background-color:#fff;
	min-width:1200px;
}

dl.pickup {
	display:flex;
	margin:0 0 20px 0;
	padding:0;
}

dl.pickup dt {
	width:200px;
	padding:5px;
	text-align:center;
}

.ptitle {
	font-size:1.2em;
	font-weight:bold;
	color:#008;
	margin-bottom:0.5em;
}

.ptitle span {
	position:relative;
}

.ptitle span:after {
	content:"";
	position:absolute;
	bottom:0em;
	left:0;
	width:100%;
	height:0.4em;
	background-color:rgba(0,0,255,0.1);
}

dl.pickup dd {
	padding:5px 10px;
	flex:1;
}


#servicemenu {
	width:100%;
	height: calc(100vh - 80px);
	min-height:600px;
	background-color:#000;
}

.servicemenutitle {
	position:relative;
	width:10%;
	background-color:#fff;
}

.smenu {
	display:block;
	text-decoration:none;
	position:relative;
	width:30%;
	height: calc(100vh - 80px);
	min-height:600px;
	overflow:hidden;
}

.smenu-title0 {
	position:absolute;
	top:10px;
	right:0.5em;
	padding:15px;
	font-family: "Noto Serif JP", serif;
	font-size:2.5em;
	font-weight:bold;
	color:#333;
}

.smenu-title1 {
	position:absolute;
	top:15px;
	right:3.5em;
	padding:15px;
	font-family: "Noto Serif JP", serif;
	font-size:1.4em;
	font-weight:bold;
	color:#333;
}

.smenu-title {
	position:absolute;
	top:10px;
	right:10px;
	padding:15px;
	font-family: "M PLUS 1p", sans-serif;
	font-size:2em;
	font-weight:bold;
	color:#038;
	background-color:rgba(255,255,255,0.8);
	z-index:1;
}

.smenu-cmt {
	position:absolute;
	top:50px;
	right:10vw;
	height: calc(100vh - 200px);
	padding:10px;
	font-size:1.4em;
	font-weight:bold;
	color:#fff;
	line-height:1.6;
	background-color:rgba(0,0,0,0.3);
	opacity:0;
	z-index:1;
	transition: all 0.5s;
}

.smenu:hover .smenu-cmt {
	opacity:1;
}

.simg {
	width:100%;
	height:100%;
	object-fit:cover;
	transition: all 0.5s;
}

.smenu:hover .simg {
	opacity:0.5;
	transform: scale(1.1, 1.1);
}


.servicewaku {
	position:relative;
	background-color:#eef;
	min-width:1200px;
}

.service-bg {
	width:100%;
	min-height: calc(100svh - 80px);
	padding-bottom:150px;
	background-color:rgba(0,0,0,0.2);
	transition: all 0.5s;
}

.service-bg:hover {
	background-color:rgba(255,255,255,0.3);
}

.service-bg01 {
	background:url(../images/oshibori_bg.png) center center no-repeat;
	background-size:cover;
	background-attachment:fixed;
}


.bg01 {
	padding-top:150px;
	width: 50%;
	height:40vw;
	object-fit:cover;
	overflow:hidden;
}

.bg02 {
	margin-left:40%;
	padding-top:160px;
	width: 60%;
	height:40vw;
	object-fit:cover;
	overflow:hidden;
}

.bg03 {
	padding-top:180px;
	width: 50%;
	height:40vw;
	object-fit:cover;
	overflow:hidden;
}

.text01 {
	position:absolute;
	top:10px;
	left: calc(50% - 600px);
	font-size:3.6em;
	font-weight:bold;
	letter-spacing:0.1em;
	background-color:rgba(255,255,255,0.9);
	padding:10px 20px;
	color:#25a;
}

.text01 a {
	color:#25a;
}

.text01 a:hover {
	color:#25a;
	text-decoration:none;
}

.text02 {
	position:absolute;
	top:5vw;
	font-size:2.5em;
	font-weight:bold;
	right:3vw;
	letter-spacing:0.1em;
	white-space:nowrap;
	background-color:rgba(255,255,255,0.9);
	padding:10px 20px;
	color:#038;
	z-index:1;
}

.text03 {
	position:absolute;
	top:-25vw;
	left: 10%;
	font-size:1.8em;
	line-height:1.6em;
	padding:10px;
	background-color:rgba(255,255,255,0.7);
	border-radius:10px;
}

.text04 {
	position:absolute;
	top:10vw;
	left: 5%;
	font-size:1.8em;
	line-height:1.6em;
	padding:10px;
	background-color:rgba(255,255,255,0.7);
	border-radius:10px;
}

.text05 {
	position:absolute;
	top:10vw;
	right: 5%;
	font-size:1.8em;
	line-height:1.6em;
	padding:10px;
	background-color:rgba(255,255,255,0.7);
	border-radius:10px;
}

.img03 {
	position:absolute;
	top:12vw;
	left: 10%;
	width:520px;
	border-radius:10px;
	overflow:hidden;
}

.service-bg02 {
	background:url(../images/dastcleaning_bg.jpg?2) center center no-repeat;
	background-size:cover;
	background-attachment:fixed;
}

.service-bg03 {
	background:url(../images/hanbai_bg.jpg?2) center center no-repeat;
	background-size:cover;
	background-attachment:fixed;
}


.complogo {
	width:80%;
	max-width:500px;
}

.gmap {
	width:100%;
	height:auto;
	aspect-ratio: 5 / 2;
	border:1px solid #ccc;
}

.companygaiyouwaku {
}



.jigyo01 {
	position:relative;
	width:100%;
	height:auto;
	max-height:250px;
	overflow:hidden;
}

.jigyo01 img {
	width:200%;
	object-fit:cover;
}

.jigyo01title {
	position:absolute;
	top:50%;
	left:50%;
	width:50vw;
	margin-left:-25vw;
}

.jigyo01text {
	font-size:1.8em;
	font-weight:bold;
}


/* パソコンonly用 */
@media screen and (min-width:566px){
	.loadingmainchatchpc {
		position:absolute;
		top:50%;
		left:50%;
		margin-left:-40vw;
		margin-top:100px;
		width:80vw;
		text-align:center;
	}
	
	.loadingmainchatchsp {
		display:none;
	}
	
	.mainchatchpc {
		position:absolute;
		top:50%;
		left:50%;
		margin-left:-40vw;
		margin-top:100px;
		width:80vw;
		text-align:center;
		z-index:10;
	}
	
	.mainchatchsp {
		display:none;
	}
}

/* スマホ用 */
@media screen and (max-width:565px){
	#topmenu {
		position:relative;
		width:100%;
		height:100svh;
		overflow:hidden;
	}
	
	#loadingmainlogo {
		position:absolute;
		top:10svh;
		left:0;
		margin-left:0;
		margin-top:0;
		padding:10vw;
		width:100%;
		text-align:center;
	}
	
	.mainlogo {
		position:absolute;
		top:10svh;
		left:0;
		margin-left:0;
		margin-top:0;
		padding:10vw;
		width:100%;
		text-align:center;
	}
	
	.mainicatch {
		display:block;
		width:100%;
		margin-top:20px;
		text-align:center;
	}
	
	.mainicatch img {
	}
	
	.loadingmainchatchpc {
		display:none;
	}
	
	.loadingmainchatchsp {
		position:absolute;
		top:520px;
		left:0;
		margin-left:0;
		margin-top:0;
		padding:5vw;
		text-align:center;
		width:100%;
	}
	
	.mainchatchpc {
		display:none;
	}
	
	.mainchatchsp {
		position:absolute;
		top:520px;
		left:0;
		margin-left:0;
		margin-top:0;
		padding:5vw;
		text-align:center;
		width:100%;
		z-index:10;
	}
	
	
	.pickupwaku {
		min-width:100%;
	}
	
	dl.pickup dt {
		width:40vw;
		padding:5px 5px;
		text-align:center;
	}
	
	
	.servicewaku {
		min-width:100%;
	}
	
	
	#servicemenu {
		height: 100svh;
		min-height:400px;
	}
	
	.servicemenutitle {
		width:100%;
		height: 10svh;
	}
	
	.smenu {
		width:100%;
		height: 30svh;
		min-height:30svh;
		overflow:hidden;
	}
	
	.smenu-title0 {
		position:relative;
		top:0;
		right:0;
		padding:5px;
		font-size:1.5em;
	}
	
	.smenu-title1 {
		position:relative;
		top:0;
		right:0;
		padding:5px;
		font-family: "Noto Serif JP", serif;
		font-size:1.1em;
	}
	
	.smenu-title {
		position:absolute;
		top:10px;
		left:10px;
		right:auto;
		width: calc(100% - 20px);
		padding:10px;
		font-size:1.5em;
		background-color:rgba(255,255,255,0.8);
		z-index:1;
	}
	
	.smenu-cmt {
		position:absolute;
		top:90px;
		left:10px;
		right:auto;
		height: auto;
		width: calc(100% - 20px);
		padding:5px;
		font-size:1em;
		line-height:1.6;
		opacity:1;
	}
	
	.simg {
		opacity:0.5;
	}
	
	.service-bg {
		min-height: 100svh;
		padding-bottom:50px;
	}
	
	.service-bg01 {
		background-attachment:local;
	}
	
	.service-bg02 {
		background-attachment:local;
	}
	
	.service-bg03 {
		background-attachment:local;
	}
	
	
	.bg01 {
		margin-top:40px;
		width: 90%;
		height:300px;
	}
	
	.bg02 {
		margin-left:0;
		padding-top:420px;
		width: 100%;
		height:auto;
	}
	
	.bg03 {
		margin-left:0;
		padding-top:420px;
		width: 100%;
		height:auto;
	}
	
	.text01 {
		position:absolute;
		top:10px;
		left: 0;
		font-size:1.6em;
		padding:5px 10px;
	}
	
	.text02 {
		position:absolute;
		top:70px;
		right:auto;
		left:5px;
		font-size:1.5em;
		font-weight:bold;
		letter-spacing:0.1em;
		white-space:nowrap;
		background-color:rgba(255,255,255,0.9);
		padding:5px 10px;
	}
	
	.text03 {
		position:absolute;
		top:10px;
		left: 10px;
		width: calc(100% - 20px);
		font-size:1.1em;
		line-height:1.6em;
		padding:5px;
	}
	
	.text04 {
		position:absolute;
		top:70px;
		left: 10px;
		width: calc(100% - 20px);
		font-size:1.1em;
		padding:5px;
	}
	
	.text05 {
		position:absolute;
		top:70px;
		right:auto;
		left:10px;
		width: calc(100% - 20px);
		font-size:1.1em;
		line-height:1.6em;
		padding:5px;
		background-color:rgba(255,255,255,0.7);
		border-radius:10px;
	}
	
	.img03 {
		position:absolute;
		top:80px;
		left: 10px;
		width:300px;
	}
	
	.gmap {
		aspect-ratio: 5 / 4;
	}
	
	
	
	
	.jigyo01 {
		position:relative;
		width:100%;
		height:auto;
		overflow:hidden;
	}
	
	.jigyo01 img {
		width:100%;
		object-fit:contain;
	}
	
	.jigyo01title {
		position:absolute;
		top:50%;
		left:50%;
		width:80vw;
		margin-left:-40vw;
	}
	
	.jigyo01text {
		font-size:1.4em;
	}
	
	
	
}
