@charset "utf-8";
/* トップページ記述用CSSファイル */


/* index-head
--------------------------------------------*/
.index-head-wrap {
	position: relative;
	width: fit-content;
	margin: 0 0 0 auto;
	font-size: 20px;
}
.index-head-title {
	position: absolute;
	left: 1.2em;
	bottom: 1.3em;
	width: 5.5em;
	font-size: 6.8vw;
}

/* 初期状態（アニメ前） */
.index-head-img,
.index-head-title {
    opacity: 0;
}
/* ロード後のアニメ適用 */
.index-head.loaded .index-head-img,
.index-head.loaded .index-head-title {
    opacity: 1;
    transition: opacity .8s ease;
}
.index-head.loaded .index-head-img {
    transition-delay: 0s;
}
.index-head.loaded .index-head-title {
    transition-delay: 0.5s; /* 画像のあとに表示 */
}
/* ユーザーが「軽減されたモーション」を設定している場合にアニメ短縮/無効化 */
@media (prefers-reduced-motion: reduce) {
    .index-head-img,
    .index-head-title {
        transition: none;
    }
}

.index-head-scroll {
	position: absolute;
	right: 3vw;
	bottom: 0;
}
.index-head-scroll .txt {
	transform: rotate(90deg);
	font-size: 16px;
}
.index-head-scroll .inner {
    position: relative;
    display: block;
    overflow: hidden;
    height: 50px;
	margin: .5em 0 0;
}
@keyframes animate {
  0% {
    transform: translateY(-100%);
  }
  100% {
    transform: translateY(100%);
  }
}
.index-head-scroll .line {
    position: absolute;
    width: 1px;
    height: 100%;
    top: 0;
    right: 50%;
    background: linear-gradient(to bottom, transparent, #fff);
    animation: animate 2s linear infinite;
}

@media screen and (min-width: 768px) {
	.index-head-title {
		font-size: 3.2vw;
		left: 2.2em;
		bottom: 2em;
	}
	.index-head-scroll {
		right: 40px;
	}
	.index-head-scroll .inner {
		height: 120px;
	}
}
@media screen and (min-width: 1270px) {
	.index-head-title {
		font-size: 40px;
	}
}


/* #index-news
--------------------------------------------*/
.index-news {
	padding: 2.6em 0 5.6em;
}
.index-news-title {
	position: relative;
	margin: 0 0 1.2em;
}
.index-news-title::before {
	width: 90px;
	height: 90px;
	right: 0;
	top: -1em;
}
.index-news .main-btn {
	margin: 0 auto;
}
.post-non {
	text-align: center;
	padding: 50px 0;
}
@media screen and (min-width: 768px) {
	.index-news {
		padding: 3.9em 0 5.6em;
	}
	.index-news-wrap {
		display: flex;
		justify-content: space-between;
	}
	.index-news-title {
		width: 190px;
		flex-shrink: 0;
	}
	.index-news-title::before {
		width: 115px;
		height: 115px;
		bottom: -2em;
		left: 0;
		top: auto;
		right: auto;
	}
	.index-news-list {
		width: 100%;
	}
	.index-news .main-btn {
		margin: 0 0 0 auto;
	}
}


/* #index-read
--------------------------------------------*/
.index-read-inner {
	padding: 5.5em 0 6em;
}
.index-read-block {
	font-size: 4.7vw;
}
.index-read-block::before {
	width: 85px;
	height: 100px;
	right: 0;
	bottom: -90px;
}
.index-read-title {
	font-size: 1.8em;
}
.index-read-txt {
	margin: 2.2em 0 2.8em;
}
.index-read-txt p {
	font-size: 1em;
	line-height: 2.4;
	margin: 0 0 2em;
}
@media screen and (min-width: 390px) {
	.index-read-block {
		font-size: 18px;
	}
}
@media screen and (min-width: 768px) {
	.index-read-inner {
		padding: 8.5em 0;
	}
	.index-read-block::before {
		width: 100px;
		bottom: -20px;
	}
	.index-read-title {
		font-size: 2em;
	}
	.index-read-txt {
		margin: 3.3em 0 2.8em;
	}
}


/* #index-service
--------------------------------------------*/
.index-sv {
	padding: 5em 0 1em;
}
.index-sv-head .img {
	margin: 6em 0 0;
}
.index-sv-head .balloon {
	top: -60px;
	left: 0;
}
@media screen and (min-width: 768px) {
	.index-sv {
		padding: 7em 0;
	}
	.index-sv-head .img {
		margin: 4em 0 0;
	}
	.index-sv-head .balloon {
		top: -30px;
		left: -145px;
	}
}
@media screen and (min-width: 950px) {
	.index-sv-head {
		display: flex;
		justify-content: space-between;
		align-items: flex-end;
	}
	.index-sv-head .main {
		width: 55%;
		padding: 0 0 2.5em;
	}
	.index-sv-head .img {
		width: 40%;
		margin: 0;
	}
}

.index-sv-block {
	margin: 3em 0 5.6em;
}
.index-sv-main .head {
	position: relative;
	padding: 0 0 35px;
	margin: 20px 0 25px;
}
.index-sv-main .head::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 9px;
    background-image: radial-gradient(#CDDBB9 40%, transparent 40%);
    background-size: 9px;
    background-repeat: repeat-x;
}
.index-sv-block.reverse .index-sv-main .inner {
	margin: 0;
	padding: 0 1em 0 0;
}
.index-sv-main .title {
	text-align: center;
}
.index-sv-main .sv-icon::before {
	width: 110px;
	height: 110px;
	margin: 0 auto .5em;
}
.sv-icon::before {
	content: '';
	display: block;
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
}
#sv-dog .sv-icon::before {
	background-image: url('../image/icon/service_dog.png');
}
#sv-dog-food .sv-icon::before {
	background-image: url('../image/icon/service_dog-food.png');
}
#sv-trimming .sv-icon::before {
	background-image: url('../image/icon/service_trimming.png');
}
#sv-community .sv-icon::before {
	background-image: url('../image/icon/service_community.png');
}
.index-sv-main .main-btn {
	margin: 1.8em auto 0;
}
@media screen and (min-width: 768px) {
	.index-sv-block {
		display: flex;
		align-items: center;
	}
	.index-sv-block.reverse {
		flex-direction: row-reverse;
	}
	.index-sv-img {
		width: 46%;
	}
	.index-sv-main {
		width: 54%;
	}
	.index-sv-main .head {
		padding: 0 0 20px;
		margin: 0 0 35px;
	}
	.index-sv-main .inner {
		max-width: 510px;
		margin: 0 0 0 auto;
		padding: 0 0 0 1em;
	}
	.index-sv-main .main-btn {
		margin: 1.2em 0 0;
	}
}
@media screen and (min-width: 900px) {
	.index-sv-main .title {
		display: flex;
		align-items: center;
		text-align: left;
	}
	.index-sv-main .sv-icon::before {
		margin: 0 .7em 0 .3em;
	}
}

.index-sv-support {
	margin: -1.3em 0 4em;
}
.index-sv-support .box {
	border: 1px solid #486926;
	background: #fff;
	border-radius: 10px;
}
.index-sv-support .inner {
	padding: 2em 1em;
}
@media screen and (max-width: 849px) {
	.index-sv-support .inner {
		display: flex;
		flex-wrap: wrap;
	}
	.index-sv-support .title {
		order: 1;
		margin: 0 auto 1em;
	}
	.index-sv-support .txt {
		order: 2;
	}
	.index-sv-support .main-btn {
		order: 3;
		margin: 1.8em auto 0;
	}
}
@media screen and (min-width: 850px) {
	.index-sv-support {
		margin: -1.3em 0 6em;
	}
	.index-sv-support .inner {
		max-width: 810px;
		margin: 0 auto;
		padding: 2.4em 1em;
	}
	.index-sv-support .title {
		margin: .3em 0 1.3em;
	}
	.index-sv-support .main-btn {
		float: right;
	}
}

.index-sv-other .box {
	margin: 0 0 4em;
}
.index-sv-other .main-btn {
	text-align: center;
	width: 110px;
	height: 110px;
	padding: 0 0 1em;
	justify-content: center;
	border-radius: 50%;
	border: 1px solid;
	position: absolute;
	bottom: -1em;
	right: -1em;
}
.index-sv-other .main-btn a::after {
	top: auto;
	right: auto;
	left: 50%;
	transform: translateX(-50%);
	bottom: 8px;
}
.index-sv-other .title {
	margin: 20px 30px 15px 0;
}
@media screen and (min-width: 768px) {
	.index-sv-other {
		display: flex;
		justify-content: space-between;
	}
	.index-sv-other .box {
		width: 44.5%;
		margin: 0;
	}
}


/* #index-topics
--------------------------------------------*/
.index-topics {
	padding: 70px 0;
}
.index-topics-title {
	margin: 0 0 40px;
}
@media screen and (min-width: 768px) {
	.index-topics {
		padding: 110px 0 90px;
	}
	.index-topics-title {
		margin: 0 0 -40px;
	}
}


/* #index-shop
--------------------------------------------*/
.index-shop-img {
	width: 95%;
	margin: 0 0 0 auto;
}
.index-shop-main {
	padding: 60px 0 0;
}
.index-shop .stamp-b::before {
	width: 97px;
	height: 97px;
}
.index-shop-main.stamp-b::before {
	top: -50px;
	left: 0;
}
.index-shop-txt {
	margin: 25px 0 30px;
}
.index-shop-chara {
	position: relative;
	margin: 160px auto 40px;
	max-width: 320px;
}
.index-shop-chara.stamp-b::before {
	bottom: 20px;
	left: 40px;
}
.index-shop-chara .c02 {
	margin: 0 auto 20px 0;
}
.index-shop-chara .balloon {
	width: 300px;
	top: -70px;
	left: 10px;
}
@media screen and (max-width: 767px) {
	.index-shop-chara .c03 {
		margin: 0 0 0 auto;
	}
}
@media screen and (min-width: 768px) {
	.index-shop-img {
		position: absolute;
		top: -35px;
		right: 0;
		width: 46%;
		margin: 0;
	}
	.index-shop-main {
		width: 53%;
		padding: 80px 0 0;
	}
	.index-shop-main.stamp-b::before {
		top: 20px;
		right: 20px;
		left: auto;
	}
	.index-shop-txt {
		width: 95%;
	}
	.index-shop-chara {
		display: flex;
		align-items: flex-end;
		max-width: 530px;
		margin: 75px auto 20px;
	}
	.index-shop-chara.stamp-b::before {
		right: 0;
		bottom: 130px;
		left: auto;
	}
	.index-shop-chara .c02 {
		margin: 0 50px 70px 0;
	}
	.index-shop-chara .balloon {
		top: 10px;
		left: 200px;
	}
}
@media screen and (min-width: 1000px) {
	.index-shop-chara {
		margin: 75px 0 20px;
	}
}
@media screen and (min-width: 1200px) {
	.index-shop-img {
		width: 48%;
	}
	.index-shop-main {
		padding: 140px 0 0;
	}
	.index-shop-main.stamp-b::before {
		top: 70px;
	}
}
@media screen and (min-width: 1441px) {
	.index-shop-img {
		border-right: 5px solid #FFF9E8;
	}
}

