@font-face {
	src: url(../font/FuturaMedium.ttf);
	font-family: "futura";
}

body {
	font-family: zen-maru-gothic, sans-serif;
}

body {
	font-weight: 500;
}

.u-desktop {
	display: none;
}

html.is-fixed {
	overflow: hidden;
}

.l-experience {
	margin-top: 48px;
	margin-top: 3rem;
}

.l-movie {
	margin-top: 57px;
	margin-top: 3.5625rem;
}

.l-withchild {
	margin-top: 34px;
	margin-top: 2.125rem;
}

/* ============================================================================
先輩お母さんの体験談！
============================================================================== */

.p-experience {
	overflow: hidden;
}

.p-experience__title {
	margin: 0 auto;
	max-width: 345px;
	max-width: 21.5625rem;
	position: relative;
	z-index: 1;
}

.p-experience__slider {
	margin: 0 auto;
	margin-top: -30px;
	margin-top: -1.875rem;
	max-width: 316px;
	max-width: 19.75rem;
	padding-bottom: 75px;
	padding-bottom: 4.6875rem;
	padding-top: 94px;
	padding-top: 5.875rem;
	position: relative;
}

.p-experience__slider .slick-list {
	overflow: unset;
}

.p-experience__slider::before {
	background-color: #FFECE5;
	content: "";
	height: 100%;
	left: 0;
	margin-left: calc(50% - 50vw);
	position: absolute;
	top: 0;
	width: 100vw;
}

.p-experience__item {
	background-color: #fff;
	border: 1px solid #000000;
	border: 0.0625rem solid #000000;
	border-radius: 0.3125rem;
	display: -webkit-box !important;
	display: -ms-flexbox !important;
	display: flex !important;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin: 0 5px;
	margin: 0 0.3125rem;
	padding: 26px 28px;
	padding: 1.625rem 1.75rem;
	position: relative;
}

.p-experience__img {
	margin: 0 auto;
	width: 119px;
	width: 7.4375rem;
}

.p-experience__subtitle {
	font-size: max(1.125rem,16px);
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1.4444444444;
	margin-top: 36px;
	margin-top: 2.25rem;
	text-align: center;
}

.p-experience__text {
	letter-spacing: normal;
	margin-top: 32px;
	margin-top: 2rem;
}

.p-experience__btn {
	cursor: pointer;
	margin: 0 auto;
	max-width: 133px;
	max-width: 8.3125rem;
	width: 100%;
}

.p-experience__slider .slide-arrow {
	display: none !important;
}

.p-experience__slider .prev-arrow {
	left: -6px;
	left: -0.375rem;
}

.p-experience__slider .next-arrow {
	right: -6px;
	right: -0.375rem;
}

.p-experience__modal {
	background-color: #fff;
	border-radius: 0.3125rem;
	bottom: 0;
	display: none;
	height: calc(100% - 1.875rem);
	left: 0;
	margin: auto;
	padding: 50px 0px 40px;
	padding: 3.125rem 0rem 2.5rem;
	padding: 0;
	position: fixed;
	right: 0;
	top: 0;
	width: calc(100vw - 1.875rem);
	z-index: 1002;
}

.p-experience__close {
	position: fixed;
	right: 20px;
	right: 1.25rem;
	top: 20px;
	top: 1.25rem;
	width: 35px;
	width: 2.1875rem;
}

.p-experience__item2 {
	display: none;
	height: calc(100vh - 1.875rem);
	margin: 0 auto;
	overflow: scroll;
	padding: 0 7.5px;
	padding: 0 0.46875rem;
	padding-top: 50px;
	padding-top: 3.125rem;
}

.p-experience__img2 {
	height: 147px;
	height: 9.1875rem;
	margin: 0 auto;
}

.p-experience__img2 img {
	height: 100%;
	margin: 0 auto;
	max-width: unset;
	width: auto;
}

.p-experience__subtitle2 {
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1;
	font-size: 16px;
	font-size: 1rem;
	font-weight: bold;
	line-height: 1.625;
	margin-top: 20px;
	margin-top: 1.25rem;
	text-align: center;
}

.p-experience__lists {
	gap: 25px;
	gap: 1.5625rem;
	background-color: #ffece5;
	border-radius: 0.3125rem;
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	margin-bottom: 40px;
	margin-bottom: 2.5rem;
	margin-top: 20px;
	margin-top: 1.25rem;
	padding: 30px 15px;
	padding: 1.875rem 0.9375rem;
}

.p-experience__list p:first-child {
	font-size: max(16px, 14px);
	font-size: max(1rem, 14px);
	font-weight: bold;
	text-align: center;
}

.p-experience__list p:last-child {
	letter-spacing: normal;
	margin-top: 26px;
	margin-top: 1.625rem;
}

.p-experience__bg {
	background: rgba(0, 0, 0, .7);
	display: none;
	height: 100%;
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 1001;
}

.p-experience__prev {
	bottom: 90px;
	bottom: 5.625rem;
	cursor: pointer;
	left: 5px;
	left: 0.3125rem;
	position: fixed;
	width: 26px;
	width: 1.625rem;
}

.p-experience__next {
	bottom: 90px;
	bottom: 5.625rem;
	cursor: pointer;
	position: fixed;
	right: 5px;
	right: 0.3125rem;
	width: 26px;
	width: 1.625rem;
}

/* ============================================================================
ある日のほりべ歯科
============================================================================== */

.p-movie__head {
	margin: 0 auto;
	position: relative;
	width: -moz-fit-content;
	width: -webkit-fit-content;
	width: fit-content;
}

.p-movie__img {
	left: -20px;
	left: -1.25rem;
	position: absolute;
	top: -28px;
	top: -1.75rem;
	width: 52px;
	width: 3.25rem;
	z-index: 1;
}

.p-movie__title {
	background-color: #fff;
	border: 1px solid #000000;
	border: 0.0625rem solid #000000;
	border-radius: 1.0625rem;
	font-size: max(15px, 14px);
	font-size: max(0.9375rem, 14px);
	font-weight: 700;
	letter-spacing: 0.1em;
	padding: 10px 16px 10px 41px;
	padding: 0.625rem 1rem 0.625rem 2.5625rem;
	position: relative;
}

.p-movie__title::before {
	background: url(../images/common/triangle.png) center center/contain no-repeat;
	bottom: -23px;
	bottom: -1.4375rem;
	content: "";
	height: 12px;
	height: 0.75rem;
	left: 50%;
	position: absolute;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 14px;
	width: 0.875rem;
}

.p-movie__main {
	margin-top: 52px;
	margin-top: 3.25rem;
}

.p-movie__house {
	margin: 0 auto;
	position: relative;
	width: 35px;
	width: 2.1875rem;
	z-index: 1;
}

.p-movie__thumbnail {
	border: 1px solid #000000;
	border: 0.0625rem solid #000000;
	border-radius: 0.3125rem;
	margin-top: -5px;
	margin-top: -0.3125rem;
	position: relative;
}

.p-movie__play-btn {
	left: 50%;
	position: absolute;
	top: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 50px;
	width: 3.125rem;
}

.p-movie__modal {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	height: 100%;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	left: 0;
	opacity: 0;
	position: fixed;
	top: 0;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
	visibility: hidden;
	width: 100%;
	z-index: 10000;
}

.p-movie__modal.is-open {
	opacity: 1;
	visibility: visible;
}

.p-movie__video {
	aspect-ratio: 313/175;
	position: relative;
	width: 90%;
	z-index: 1;
}

.p-movie__video video {
	-o-object-fit: cover;
	height: 100%;
	left: 0;
	object-fit: cover;
	position: absolute;
	top: 0;
	width: 100%;
}

.p-movie__modal-btn {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	border: 2px solid #fff;
	border: 0.125rem solid #fff;
	border-radius: 50%;
	color: #fff;
	cursor: pointer;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	font-size: 20px;
	font-size: 1.25rem;
	height: 25px;
	height: 1.5625rem;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	padding-bottom: 4px;
	padding-bottom: 0.25rem;
	position: absolute;
	right: 4%;
	top: 25px;
	top: 1.5625rem;
	width: 25px;
	width: 1.5625rem;
	z-index: 1;
}

.p-movie__modal-bg {
	background-color: rgba(0, 0, 0, .8);
	display: none;
	height: 100%;
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
}

.p-whatdo {
	background: url(../images/child/whatdo_bg.png) center center/cover repeat;
	padding-bottom: 30px;
	padding-bottom: 1.875rem;
	padding-top: 15px;
	padding-top: 0.9375rem;
}

.p-whatdo__slider .slide-arrow {
	display: none !important;
}

.p-whatdo__slider-img {
	aspect-ratio: 345/197;
	position: relative;
	width: 100%;
}

.pp-whatdo__slider-img img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-whatdo__comment {
	background: url(../images/child/whatdo_comment_sp.png) center center/contain no-repeat;
	height: 33px;
	height: 2.0625rem;
	margin-top: -13px;
	margin-top: -0.8125rem;
	position: relative;
	width: 100%;
}

.p-whatdo__comment-bg {
	width: 100%;
}

.p-whatdo__comment-text {
	font-size: 13px;
	font-size: 0.8125rem;
	font-weight: bold;
	left: 50%;
	letter-spacing: 0.1em;
	padding-left: 8px;
	padding-left: 0.5rem;
	position: absolute;
	text-align: center;
	top: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 100%;
}

.p-whatdo__comment-text:not(:first-child) {
	display: none;
}

.p-whatdo__grid {
	margin-top: 14px;
	margin-top: 0.875rem;
}

.p-whatdo__grid .slick-track {
	gap: 7px 6px;
	gap: 0.4375rem 0.375rem;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	-webkit-transform: unset !important;
	transform: unset !important;
	width: 100% !important;
}

.p-whatdo__grid .slick-slide {
	display: block !important;
	float: none !important;
	width: 100% !important;
}

.p-whatdo__grid .slick-track:before {
	display: none;
}

.p-whatdo__grid .slick-track:after {
	display: none;
}

.p-whatdo__grid-img {
	aspect-ratio: 81/53;
	border-radius: 0.1875rem;
	cursor: pointer;
	overflow: hidden;
}

.p-whatdo__grid-img img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-whatdo__grid-img:hover {
	opacity: 0.8;
}

.p-whatdo__grid-img.slick-current {
	border: 1px solid #000000;
	border: 0.0625rem solid #000000;
}

/* ============================================================================
小さなお子様連れでも安心
============================================================================== */

.p-withchild__anime {
	margin: 0 auto;
	width: 80px;
	width: 5rem;
}

.p-withchild__lists {
	gap: 17px 8px;
	gap: 1.0625rem 0.5rem;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	margin-top: 52px;
	margin-top: 3.25rem;
}

.p-withchild__list {
	cursor: pointer;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}

.p-withchild__list:hover {
	opacity: 0.8;
}

.p-withchild__modal {
	bottom: 0;
	display: none;
	height: -moz-fit-content;
	height: -webkit-fit-content;
	height: fit-content;
	left: 0;
	margin: auto;
	position: fixed;
	right: 0;
	top: 0;
	width: calc(100% - 1.875rem);
	z-index: 1002;
}

.p-withchild__modal .c-big-panel2 {
	height: auto;
}

.p-withchild__close {
	position: absolute;
	right: 12px;
	right: 0.75rem;
	top: 15px;
	top: 0.9375rem;
	width: 35px;
	width: 2.1875rem;
}

.p-withchild__bg {
	background: rgba(0, 0, 0, .5);
	display: none;
	height: 100%;
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 1001;
}

.p-withchild__prev {
	bottom: 90px;
	bottom: 5.625rem;
	cursor: pointer;
	left: -15px;
	left: -0.9375rem;
	position: absolute;
	width: 26px;
	width: 1.625rem;
}

.p-withchild__next {
	bottom: 90px;
	bottom: 5.625rem;
	cursor: pointer;
	position: absolute;
	right: -13px;
	right: -0.8125rem;
	width: 26px;
	width: 1.625rem;
}

.p-withchild__modal:first-child .p-withchild__prev {
	display: none;
}

.p-withchild__list:last-child .p-withchild__next {
	display: none;
}

@media screen and (min-width: 768px) {

.u-desktop {
	display: block;
}

.u-mobile {
	display: none;
}

.l-experience {
	margin-top: 8rem;
}

.l-movie {
	margin-top: 6.875rem;
}

.l-withchild {
	margin-top: 4.875rem;
}

.p-experience__title {
	max-width: 39.0625rem;
}

.p-experience__slider {
	margin-top: -6.4375rem;
	max-width: 55.6875rem;
	padding-bottom: 12.25rem;
	padding-top: 13rem;
}

.p-experience__item {
	border: none;
	border-radius: 0.625rem;
	margin: 0 1.125rem;
	padding: 4.6875rem 8.25rem 4.875rem;
}

.p-experience__img {
	width: 8.75rem;
}

.p-experience__subtitle {
	font-size: max(1.5rem, 18px);
	line-height: 1.6666666667;
	margin-top: 2.375rem;
}

.p-experience__text {
	font-size: max(0.9375rem, 15px);
	letter-spacing: 0.1em;
	margin-top: 2.6875rem;
}

.p-experience__btn {
	margin-top: 3rem;
	max-width: 12.8125rem;
	min-width: 100px;
}

.p-experience__btn .c-btn {
	padding-bottom: 0.75rem;
	padding-top: 0.75rem;
}

.p-experience__slider .slide-arrow {
	display: block !important;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.p-experience__modal {
	border-radius: 0.625rem;
	max-width: 47.8125rem;
	padding: 6.6875rem 5.625rem 5.5rem;
	padding: 0;
	width: 100%;
}

.p-experience__close {
	right: calc(50% - 21.875rem);
	top: 1.875rem;
	width: 4.375rem;
}

.p-experience__item2 {
	padding: 0 5.625rem;
	padding-top: 6.6875rem;
}

.p-experience__img2 {
	height: 12.5rem;
}

.p-experience__subtitle2 {
	font-size: 1.5rem;
	letter-spacing: 0.1em;
}

.p-experience__lists {
	gap: 3.5625rem;
	margin-bottom: 5.5rem;
	margin-top: 2.6875rem;
	padding: 2.8125rem 2.8125rem 4.6875rem;
}

.p-experience__list p:first-child {
	font-size: max(1.25rem, 16px);
	letter-spacing: 0.1em;
}

.p-experience__prev {
	bottom: max(11.25rem, 180px);
	left: calc(50% - 25rem);
	width: 3.375rem;
}

.p-experience__next {
	bottom: max(11.25rem, 180px);
	right: calc(50% - 25rem);
	width: 3.375rem;
}

.p-movie__inner.l-inner {
	max-width: 1470px;
}

.p-movie__img {
	left: -1.875rem;
	width: 4.4375rem;
}

.p-movie__title {
	border-radius: 1.4375rem;
	border-width: 0.125rem;
	font-size: 1.25rem;
	padding: 0.9375rem 1.5rem 0.9375rem 4.5rem;
}

.p-movie__title::before {
	bottom: -1.875rem;
	height: 1.125rem;
	width: 1.25rem;
}

.p-movie__main {
	margin-top: 7.5rem;
}

.p-movie__house {
	width: 5.6875rem;
}

.p-movie__thumbnail {
	border-radius: 0.625rem;
	border-width: 0.3125rem;
	cursor: none;
	margin-top: -1.875rem;
	overflow: hidden;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}

.p-movie__thumbnail img {
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}

.p-movie__thumbnail:hover img {
	-webkit-transform: scale(1.1);
	transform: scale(1.1);
}

.p-movie__play-btn {
	-webkit-animation-duration: 0.3s;
	animation-duration: 0.3s;
	-webkit-animation-fill-mode: forwards;
	animation-fill-mode: forwards;
	-webkit-animation-name: cursor_off;
	animation-name: cursor_off;
	opacity: 0;
	pointer-events: none;
	position: fixed;
	-webkit-transform: scale(0, 0);
	transform: scale(0, 0);
	-webkit-transition: -webkit-transform 0.3s;
	transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
	transition: transform 0.3s, -webkit-transform 0.3s;
	visibility: hidden;
}

.p-movie__thumbnail.is-cursor .p-movie__play-btn {
	-webkit-animation-duration: 0.3s;
	animation-duration: 0.3s;
	-webkit-animation-fill-mode: forwards;
	animation-fill-mode: forwards;
	-webkit-animation-name: cursor_scale;
	animation-name: cursor_scale;
	display: block;
	opacity: 1;
	-webkit-transform: scale(1, 1);
	transform: scale(1, 1);
	-webkit-transition: -webkit-transform 0.1s;
	transition: -webkit-transform 0.1s;
	transition: transform 0.1s;
	transition: transform 0.1s, -webkit-transform 0.1s;
	visibility: visible;
}

.p-movie__video {
	width: 60%;
}

.p-movie__modal-btn {
	font-size: 2.5rem;
	height: 5rem;
	width: 5rem;
}

.p-whatdo {
	background: url(../images/child/whatdo_bg_pc.png) left center/120rem repeat;
	padding-bottom: 6.875rem;
	padding-top: 5rem;
}

.p-whatdo__inner.l-inner {
	max-width: 76.5vw;
}

.p-whatdo__title {
	margin: 0 auto;
	max-width: 46.5625rem;
}

.p-whatdo__slider .slide-arrow {
	display: block !important;
	height: 3.3125rem;
	width: 3.3125rem;
}

.p-whatdo__slider .prev-arrow {
	left: -1.625rem;
}

.p-whatdo__slider .next-arrow {
	right: -1.625rem;
}

.p-whatdo__comment {
	background: url(../images/child/whatdo_comment.png) center center/contain no-repeat;
	height: 7.625rem;
	margin: 0 auto;
	margin-top: -3.25rem;
	max-width: 75rem;
}

.p-whatdo__comment-text {
	font-size: 1.875rem;
	padding: 0;
}

.p-whatdo__grid {
	margin-top: 2.5rem;
}

.p-whatdo__grid .slick-track {
	gap: 1.0625rem 0.9375rem;
	grid-template-columns: repeat(6, 1fr);
}

.p-whatdo__grid .slick-slide {
	width: 100% !important;
}

.p-whatdo__grid-img {
	aspect-ratio: 204/134;
	border-radius: 0.375rem;
}

.p-whatdo__grid-img.slick-current {
	border-width: 0.1875rem;
}

.p-withchild__inner.l-inner {
	max-width: 1470px;
}

.p-withchild__anime {
	width: 9.25rem;
}

.p-withchild__title {
	letter-spacing: 0.1em;
	margin-top: 1.5rem;
}

.p-withchild__lists {
	gap: 2.1875rem 1.25rem;
	grid-template-columns: repeat(3, 1fr);
	margin-top: 6.5625rem;
}

.p-withchild__modal {
	max-width: 47.8125rem;
	width: 100%;
}

.p-withchild__close {
	right: 1.5625rem;
	top: 1.875rem;
	width: 4.375rem;
}

.p-withchild__prev {
	bottom: 11.25rem;
	left: -1.6875rem;
	width: 3.375rem;
}

.p-withchild__next {
	bottom: 11.25rem;
	right: -1.6875rem;
	width: 3.375rem;
}

}

@media screen and (min-height: 1000px) and (min-width: 768px) {

.p-experience__modal {
	height: -moz-fit-content;
	height: -webkit-fit-content;
	height: fit-content;
}

}

@-webkit-keyframes cursor_scale {

0% {
	height: 0;
	margin: 0;
	opacity: 0;
	width: 0;
}

100% {
	height: 100px;
	margin: -50px 0 0 -50px;
	opacity: 1;
	width: 100px;
}

}

@keyframes cursor_scale {

0% {
	height: 0;
	margin: 0;
	opacity: 0;
	width: 0;
}

100% {
	height: 100px;
	margin: -50px 0 0 -50px;
	opacity: 1;
	width: 100px;
}

}

@-webkit-keyframes cursor_off {

0% {
	height: 100px;
	margin: -50px 0 0 -50px;
	opacity: 1;
	width: 100px;
}

100% {
	height: 0;
	margin: 0;
	opacity: 0;
	width: 0;
}

}

@keyframes cursor_off {

0% {
	height: 100px;
	margin: -50px 0 0 -50px;
	opacity: 1;
	width: 100px;
}

100% {
	height: 0;
	margin: 0;
	opacity: 0;
	width: 0;
}

}

