@charset "utf-8";
/* ===================================
トップ画像
=================================== */

.top_image {
  background-image: url(../images/facility/top_img.jpg);
}

/* ===================================
各校紹介
=================================== */

.start {
  padding-top: 1em;
}

.start .h2_under {
  display: block;
  width: 112px;
  margin: 1em auto 3.5em;
}

@media print, screen and (min-width: 600px) {
  .start {
    padding-top: 2em;
  }
}

.school_area {
  margin-top: 2em;
  padding-bottom: 3em;
  position: relative;
}

.wrapper {
  width: 85%;
  max-width: 950px;
}

.schoolbox {
  margin-bottom: 3.5em;
  position: relative;
  z-index: 99;
}

.schoolbox::before {
  content: "";
  width: 50px;
  height: 70px;
  position: absolute;
  top: -0.9em;
  left: 6px;
  z-index: 999;
}

.schoolbox.naka::before {
  background: url(../images/facility/naka_clip.svg) center / contain no-repeat;
}

.schoolbox.hashikabe::before {
  background: url(../images/facility/hashikabe_clip.svg) center / contain no-repeat;
}

.schoolbox.katsuta::before {
  background: url(../images/facility/katsuta_clip.svg) center / contain no-repeat;
}

.schoolbox::after {
  content: "";
  width: 0;
  height: 0;
  border: 34px solid transparent;
  border-bottom-color: #C4ECF3;
  border-right-color: #C4ECF3;
  position: absolute;
  right: -20px;
  bottom: -20px;
  z-index: 99;
}

.schoolbox_inner {
  padding: 2em 1.5em 1.5em;
  display: flex;
  flex-wrap: wrap;
  position: relative;
  top: 0;
  text-align: left;
  background-color: #fff;
  border: 3px solid #ccc;
  border-radius: 3px;
  z-index: 99;
}

.schoolbox.naka .schoolbox_inner {
  box-shadow: 10px 10px 0 #24A263;
}

.schoolbox.hashikabe .schoolbox_inner {
  box-shadow: 10px 10px 0 #0B74D1;
}

.schoolbox.katsuta .schoolbox_inner {
  box-shadow: 10px 10px 0 #E88521;
}

/* 折り返し装飾 */
.schoolbox_inner::before {
  content: "";
  width: 42px;
  height: 42px;
  background-color: #e2e2e2;
  border-radius: 3px 0 0 0;
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 99;
  box-shadow: -2px -2px 0 #ccc;
}

.schoolbox_inner::after {
  content: "";
  width: 0;
  height: 0;
  border: 24px solid transparent;
  position: absolute;
  right: -4px;
  bottom: -4px;
  z-index: 999;
}

.schoolbox.naka .schoolbox_inner::after {
  border-bottom-color: #24A263;
  border-right-color: #24A263;
}

.schoolbox.hashikabe .schoolbox_inner::after {
  border-bottom-color: #0B74D1;
  border-right-color: #0B74D1;
}

.schoolbox.katsuta .schoolbox_inner::after {
  border-bottom-color: #E88521;
  border-right-color: #E88521;
}



.schoolbox.hashikabe .text {
  order: 1;
}

.schoolbox.hashikabe .img {
  order: 2;
}

.schoolbox_inner .text h3 {
  padding-left: 30px;
  display: flex;
  align-items: center;
  position: relative;
  font-size: 1.2em;
  font-weight: 500;
}

.schoolbox.naka .schoolbox_inner .text h3 {
  color: #24A263;
}

.schoolbox.hashikabe .schoolbox_inner .text h3 {
  color: #0B74D1;
}

.schoolbox.katsuta .schoolbox_inner .text h3 {
  color: #E88521;
}

.schoolbox .schoolbox_inner .text h3::after {
  content: "";
  margin-left: 0.5em;
  flex-grow: 1;
}

.schoolbox.naka .schoolbox_inner .text h3::after {
  border-top: 2px dashed #24A263;
}

.schoolbox.hashikabe .schoolbox_inner .text h3::after {
  border-top: 2px dashed #0B74D1;
}

.schoolbox.katsuta .schoolbox_inner .text h3::after {
  border-top: 2px dashed #E88521;
}

.schoolbox .schoolbox_inner .text h3::before {
  content: "";
  position: absolute;
}

.schoolbox.naka .schoolbox_inner .text h3::before {
  width: 85px;
  height: 85px;
  top: -20px;
  right: -15px;
  background: url(../images/facility/school_naka_illust01.svg) center / contain no-repeat;
}

.schoolbox.hashikabe .schoolbox_inner .text h3::before {
  width: 65px;
  height: 60px;
  top: -18px;
  right: -8px;
  background: url(../images/facility/school_hashikabe_illust01.svg) center / contain no-repeat;
}

.schoolbox.katsuta .schoolbox_inner .text h3::before {
  width: 65px;
  height: 60px;
  top: -18px;
  right: -8px;
  background: url(../images/facility/school_katsuta_illust01.svg) center / contain no-repeat;
}

.schoolbox_inner .text .h3_sub {
  margin-top: 0.2em;
  padding-left: 30px;
  display: block;
  font-size: 0.9em;
}
.schoolbox_inner .text p {
  margin-bottom: 1em;
  font-size: 0.95em;
  line-height: 1.8em;
}

.schoolbox_inner .text p a {
  color: #000;
}

.schoolbox_inner .text p:first-of-type {
  margin-top: 1em;
}

.schoolbox_inner .text p:last-child {
  margin-bottom: 0;
}

.schoolbox_inner .img {
  margin-top: 1.5em;
  position: relative;
}

.schoolbox_inner .img::before {
  width: 96%;
  height: 94%;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  content: "";
  position: absolute;
  border: 1px solid #fff;
  border-radius: 15px;
}

.schoolbox.naka .schoolbox_inner .img::after {
  content: "";
  width: 110px;
  height: 132px;
  position: absolute;
  bottom: -13px;
  left: -14px;
  background: url(../images/facility/school_naka_illust02.svg) center / contain no-repeat;
}

.schoolbox.hashikabe .schoolbox_inner .img::after {
  content: "";
  width: 100px;
  height: 100px;
  position: absolute;
  top: -34px;
  right: -14px;
  background: url(../images/facility/school_hashikabe_illust02.svg) center / contain no-repeat;
}

.schoolbox.katsuta .schoolbox_inner .img::after {
  content: "";
  width: 110px;
  height: 132px;
  position: absolute;
  bottom: -13px;
  left: -14px;
  background: url(../images/facility/school_katsuta_illust02.svg) center / contain no-repeat;
}

.schoolbox_inner .img img {
  width: 100%;
  display: block;
  border-radius: 15px;
}

@media print, screen and (min-width: 600px) {
  .schoolbox_inner {
    padding: 2em 1.8em 2.5em;
  }

}

@media print, screen and (min-width: 768px) {
  .schoolbox::after {
    border: 27px solid transparent;
    border-bottom-color: #d4eff9;
    border-right-color: #d4eff9;
}

  .schoolbox_inner {
    flex-wrap: nowrap;
    justify-content: center;
    align-items: flex-start;
  }
  .schoolbox.naka .schoolbox_inner {
    box-shadow: 20px 20px 0 #24A263;
  }

  .schoolbox.hashikabe .schoolbox_inner {
    box-shadow: 20px 20px 0 #0B74D1;
  }

  .schoolbox.katsuta .schoolbox_inner {
    box-shadow: 20px 20px 0 #E88521;
  }

  .schoolbox.naka .schoolbox_inner .img::after {
    width: 130px;
    height: 150px;
    bottom: -22px;
    left: -30px;
  }
  .schoolbox.hashikabe .schoolbox_inner .img::after {
    width: 135px;
    height: 105px;
    top: auto;
    bottom: -20px;
    right: 1px;
  }
  .schoolbox.katsuta .schoolbox_inner .img::after {
    width: 130px;
    height: 150px;
    bottom: -22px;
    left: -30px;
  }
  .schoolbox_inner .text {
    width: 88%;
  }
  .schoolbox.hashikabe .text {
    order: 2;
  }
  .schoolbox.hashikabe .img {
    order: 1;
  }
  .schoolbox.naka .schoolbox_inner .text, .schoolbox.katsuta .schoolbox_inner .text {
    margin-right: 1.5em;
  }
  .schoolbox.hashikabe .schoolbox_inner .text {
    margin-left: 1.5em;
  }
  .schoolbox.hashikabe .schoolbox_inner .text h3 {
    padding-left: 0;
  }
  .schoolbox.naka .schoolbox_inner .text h3::before {
    width: 99px;
    height: 80px;
    top: -10px;
    right: 6px;
  }
  .schoolbox.hashikabe .schoolbox_inner .text h3::before {
    width: 30%;
    height: 70px;
    top: -18px;
    right: -2px;
  }
  .schoolbox.katsuta .schoolbox_inner .text h3::before {
    width: 90px;
    height: 60px;
    top: 0px;
    right: -8px;
  }
  .schoolbox_inner .text p {
    font-size: 1em;
  }
  .schoolbox_inner .img {
    max-width: 360px;
    margin-top: 1em;
  }
}

@media print, screen and (min-width: 1025px) {
  .schoolbox {
    margin-bottom: 5.5em;
  }
  .schoolbox::after::after {
    height: 86%;
    top: 20%;
    left: 2.8%;
  }
  .schoolbox_inner {
    padding: 2.5em 1.8em
  }
  .schoolbox_inner .text {
    max-width: 381px;
  }
  .schoolbox.naka .schoolbox_inner .text, .schoolbox.katsuta .schoolbox_inner .text {
    margin-right: 3.5em;
  }
  .schoolbox.hashikabe .schoolbox_inner .text {
    margin-left: 3.5em;
  }
  .schoolbox_inner .text h3 {
    font-size: 1.4em;
  }
  .schoolbox.naka .schoolbox_inner .text h3, .schoolbox.katsuta .schoolbox_inner .text h3 {
    padding-left: 0;
  }
  .schoolbox_inner .text .h3_sub {
    padding-left: 0;
    font-size: 0.95em;
  }
}

/* ===================================
各校紹介 - 装飾
=================================== */

.illust_school {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 7em;
  left: 0;
  background: url(../images/facility/school_back_sp.png) center / cover no-repeat;
  overflow: hidden;
  z-index: 1;
}

.illust_school img {
  width: 100%;
}

.illust_school::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  background: url(../images/facility/school_bottom.svg) left bottom / contain no-repeat;
}

.illust_school .illust_01 {
  width: 116px;
  height: 172px;
  position: absolute;
  bottom: 0;
  left: 50px;
}

@media print, screen and (min-width: 600px) {
  .illust_school {
    background-image: url(../images/facility/school_back_pc.png);
  }
}

@media print, screen and (min-width: 1025px) {
  /* .illust_school {
    background-position: 0 0, 75px 75px;
    background-size: 150px 150px;
  } */
  .illust_school .illust_01 {
    width: 210px;
    height: 304px;
    left: auto;
    right: calc(50% + 530px);
  }
}

/* ===================================
施設紹介
=================================== */

.faci_area {
  width: 100%;
  height: auto;
  margin-top: 9em;
  padding-bottom: 4em;
  text-align: center;
}

.faci_inner {
  width: 85%;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
}

.faci_area.forest_deco::before, .faci_area.forest_deco::after {
  padding-top: 3em;
  display: none;
}

.faci_area h2 {
  margin-bottom: 1.5em;
}

.faci_box {
  margin-top: 2em;
  text-align: left;
}

.faci_box:first-child {
  margin-top: 0;
}

.faci_box img {
  width: 100%;
  border-radius: 3px;
}

.faci_box h3 {
  margin: 0.5em 0;
  display: block;
  position: relative;
  font-family: "keifont";
  font-size: 1.1em;
  font-weight: 500;
}

.faci_box:first-child h3::before {
  content: "";
  width: 50px;
  height: 81px;
  position: absolute;
  top: -44px;
  right: 10px;
  background: url(../images/facility/facility_illust01.svg) center / contain no-repeat;
}

.faci_box:last-child h3::before {
  content: "";
  width: 80px;
  height: 80px;
  position: absolute;
  top: -55px;
  right: 5px;
  background: url(../images/facility/facility_illust02.svg) center / contain no-repeat;
}

.faci_box h3::after {
  margin-left: 1em;
  padding: 3px 10px;
  display: inline-block;
  font-family: "SourceHanSans-Regular";
  font-size: 0.7em;
  font-weight: 200;
  border-radius: 50px;
}

.faci_box h3.naka::after {
  content: "#那珂校";
  color: #fff;
  background-color: #24a263;
}

.faci_box h3.hashikabe::after {
  content: "#はしかべ校";
  color: #fff;
  background-color: #0B74D1;
}

.faci_box h3.katsuta::after {
  content: "#勝田駅前校";
  color: #fff;
  background-color: #E88521;
}

.faci_box p {
  font-size: 0.95em;
  line-height: 1.8em;
}

.faci_box.ground img {
  border-top: 4px solid #f74343;
}

.faci_box.haiji img {
  border-top: 4px solid #ffe216;
}

@media print, screen and (min-width: 600px) {
  .faci_area {
    padding-bottom: 6em;
  }
  .faci_area.forest_deco::before, .faci_area.forest_deco::after {
    display: block;
  }
  .faci_inner {
    width: 70%;
  }
  .faci_box:first-child h3::before {
    width: 61px;
    height: 100px;
    top: -67px;
  }
  .faci_box:last-child h3::before {
    width: 95px;
    height: 95px;
    top: -62px;
  }
}

@media print, screen and (min-width: 768px) {
  .faci_inner {
    width: 100%;
    max-width: 1550px;
    margin: 0 auto;
    flex-wrap: nowrap;
    justify-content: center;
  }
  .faci_box {
    width: 40%;
    max-width: 530px;
    margin-top: 0;
    margin-right: 2em;
  }
  .faci_box:last-child {
    margin-right: 0;
  }

}

@media print, screen and (min-width: 1025px) {
  .faci_box {
    width: 35%;
    margin-right: 4em;
  }
  .faci_box h3 {
    margin: 0.8em 0;
    font-size: 1.4em;
  }
  .faci_box p {
    font-size: 1.1em;
  }
  .faci_box_illust {
    width: 25%;
    margin: 0;
  }
  .faci_box:first-child h3::before {
    width: 80px;
    height: 100px;
    top: -58px;
  }
  .faci_box:last-child h3::before {
    width: 100px;
    height: 100px;
    top: -70px;
  }
}

/* ===================================
イベント
=================================== */

.event_area {
	position: relative;
	text-align: center;
	z-index: 9;
  background: url(../images/facility/event_back_sp.png) center / cover no-repeat;
}

.event_area::before {
  content: "";
  width: 110px;
  height: 100px;
  position: absolute;
  top: -60px;
  right: 10%;
  background: url(../images/facility/event_illust.svg) center / contain no-repeat;
}

.event_inner {
  padding: 3em 0 5em;
	overflow: hidden;
}

.event_inner h2 {
	margin-bottom: 2em;
}

.memo_area {
	width: 100%;
	height: 100%;
	padding: 3em 0 1em;
	position: relative;
	background-color: #fff;
	border-top: 2px solid #000;
	border-bottom: 2px solid #000;
	z-index: 99;
	background-image: repeating-linear-gradient( 0deg, #f3f7f7 0px 2px, transparent 1px 50px), repeating-linear-gradient( 90deg, #f3f7f7 0px 2px, transparent 1px 50px);
}

.memo_area::before {
	content: "";
	width: 100%;
	height: 40px;
	position: absolute;
	top: -15px;
	left: 0;
	background-image: url(../images/about/history_memo_top.svg);
	background-size: contain;
	z-index: 999;
}

.memo_area::after {
	content: "";
	width: 100%;
	height: 50px;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	background-color: #00B1D1;
	background-image: none;
	border-bottom: 2px solid #018aa2;
	transform: none;
	z-index: 99;
}

.skyblue {
	display: inline-block;
	margin: 0.8em 0;
	font-family: "GenJyuuGothic-P-Bold";
	font-size: 1.5em;
	font-weight: bold;
	color: #00b1d1;
}

.memo_flex {
	display: flex;
	flex-wrap: wrap;
	position: relative;
}

.memo_box {
	width: 80%;
	margin: 0 auto 1.5em;
	position: relative;
	border-radius: 1.5rem;
	text-align: left;
}

.memo_box:last-child {
	margin-bottom: 0;
}

.month {
	width: 100%;
	height: 50px;
	padding: 7px 0;
	display: inline-block;
	position: relative;
	font-size: 1.2em;
	color: #FFF;
	text-align: center;
	border-radius: 6px;
}

.month.spring {
	background-color: #f9a9bf;
}
.month.summer {
	background-color: #ff965d;
}
.month.winter {
	background-color: #6ec4d4;
}

.month span {
	margin: 0;
    padding: 0 25px 0 15px;
    display: block;
    font-family: "keifont";
    line-height: 1.8em;
    border-top: dashed 1px #FFF;
    border-bottom: dashed 1px #FFF;
}

.month span::after {
	content: "";
	width: 0px;
	height: 0px;
	position: absolute;
	top: 0;
	right: 0;
	border-width: 25px 15px 25px 0px;
	border-color: transparent #fff transparent transparent;
	border-style: solid;
	z-index: 1;
}

.memo_box ul {
	margin-top: 1em;
}

.memo_box ul li {
	position: relative;
	margin-bottom: 0.3em;
	padding-left: 1.3em;
  font-weight: 300;
	text-indent: -1.3em;
}

.memo_box ul li:last-child {
	margin-bottom: 0;
}

.memo_box ul li::before {
	content: "●";
	margin-right: 0.3em;
	font-size: 0.8em;
	color: #ffe31a;
}

@media print, screen and (min-width:500px) {
	.memo_box {
		width: 70%;
	}
}

@media print, screen and (min-width:600px) {
  .event_area {
    background-image: url(../images/facility/event_back_pc.png);
  }
  .event_area::before {
    width: 20%;
    height: 231px;
    top: -165px;
  }
}

@media print, screen and (min-width:768px) {
	.memo_area {
		width: 90%;
		max-width: 900px;
		margin: 0 auto;
		padding-bottom: 3em;
		border: solid;
		border-radius: 15px;
	}
	.memo_flex:last-child {
		margin-top: 2em;
	}
	.memo_area::before {
		width: 615px;
		left: 50%;
		transform: translateX(-50%);
	}
	.memo_area::after {
		border-radius: 12px 12px 0 0;
	}
	.memo_flex {
		justify-content: center;
	}
	.memo_box {
		width: 29%;
		max-width: 220px;
		margin: 0 0.5em 0;
	}
	.no_margin {
		margin-bottom: 0;
	}
}

@media print, screen and (min-width:1025px) {
  .event_inner {
    padding-bottom: 7em;
  }
}

/* ===================================
年間行事 - イラスト・写真
=================================== */

.memo_box:first-child::before {
	content: "";
  width: 100px;
  height: 70px;
  position: absolute;
  bottom: -21px;
  right: 0;
	background: url(../images/facility/event_memo_illust01.svg) center / contain no-repeat;
	z-index: 99;
}

.memo_box:last-child::before {
    content: "";
    width: 120px;
    height: 95px;
    position: absolute;
    bottom: -12px;
    right: 30px;
    background: url(../images/facility/event_memo_illust02.svg) center / contain no-repeat;
    z-index: 99;
}

.memo_photo01, .memo_photo02 {
	width: 75%;
	margin: 0 auto 2em;
	padding: 0.5em;
	position: relative;
  background-color: #fff;
	border: 1px solid #c5c5c5;
	border-radius: 2px;
}

.memo_photo01 img, .memo_photo02 img {
	width: 100%;
	display: block;
	border: 1px solid #f3f3f3;
}

.memo_photo01 {
	margin-top: 2.5em;
	transform: rotate(2deg);
}

.memo_photo01::before {
	content: "";
	width: 105px;
	height: 60px;
	position: absolute;
	top: -15px;
	right: -23px;
	background: url(../images/facility/event_photo01_deco01.svg) center / contain no-repeat;
}

.memo_photo01::after {
	content: "";
	width: 98px;
	height: 60px;
	position: absolute;
	bottom: -14px;
	left: -24px;
	background: url(../images/facility/event_photo01_deco02.svg) center / contain no-repeat;
	transform: rotate(14deg);
}

.memo_photo02 {
	transform: rotate(-2deg);
}

.memo_photo02::before {
	content: "";
	width: 99px;
	height: 60px;
	position: absolute;
	top: -15px;
	left: -27px;
	background: url(../images/facility/event_photo02_deco01.svg) center / contain no-repeat;
}

.memo_photo02::after {
	content: "";
	width: 100px;
	height: 60px;
	position: absolute;
	bottom: -21px;
	right: -24px;
	background: url(../images/facility/event_photo02_deco02.svg) center / contain no-repeat;
}

@media print, screen and (min-width:600px) {
  .memo_flex:last-child {
    flex-wrap: nowrap;
    align-items: center;
  }
  .memo_photo01, .memo_photo02 {
    width: 41%;
  }
}

@media print, screen and (min-width: 768px) {
	.memo_photo01, .memo_photo02 {
		width: 37%;
		margin: 1em 0 0;
	}
	.memo_photo01 {
		margin-right: 3.5em;
		transform: rotate(-1deg);
	}
	.memo_photo02 {
		transform: rotate(2deg);
	}
	.memo_photo02::before {
		left: -24px;
	}
	.memo_box:last-child::before {
		width: 140px;
		height: 110px;
		bottom: -35px;
		right: -64px;
	}
}

/* ===================================
施設の風景ギャラりー - イラスト
=================================== */
.gallery_illust {
  width: 100%;
  position: absolute;
  top: -50px;
  text-align: left;
}

.gallery_illust img {
  display: inline-block;
  position: absolute;
}

.gallery_illust .illust01 {
  width: 42%;
  left: 20px;
}

.gallery_illust .illust02 {
  width: 40%;
  right: 20px;
}

@media print, screen and (min-width: 600px) {
  .gallery_illust .illust01 {
    width: 250px;
    left: 8%;
  }
  .gallery_illust .illust02 {
    width: 250px;
    right: 8%;
  }
}
@media print, screen and (min-width: 1025px) {
  .gallery_illust {
    top: -55px;
  }
  .gallery_illust .illust01 {
    width: 28%;
    max-width: 390px;
    left: 6%;
  }
  .gallery_illust .illust02 {
    width: 25%;
    max-width: 390px;
  }
}

/* ===================================
施設の風景ギャラりー
=================================== */

.gallery {
  padding: 3.5em 0 12em;
  position: relative;
  text-align: center;
  background-color: #fffde7;
  z-index: 99;
}

.gallery .arch::before {
  display: none;
}

.gallery.forest_deco::before {
  z-index: 999;
}

.gallery_cmt {
  font-family: "keifont";
  margin-top: 1em;
  display: block;
}

.gallery_cmt .marker {
  font-size: 1.6em;
  background: linear-gradient(transparent 65%, #fff799 0%);
  border-radius:6px;
  position: relative;
}

.gallery_cmt .marker::before {
  content: "";
  width: 2.7em;
  height: 1.7em;
  position: absolute;
  top: -0.8em;
  left: -3.2em;
  background: url(../images/facility/facility_gallery/title_before.svg) left / contain no-repeat;
}

.gallery_cmt .marker::after {
  content: "";
  width: 2em;
  height: 1.5em;
  position: absolute;
  top: -0.5em;
  right: -3.2em;
  background: url(../images/facility/facility_gallery/title_after.svg) left / contain no-repeat;
}


@media print, screen and (min-width: 1025px) {
  .gallery {
    padding-top: 6em;
  }
  .gallery_cmt .marker {
    font-size: 2.2em;
  }
}

/* ===================================
その他の施設ギャラリー - slider
=================================== */
.overflow {
  width: 100%;
  margin-top: 2em;
  overflow: hidden;
}

.slider {
  display: flex;
}

.slider_inner {
  display: flex;
}

.slider_inner:first-child {
  animation: loop 120s linear infinite;
}

.slider_inner:nth-child(2) {
  animation: loop2 120s -80s linear infinite;
}

.slider_inner:last-child {
  animation: loop3 120s -40s linear infinite;
}

.slider_item {
  width: 250px;
  height: auto;
  position: relative;
  margin-right: 1.5em;
  text-align: left;
}

.slider_item img {
  width: 100%;
  border-radius: 10px;
}

/* ピン */
.slider_item::before {
  content: "";
  width: 33px;
  height: 33px;
  position: absolute;
  top: -10px;
  left: 54%;
  transform: translateX(-50%);
}

.slider_item:first-child::before, .slider_item:nth-child(4)::before, .slider_item:nth-child(7)::before, .slider_item:nth-child(10)::before, .slider_item:nth-child(11)::before, .slider_item:nth-child(14)::before {
  background: url(../images/facility/facility_gallery/pin_blue.svg) center / contain no-repeat;
}

.slider_item:nth-child(2)::before, .slider_item:nth-child(5)::before, .slider_item:nth-child(8)::before, .slider_item:nth-child(11)::before, .slider_item:nth-child(12)::before {
  background: url(../images/facility/facility_gallery/pin_red.svg) center / contain no-repeat;
}

.slider_item:nth-child(3)::before, .slider_item:nth-child(6)::before, .slider_item:nth-child(9)::before, .slider_item:nth-child(12)::before, .slider_item:nth-child(13)::before {
  background: url(../images/facility/facility_gallery/pin_yellow.svg) center / contain no-repeat;
}

/* タグ */
.slider_item span {
  margin: 1em 0.5em 0.5em 0;
  padding: 3px 10px;
  display: inline-block;
  position: absolute;
  bottom: 10px;
  left: 10px;
  font-size: 0.9em;
  color: #fff;
  border-radius: 50px;
}

.slider_item span.naka {
  background-color: #24a263;
}

.slider_item span.hashikabe {
  background-color: #0B74D1;
}

.slider_item span.katsuta {
  background-color: #ff8d1a;
}

.slider_item span.haiji {
  background-color: #f74343;
}

.slider_item span.ground {
  background-color: #4cd031;
}

.gallery .link {
  color: #000;
  background-color: #fff;
  border: 2px solid #000;
  box-shadow: 0px 7px 0 #fff799
}

.gallery .link span::before {
  border-left-color: #FFCC23;
}

@keyframes loop {
  0% {
    transform: translateX(200%);
  }
  to {
    transform: translateX(-100%);
  }
}

@keyframes loop2 {
  0% {
    transform: translateX(100%);
  }
  to {
    transform: translateX(-200%);
  }
}

@keyframes loop3 {
  0% {
    transform: translateX(0%);
  }
  to {
    transform: translateX(-300%);
  }
}

@media print, screen and (min-width: 1025px) {
  .slider_inner {
    padding: 1em 0;
    align-items: flex-start;
  }
  .slider_item {
    width: 300px;
    margin-right: 2.5em;
  }

  .slider_item:nth-child(odd) {
    margin-top: 2em;
  }
}