@charset "utf-8";


.ippo_carousel {
	height: 50%;
	margin: 0 auto;
	position: relative;
	overflow: visible;
}

.swiper {
	height: 100%;
	overflow: hidden;
}

.swiper-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.swiper-slide:not(.swiper-slide-active) {
	opacity: 0.7;
}

.ippo_carousel .swiper-pagination {
	bottom: -32px;
	z-index: 5;
}

.swiper-pagination-bullet {
	width: 8px;
	height: 8px;
	border-radius: 50%;
}

.swiper-pagination-bullet.swiper-pagination-bullet-active {
	background: var(--brand-color);
}

.bi {
	font-size: 48px;
	color: var(--brand-color);
}

.ippo-button-prev,
.ippo-button-next {
	position: absolute;
	top: calc(50% - 24px);
	line-height: 0;
	z-index: 2;
}

.ippo-button-prev {
	left: calc(25% - 24px);
	/* left:  24px; */
}

.ippo-button-next {
	right: calc(25% - 24px);
	/* right: 24px; */
}

.slider-text {
	position: absolute;
	top: 16px;
	left: calc(50% - 200px);
	z-index: 4;
}



/* announcements */

.announcements {
	padding: 48px 32px 32px;
	position: relative;
	background: var(--bg-color-green);
}

.announcements::after {
	content: '';
	background: url(../img/bg-notice.png) center/cover;
	width: 100%;
	height: 32px;
	position: absolute;
	bottom: -32px;
	left: 0;
}

.announcements__container {
	display: flex;
	justify-content: center;
	align-items: center;
}

.announcements__container img {
	margin-right: 50px;
}

.announcements__title-sp {
	display: none;
}

.announcements__item {
	width: 400px;
}

.announcements__link_to_blog {
	font-size: 14px;
	color: #666;
	text-indent: -1.4em;
	padding-left: 1.4em;
	margin-bottom: 8px;
}

.announcements__link_to_blog::before {
	content: '\0274b ';
	color: var(--brand-color);
}

.announcements__link_to_blog a {
	font-size: 16px;
	color: var(--brand-color);
}

.announcement {
	width: 400px;
	height: 150px;
	padding: 8px 20px;
	border: 1px solid #999;
	overflow: auto;
	overflow-y: scroll;
}

.announcement dt {
	font-size: 12px;
	line-height: 1.8;
	color: #999;
}

.announcement dt img {
	width: 30px;
	height: 12px;
	vertical-align: middle;
}

.announcement dd {
	color: #555;
	font-size: 13px;
	margin-bottom: 8px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--brand-color);
}

.announcement dd a {
	color: #555;
}


/* main */

.hero {
	padding: 32px;
	position: relative;
}

.hero__bg__branch-l {
	position: absolute;
	content: "";
	top: 128px;
	left: 0;
	z-index: -1;
}


.hero__bg__branch-r {
	position: absolute;
	content: "";
	top: 186px;
	right: 0;
	z-index: -2;
}

.hero__container {
	margin: 0 auto;
	padding: 24px;
	max-width: 750px;
	background: #fff;
	opacity: .9;
}

.hero__container>p {
	margin-bottom: 48px;
}

.hero__letter {
	margin: 0 auto;
	width: calc(100% - 32px);
	max-width: 750px;
}

.hero__letter p {
	font-size: 17px;
	line-height: 2;
	margin-bottom: 22px;
}

.hero__important {
	font-size: 18px;
	font-weight: bold;
	color: var(--brand-color);
}

.hero__h2-pc {
	width: 100%;
	max-width: 750px;
	height: auto;
	margin: 0 auto;
}

.hero__h2-sp {
	display: none;
}



/* guardian */

.guardian {
	background: rgb(250, 245, 228);
	padding: 32px;
	position: relative;
}

.guardian::before {
	content: '';
	background: url(../img/bg_beige_before.png) center/cover;
	width: 100%;
	height: 32px;
	position: absolute;
	top: -31px;
	left: 0;
}

.guardian::after {
	content: '';
	background: url(../img/guardian-after.png) center/cover;
	width: 100%;
	height: 32px;
	position: absolute;
	bottom: -31px;
	left: 0;
}

.guardian__container {
	margin: 0 auto;
	width: 750px;
}

.guardian__container p {
	margin: 4px 0 18px;
}

.guardian__h3 {
	margin: 32px 0;
}

.guardian__h4 {
	text-align: left;
}

.guardian__h2-pc {
	margin: 0 auto 16px;
	text-align: center;
}

.guardian__h2-pc img {
	width: 600px;
	height: auto;
}

.guardian__h2-sp {
	display: none;
}

/* snow */

.guardian__container__snow {
	background: white;
	border-radius: 50%;
	position: absolute;
	animation: snowup 10s linear;
}

@keyframes snowup {
	0% {
		opacity: 0;
		bottom: 0;
	}

	10% {
		opacity: 1;
	}

	90% {
		opacity: 1;
	}

	100% {
		opacity: 0;
		top: 0;
	}
}



/* features */

.features {
	width: 100%;
	background: url(../img/bg-features.png) center top/contain rgb(180, 225, 243);
	padding: 64px;
}

.features__h2-pc {
	text-align: center;
	margin-bottom: 64px;
}

.features__h2-pc img {
	width: 600px;
}

.features__h2-sp {
	display: none;
}

.features__container {
	display: grid;
	max-width: 1000px;
	margin: 0 auto;
	grid-template-columns: 1fr 32px 1fr;
	grid-template-rows: 1fr 96px 1fr;
}

.feature1 {
	grid-column: 1/2;
	grid-row: 1/2;
}

.feature2 {
	grid-column: 3/4;
	grid-row: 1/2;
}

.feature3 {
	grid-column: 1/2;
	grid-row: 3/4;
}

.feature4 {
	grid-column: 3/4;
	grid-row: 3/4;
}

.features__circle img {
	width: 300px;
	height: auto;
	border-radius: 50%;
	box-shadow: 0 10px 25px 0 rgba(0, 0, 0, .5);
}

.features__pic {
	position: relative;
	text-align: center;
}

.features__cloud {
	position: absolute;
	content: '';
	top: -32px;
	left: 16px;
	transition: top .5s;
	z-index: 2;
}

.features__cloud:hover {
	top: -37px;
}

.features__circle:hover {
	transform: rotate(5deg);
}

.features__desc {
	background: rgb(56, 186, 183);
	opacity: .8;
	padding: 16px 4px;
	border-radius: 64px;
	font-weight: bold;
	color: #fff;
	width: 20em;
	margin: 8px auto;
}

.features__desc:hover {
	opacity: 1;
}




/* small screen */

@media (max-width: 767px) {


	/* slider */

	.ippo_carousel .swiper {
		overflow: hidden;
	}

	.ippo-button-prev {
		left: -8px;
	}

	.ippo-button-next {
		right: -8px;
	}



	/* announcements */

	.announcements__container {
		display: block;
	}

	.announcements__container>p {
		text-align: center;
	}

	.announcements__container img {
		margin: 0;
	}

	.announcements__item {
		width: 100%;
		margin: 0 auto;
	}

	.announcement {
		width: 100%;
		height: 200px;
		margin: 0 auto;
		padding: 8px;
	}

	.announcements__title-sp {
		display: block;
		margin-bottom: 16px;
	}

	.announcements__title-pc {
		display: none;
	}



	/* main */

	.hero {
		margin: 0 auto;
		padding: 24px 4px;
	}

	.hero__h2-sp {
		display: block;
		width: calc(100% - 32px);
		height: auto;
		max-width: 500px;
		margin: 32px auto;
	}

	.hero__h2-pc {
		display: none;
	}

	.hero__container {
		padding: 0;
	}

	.hero__container>p {
		margin-bottom: 24px;
	}

	.hero__letter {
		margin: 0 auto 24px;
	}

	.hero__letter p {
		font-size: 16px;
		line-height: 1.8;
	}

	.hero__bg__branch-l,
	.hero__bg__branch-r {
		display: none;
	}



	/* guardian */

	.guardian {
		padding: 0 4px;
	}

	.guardian__h2-pc {
		display: none;
	}

	.guardian__h2-sp {
		display: block;
		margin: 0 auto 32px;
		text-align: center;
	}

	.guardian__h2-sp img {
		width: 100%;
		height: auto;
		max-width: 500px;
	}

	.guardian__container {
		width: calc(100% - 32px);
		padding: 32px 0;
		margin: 0 auto;
	}



	/* features */

	.features {
		text-align: center;
		padding: 64px 0;
	}

	.features__h2-pc {
		display: none;
	}

	.features__h2-sp {
		display: block;
		width: calc(100% - 32px);
		height: auto;
		max-width: 500px;
		margin: 0 auto 32px;
	}

	.features__container {
		display: block;
		width: calc(100% - 32px);
		margin: 32px auto;
		max-width: 350px;
	}

	.circle img {
		width: 70%;
		height: auto;
		/* min-width:250px; */
	}

	.feature1,
	.feature2,
	.feature3 {
		margin-bottom: 80px;
	}

	.features .desc {
		padding: 4px 4px;
		border-radius: 32px;
		width: 100%;
		margin: 8px auto;
	}

	.features__circle img {
		width: 240px;
	}

}