@charset "UTF-8";

/* 共通設定 */
.ttl_sub {
	width:100%;
	display:flex;
	flex-wrap:wrap;
	align-items: center;
	justify-content: center;
	padding-top:20%;
	position:relative;
}

.ttl_sub.sub01 {background:url("../images/bg_sub_ttl.jpg") no-repeat center center;background-size:cover;}
.ttl_sub.sub02 {background:url("../images/bg_sub_ttl2.jpg") no-repeat center center;background-size:cover;color:#FFF;}
.ttl_sub.sub03 {background:url("../images/bg_sub_ttl3.jpg") no-repeat center center;background-size:cover;}
.ttl_sub.sub04 {background:url("../images/bg_sub_ttl4.jpg") no-repeat center center;background-size:cover;color:#FFF;}
.ttl_sub.sub05 {background:url("../images/bg_sub_ttl5.jpg") no-repeat center center;background-size:cover;color:#FFF;}
.ttl_sub.sub06 {background:url("../images/bg_sub_ttl6.jpg") no-repeat center center;background-size:cover;}
.ttl_sub.sub07 {background:url("../images/bg_sub_ttl7.jpg") no-repeat center center;background-size:cover;}

.ttl_sub h2 {
	font-size:3rem;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
	line-height:1.4;
	position:absolute;
	top:50%;
	left:50%;
	transform:translateX(-50%) translateY(-50%);
}

@media all and (max-width:768px) {
.ttl_sub {
	width:100%;
	display:flex;
	flex-wrap:wrap;
	align-items: center;
	justify-content: center;
	padding-top:50%;
	position:relative;
	white-space: nowrap;
}
	
.ttl_sub h2 {
	font-size:2.4rem;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
	line-height:1.4;
}	
}

.ttl_h3 {
	font-size:3rem;
	font-weight:600;
	font-family: "Zen Maru Gothic", sans-serif;
	margin:0 0 50px;
}

@media all and (max-width:768px) {
.ttl_h3 {
	font-size:2.4rem;
	font-weight:600;
	font-family: "Zen Maru Gothic", sans-serif;
	margin:0 0 30px;
}
}

.ttl_h4 {
	font-size:2.6rem;
	font-weight:600;
	font-family: "Zen Maru Gothic", sans-serif;
	margin:0 0 50px;
}

@media all and (max-width:768px) {
.ttl_h4 {
	font-size:2.1rem;
	font-weight:600;
	font-family: "Zen Maru Gothic", sans-serif;
	margin:0 0 30px;
}
}

.ttl_h5 {
	font-size:2.3rem;
	font-weight:600;
	font-family: "Zen Maru Gothic", sans-serif;
	margin:0 0 20px;
}

@media all and (max-width:768px) {
.ttl_h5 {
	font-size:2rem;
	font-weight:600;
	font-family: "Zen Maru Gothic", sans-serif;
	margin:0 0 10px;
}
}

.ttl_h3-2 {
	text-align:center;
	margin:0 auto 50px;
}

.ttl_h3-2 h3 {
	font-size:3rem;
	font-weight:600;
	font-family: "Zen Maru Gothic", sans-serif;
	padding:0 0 25px;
	position:relative;
}

.ttl_h3-2 h3.green {color:#80c269;}
.ttl_h3-2 h3.pink {color:#eb6877;}
.ttl_h3-2 h3.skyBlue {color:deepskyblue;}
.ttl_h3-2 h3.forestGreen {color:forestgreen;}

.ttl_h3-2 h3::before {
	content:attr(data-ttl);
	font-size:1.8rem;
	display:inline-block;
	position:absolute;
	bottom:0;
	left:50%;
	transform:translateX(-50%);
	color:#000;
}

.ttl_h3-3 {
	text-align:center;
	margin:0 auto 50px;
}

.ttl_h3-3 h3 {
	font-size:3rem;
	font-weight:600;
	font-family: "Zen Maru Gothic", sans-serif;
	padding:65px 0 25px;
	position:relative;
}

.ttl_h3-3 h3.bluegreen {color:#41c0bb;}
.ttl_h3-3 h3.gold {color:#dbbe45;}
.ttl_h3-3 h3.skyBlue {color:#3dd5ec;}
.ttl_h3-3 h3.pink {color:#e07975;}

.ttl_h3-3 h3::before {
	content:attr(data-ttl);
	font-size:1.8rem;
	display:inline-block;
	position:absolute;
	bottom:0;
	left:50%;
	transform:translateX(-50%);
	color:#000;
}

.ttl_h3-3 h3::after {
	content:"";
	display:block;
	width:60px;
	height:60px;
	position:absolute;
	top:0;
	left:50%;
	transform:translateX(-50%);
	background-size:cover;
	border-radius: 50%;
	overflow: hidden;
}

.ttl_h3-3 h3.bluegreen::after { background:#41c0bb url("../images/icon_school01.svg") no-repeat center center;}
.ttl_h3-3 h3.gold::after { background:#dbbe45 url("../images/icon_school02.svg") no-repeat center center;}
.ttl_h3-3 h3.skyBlue::after { background:#3dd5ec url("../images/icon_school03.svg") no-repeat center center;}
.ttl_h3-3 h3.pink::after { background:#e07975 url("../images/icon_school04.svg") no-repeat center center;}

.ttl_h5_ribbon {
	display: inline-block;
	position: relative;
	height: 60px;
	line-height: 60px;
	text-align: center;
	padding: 0 80px 0 20px;
	font-size: 1.8rem;
	background: #ffc668;
	color: #FFF;
	box-sizing: border-box;
	margin:0 0 20px;
}

.ttl_h5_ribbon:after {
	position: absolute;
	content: '';
	width: 0px;
	height: 0px;
	z-index: 1;
}

.ttl_h5_ribbon:after {
	top: 0;
	right: 0;
	border-width: 30px 15px 30px 0px;
	border-color: transparent #fff transparent transparent;
	border-style: solid;
}



.block_breadcrumb {
	width:96%;
	max-width:1400px;
	margin:0 auto;
	padding:20px 0;
	font-size:1.3rem;
}

.block_breadcrumb ul li {
	display:inline-block;
	padding:0 30px 0 0;
	position:relative;
}

.block_breadcrumb ul li::after {
	content:"";
	display:block;
	width:7px;
	height:7px;
	border-top:1px solid #AAA;
	border-right:1px solid #AAA;
	position:absolute;
	top:50%;
	right:10px;
	transform:rotate(45deg) translateY(-50%);
}

.block_breadcrumb ul li:last-child::after {
	display:none;
}

.container {
	width:96%;
	max-width:1400px;
	margin:0 auto;
	padding:70px 0;
}

.container_w1000 {
	width:96%;
	max-width:1000px;
	margin:0 auto;
	padding:70px 0;
}

.full_w_container {
	width:100%;
	margin:0 auto;
	padding:70px 0;
}

.full_w_coloredContainer {
	width:100%;
	margin:0 auto;
	background:#f6f1e2;
	padding:70px 0;
}

.full_w_coloredContainer2 {
	width:100%;
	margin:0 auto;
	background:#fcfef6;
	padding:70px 0;
}

.full_w_coloredContainer3 {
	width:100%;
	margin:0 auto;
	background:#f5fcfe;
	padding:70px 0;
}

.full_w_coloredContainer4 {
	width:100%;
	margin:0 auto;
	background:#fdf5f5;
	padding:70px 0;
}

.full_w_container .container,
.full_w_coloredContainer .container,
.full_w_coloredContainer2 .container,
.full_w_coloredContainer3 .container,
.full_w_coloredContainer4 .container {
	width:96%;
	max-width:1400px;
	margin:0 auto;
	padding:0;
}

.full_w_container .container_w1000,
.full_w_coloredContainer .container_w1000,
.full_w_coloredContainer2 .container_w1000,
.full_w_coloredContainer3 .container_w1000,
.full_w_coloredContainer4 .container_w1000 {
	width:96%;
	max-width:1000px;
	margin:0 auto;
	padding:0;
}

@media all and (max-width:648px) {
.container {
	width:96%;
	max-width:1400px;
	margin:0 auto;
	padding:30px 0 70px;
}
	
.container_w1000 {
	width:96%;
	max-width:1000px;
	margin:0 auto;
	padding:30px 0 70px;
}

.full_w_container {
	width:100%;
	margin:0 auto;
	padding:30px 0 70px;
}

.full_w_coloredContainer {
	width:100%;
	margin:0 auto;
	padding:30px 0 70px;
	background:#f6f1e2;
}
	
.full_w_coloredContainer2 {
	width:100%;
	margin:0 auto;
	background:#fcfef6;
	padding:30px 0 70px;
}

.full_w_coloredContainer3 {
	width:100%;
	margin:0 auto;
	background:#f5fcfe;
	padding:30px 0 70px;
}

.full_w_coloredContainer4 {
	width:100%;
	margin:0 auto;
	background:#fdf5f5;
	padding:30px 0 70px;
}
}

.btn_detail {
	display:inline-block;
	width:300px;
	border:1px solid #8ac676;
	color:#8ac676;
	text-align:center;
	font-size:1.8rem;
	padding:1.2em;
	position:relative;
	background:#FFF;
	transition:all .3s linear;
}

.btn_detail:hover {
	box-shadow: 0px 5px 10px rgba(0,0,0,.05);
}

.btn_detail::after {
	content:"";
	display:block;
	width:10px;
	height:10px;
	border-top:1px solid #8ac676;
	border-right:1px solid #8ac676;
	position:absolute;
	right:30px;
	top:50%;
	transition:all .3s linear;
	transform:rotate(45deg) translateY(-50%);
}

.btn_detail:hover::after {
	right:20px;
}

.btn_detail2 {
	display:inline-block;
	width:300px;
	border:1px solid deepskyblue;
	color:deepskyblue;
	text-align:center;
	font-size:1.8rem;
	padding:1.2em;
	position:relative;
	background:#FFF;
	transition:all .3s linear;
}

.btn_detail2:hover {
	box-shadow: 0px 5px 10px rgba(0,0,0,.05);
}

.btn_detail2::after {
	content:"";
	display:block;
	width:10px;
	height:10px;
	border-top:1px solid deepskyblue;
	border-right:1px solid deepskyblue;
	position:absolute;
	right:30px;
	top:50%;
	transition:all .3s linear;
	transform:rotate(45deg) translateY(-50%);
}

.btn_detail2:hover::after {
	right:20px;
}

.btn_detail3 {
	display:inline-block;
	width:300px;
	border:1px solid #41c0bb;
	color:#41c0bb;
	text-align:center;
	font-size:1.8rem;
	padding:1.2em;
	position:relative;
	background:#FFF;
	transition:all .3s linear;
}

.btn_detail3:hover {
	box-shadow: 0px 5px 10px rgba(0,0,0,.05);
}

.btn_detail3::after {
	content:"";
	display:block;
	width:10px;
	height:10px;
	border-top:1px solid #41c0bb;
	border-right:1px solid #41c0bb;
	position:absolute;
	right:30px;
	top:50%;
	transition:all .3s linear;
	transform:rotate(45deg) translateY(-50%);
}

.btn_detail3:hover::after {
	right:20px;
}

.btn_detail4 {
	display:inline-block;
	width:300px;
	border:1px solid #dbbe45;
	color:#dbbe45;
	text-align:center;
	font-size:1.8rem;
	padding:1.2em;
	position:relative;
	background:#FFF;
	transition:all .3s linear;
}

.btn_detail4:hover {
	box-shadow: 0px 5px 10px rgba(0,0,0,.05);
}

.btn_detail4::after {
	content:"";
	display:block;
	width:10px;
	height:10px;
	border-top:1px solid #dbbe45;
	border-right:1px solid #dbbe45;
	position:absolute;
	right:30px;
	top:50%;
	transition:all .3s linear;
	transform:rotate(45deg) translateY(-50%);
}

.btn_detail4:hover::after {
	right:20px;
}


/* ヤマハ音楽教室 */
.list_action {
	width:100%;
	max-width:500px;
	margin:0 auto 30px;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}

.list_action li {
	display:inline-block;
	font-size:2.1rem;
	padding:.3em 1em;
	border-radius: 20px;
	color:#FFF;
	background:#41c0bb;
	position:relative;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
}

.list_action li:nth-child(2) {background:#dbbe45;}
.list_action li:nth-child(3) {background:#e07975;}
.list_action li:nth-child(4) {background:#3dd5ec;}

.list_action li::after {
	font-family: 'Material Symbols Outlined';
	content:"\e5c8";
	color:#000;
	font-size:2.4rem;
	font-weight:600;
	position:absolute;
	top:50%;
	right:-30px;
	transform: translateY(-50%);
}

.list_action li:last-child::after {
	display:none;
}

@media all and (max-width:560px) {
.list_action {
	width:100%;
	max-width:350px;
	margin:0 auto 30px;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}
	
.list_action li {
	display:inline-block;
	font-size:1.6rem;
	padding:.3em .8em;
	border-radius: 20px;
	color:#FFF;
	background:#41c0bb;
	position:relative;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
}
	
.list_action li::after {
	font-family: 'Material Symbols Outlined';
	content:"\e5c8";
	color:#000;
	font-size:2.4rem;
	font-weight:600;
	position:absolute;
	top:50%;
	right:-25px;
	transform: translateY(-50%);
}

.list_action li:last-child::after {
	display:none;
}
}

.course_name {
	display:block;
	width:min(350px, 100%);
	height:auto;
	margin:0 auto;
	font-size:3.6rem;
	font-weight:900;
}

.course_name img {
	width:100%;
}

.course_img img {
	width:100%;
}

.block_course {
	width:100%;
	background:#FFF;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	border-radius: 20px;
	overflow: hidden;
}

.course_ttl {
	font-size:2.1rem;
	padding:.5em;
	text-align:center;
	color:#FFF;
	font-weight:600;
}

.list_course {
	width:100%;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
	padding:15px 15px 15px 25px;
	background:#f7f7f7;
}

.list_course li {
	width:48%;
	margin:0 0 15px;
	background:#FFF;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
}

@media all and (max-width:648px) {
.list_course {
	width:100%;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
	padding:10px 10px 10px 25px;
	background:#f7f7f7;
}
	
.list_course li {
	width:100%;
	margin:0 0 15px;
	background:#FFF;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
}	
}

.course_body {
	position:relative;
	width:100%;
	padding:10px 25px 25px 0;
}

.ttl_ribbon {
  display: inline-block;
  position: relative;
  box-sizing: border-box;
  padding: 5px 0;
  margin: 0 0 0 -20px;
  width: calc(100% + 20px);
  color: white;
  background: #70a6ff;
}

.ttl_ribbon h6 {
	margin: 0;
	padding: 0 30px 0 15px;
	border-top: dashed 1px #FFF;
	border-bottom: dashed 1px #FFF;
	font-size: 1.8rem;
	line-height: 42px;
	font-weight:600;
}

.ttl_ribbon h6 span {
	display:inline;
	font-size:1.3rem;
	color:#000;
	background:yellow;
	padding:.2em .5em;
}

.ttl_ribbon:after {
  position: absolute;
  content: '';
  z-index: 1;
  top: 0;
  right: 0;
  width: 0px;
  height: 0px;
  border-width: 30px 15px 30px 0px;
  border-color: transparent #FFF transparent transparent;
  border-style: solid;
}

.ttl_ribbon:before {
  position: absolute;
  content: '';
  top: 100%;
  left: 0;
  border: none;
  border-bottom: solid 15px transparent;
  border-right: solid 20px #6081b7;
}

.course_content {
	padding:10px 0 0 25px;
	text-align:center;
}

.course_summary {
	height:6em;
	font-size:1.6rem;
}

.course_summary2 {
	height:9em;
	font-size:1.6rem;
}

@media all and (max-width:648px) {
.course_body {
	position:relative;
	width:100%;
	padding:10px 15px 15px 0;
}
	
.course_content {
	padding:10px 0 0 15px;
	text-align:center;
}
}

.course_detail {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    padding: .9em 2em;
    border: none;
    border-radius: 5px;
    background-color: #2589d0;
    color: #fff;
    font-weight: 600;
    font-size: 1.6rem;
}

.course_detail:hover {
    background-color: #1579c0;
}

.list_class {
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}

.list_class li {
	width:32%;
	margin:0 0 10px;
}

.list_class li a {
	display:block;
	width:100%;
	background:#FFF;
	padding:20px 20px 20px 50px;
	border-radius: 20px;
	box-shadow: 0px 5px 10px rgba(0,0,0,.05);
	font-size:1.6rem;
	color:#000;
	position:relative;
}

.list_class li a::before {
	font-family: 'Material Symbols Outlined';
	content:"\e5cc";
	display:block;
	text-align:center;
	font-size:18px;
	width:19px;
	height:19px;
	color:#FFF;
	background:orange;
	border-radius: 50%;
	position:absolute;
	top:50%;
	left:20px;
	transform:translateY(-50%);
	line-height:1.1;
}

@media all and (max-width:648px) {
.list_class li {
	width:100%;
	margin:0 0 10px;
}
}

.list_course_js {
	width:100%;
	overflow: hidden;
}

.list_course_js li {
	width:32%;
	margin:0 2% 20px 0;
	border-radius: 20px;
	overflow:hidden;
	background:#FFF;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	float:left;
}

.list_course_js li:nth-child(3n) {
	width:32%;
	margin:0 0 20px;
	border-radius: 20px;
	overflow:hidden;
	background:#FFF;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	float:left;
}

.list_course_js li a {
	display:flex;
	flex-wrap:wrap;
	align-items: center;
	justify-content: center;
	color:#000;
	padding:30px 50px 150px;
	overflow:hidden;
	text-align:center;
	position:relative;
}

.list_course_js li:first-child a {
	background:url("../images/img_junior01.jpg") no-repeat bottom center;
	background-size:cover;
}

.list_course_js li:nth-child(2) a {
	background:url("../images/img_junior02.jpg") no-repeat bottom center;
	background-size:cover;
}

.list_course_js li:nth-child(3) a {
	background:url("../images/img_junior03.jpg") no-repeat bottom center;
	background-size:cover;
}

.list_course_js li:nth-child(4) a {
	background:url("../images/img_junior04.jpg") no-repeat bottom center;
	background-size:cover;
}

.list_course_js li:nth-child(5) a {
	background:url("../images/img_junior05.jpg") no-repeat bottom center;
	background-size:cover;
}

@media all and (max-width:768px) {
.list_course_js li {
	width:48%;
	margin:0 4% 20px 0;
	border-radius: 20px;
	overflow:hidden;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	float:left;
}

.list_course_js li:nth-child(3n) {
	width:48%;
	margin:0 4% 20px 0;
	border-radius: 20px;
	overflow:hidden;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	float:left;
}
	
.list_course_js li:nth-child(even) {
	width:48%;
	margin:0 0 20px !important;
	border-radius: 20px;
	overflow:hidden;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	float:left;
}
	
.list_course_js li a {
	display:flex;
	flex-wrap:wrap;
	align-items: center;
	justify-content: center;
	color:#000;
	background:#FFF;
	padding:30px 70px 150px;
	overflow:hidden;
	text-align:center;
	position:relative;
}
}

@media all and (max-width:648px) {
.list_course_js li {
	width:100%;
	margin:0 0 20px;
	border-radius: 20px;
	overflow:hidden;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	float:left;
}

.list_course_js li:nth-child(3n) {
	width:100%;
	margin:0 0 20px;
	border-radius: 20px;
	overflow:hidden;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	float:left;
}
	
.list_course_js li:nth-child(even) {
	width:100%;
	margin:0 0 20px !important;
	border-radius: 20px;
	overflow:hidden;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	float:left;
}
	
.list_course_js li a {
	display:flex;
	flex-wrap:wrap;
	align-items: center;
	justify-content: center;
	color:#000;
	background:#FFF;
	padding:30px 70px 150px;
	overflow:hidden;
	text-align:center;
	position:relative;
}
}

h6.js_course_name {
	display:block;
	font-size:3rem;
	font-weight:900;
	color:steelblue;
	line-height:1.2;
}

h6.js_course_name span {
	display:block !important;
	font-size:1.8rem;
	font-weight:600;
	color:#000;
}

.list_course_js li a p {
	display:block !important;
	text-align:center;
	font-size:1.6rem;
}

.ttl_prejunior {
	width:66%;
	max-width:420px;
	margin:0 auto;
}

.ttl_prejunior img {
	width:100%;
}

.list_program {
	width:100%;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
	padding:30px 30px 15px;
}

.list_program li {
	width:18%;
	margin:0 0 15px;
}

@media all and (max-width:648px) {
.ttl_prejunior {
	width:100%;
	max-width:320px;
	margin:0 auto;
}
	
.list_program li {
	width:48%;
}
}

.img_program {
	width:100%;
	overflow: hidden;
	border-radius: 50%;
	aspect-ratio: 1 / 1;
	margin:0 0 10px;
}

.img_program img {
	width:100%;
}


/* 楽器を探す */
.list_instrument {
	width:100%;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}

.list_instrument li {
	width:32%;
}

@media all and (max-width:648px) {
.list_instrument li {
	width:48%;
}
}

/* 練習室レンタル */
.list_studio {
	width:100%;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}

.list_studio li {
	width:32%;
	background:#FFF;
	border-radius: 20px;
	padding:30px 30px 50px;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	margin:0;
}

@media all and (max-width:648px) {
.list_studio li {
	width:100%;
	background:#FFF;
	border-radius: 20px;
	padding:20px 20px 50px;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	margin:0 0 15px;
}
	
.list_studio li:last-child {
	width:100%;
	background:#FFF;
	border-radius: 20px;
	padding:20px 20px 50px;
	box-shadow:0px 5px 10px rgba(0,0,0,.05);
	margin:0;
}
}

.bubble {
	display:inline-block;
	font-size:1.4rem;
	font-weight:600;
	padding:.5em 1em;
	color:#FFF;
	border-radius: 25px;
	background:#80c269;
	margin:0 0 10px;
	position:relative;
}

.bubble::after {
	content:"";
	display:block;
	width:0px;
	height:0px;
	border-top:9px solid #80c269;
	border-left:7px solid transparent;
	border-right:7px solid transparent;
	position:absolute;
	bottom:-7px;
	left:20px;
}

/* 修理・調律 */
/* いちごSHOP */
.list_kodawari {
	width:100%;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
	align-items: center;
	margin:0 0 30px;
	counter-reset: number 0;
}

.list_kodawari > li {
	width:23%;
	aspect-ratio: 1 / 1;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	text-align:center;
	font-size:1.8rem;
	padding:40px 10px 10px;
	color:#FFF;
	background:#41c0bb;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
	position:relative;
}

.list_kodawari > li::before {
	font-size:4.8rem;
	counter-increment: number;
	content:"0" counter(number);
	position:absolute;
	top:10px;
	left:50%;
	transform:translateX(-50%);
}

@media all and (max-width:648px) {
.list_kodawari > li {
	width:48%;
	aspect-ratio: 1 / 1;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	text-align:center;
	font-size:1.6rem;
	padding:40px 10px 10px;
	margin:0 0 10px;
	color:#FFF;
	background:#41c0bb;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
}	
}

.list_kodawari > li:nth-child(2){background:#dbbe45;}
.list_kodawari > li:nth-child(3){background:#e07975;}
.list_kodawari > li:nth-child(4){background:#80c269;}

.list_people {
	width:100%;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
	align-items: left;
	margin:0 0 30px;
}

.list_people > li {
	width:49%;
	display: flex;
	align-items: center;
	justify-content: left;
	border-radius: 20px;
	background:#FFF;
	text-align:left;
	font-size:1.6rem;
	padding:20px 20px 20px 60px;
	font-weight:500;
	color:#e07975;
	border:1px solid #e07975;
	margin:0 0 15px;
	position:relative;
}

.list_people > li::before {
	font-family: 'Material Symbols Outlined';
	content:"\e5ca";
	display:block;
	text-align:center;
	font-size:2.1rem;
	width:30px;
	height:30px;
	color:#FFF;
	background:#e07975;
	position: absolute;
	left:15px;
	top:50%;
	transform:translateY(-50%);
	border-radius: 50%;
	line-height:1.5;
}

.btn_contact_line {
	display:flex;
	width:300px;
	height:70px;
	flex-wrap:wrap;
	align-items: center;
	justify-content: center;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
	color:#FFF;
	background:#06c755;
	line-height:1.2;
	font-size:1.8rem;
	border-radius: 20px;
	margin:0 auto;
}

.btn_contact_line {
	text-align:left;
	color:#FFF;
}

.btn_contact_line::before {
	content:"";
	display:inline-block;
	width:35px;
	height:35px;
	border-radius: 50%;
	background:url("../images/line.svg") no-repeat center center;
	background-size:contain;
	margin:0 10px 0 0;
}


/* オリジナルレッスン */
.list_osusume, .list_osusume2, .list_osusume3 {
	font-size:1.6rem;
}

.list_osusume li, .list_osusume2 li, .list_osusume3 li {
	padding:8px 0 8px 30px;
	position:relative;
}

.list_osusume li::before {
	font-family: 'Material Symbols Outlined';
	content:"\e5cc";
	display:block;
	text-align:center;
	font-size:18px;
	width:19px;
	height:19px;
	color:deepskyblue;
	border:1px solid deepskyblue;
	border-radius: 50%;
	position:absolute;
	top:13px;
	left:0;
	line-height:1.1;
}

.list_osusume2 li::before {
	font-family: 'Material Symbols Outlined';
	content:"\e5cc";
	display:block;
	text-align:center;
	font-size:18px;
	width:19px;
	height:19px;
	color:forestgreen;
	border:1px solid forestgreen;
	border-radius: 50%;
	position:absolute;
	top:13px;
	left:0;
	line-height:1.1;
}

.list_osusume3 li::before {
	font-family: 'Material Symbols Outlined';
	content:"\e5cc";
	display:block;
	text-align:center;
	font-size:18px;
	width:19px;
	height:19px;
	color:crimson;
	border:1px solid crimson;
	border-radius: 50%;
	position:absolute;
	top:13px;
	left:0;
	line-height:1.1;
}

/* 教室一覧 */
.list_school {
	width:100%;
	overflow:hidden;
}

.list_school li {
	width:49%;
	margin:0 2% 15px 0;
	float:left;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}

.list_school li:nth-child(even) {
	width:49%;
	margin:0 0 15px;
	float:left;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}

@media all and (max-width:648px) {
.list_school li {
	width:100%;
	margin:0 0 15px;
	float:left;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}

.list_school li:nth-child(even) {
	width:100%;
	margin:0 0 15px;
	float:left;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}	
}

.school_photo {
	width:45%;
}

.school_photo img {
	width:100%;
}

.school_info {
	width:53%;
	font-size:1.6rem;
	line-height:1.8em;
}

.school_info a {
	display:inline-block;
	padding:3px 15px;
	nbackground:#FFF;
	border:1px solid orange;
	color:orange;
	font-size:1.4rem;
	line-height:1.4;
}


 /* お知らせ */
.list_category {
	width:100%;
	border-top:1px solid #CCC;
	font-size:1.6rem;
}

.list_category li {
	border-bottom:1px solid #CCC;
}

.list_category li a {
	display:block;
	padding:1em 50px 1em 1em;
	color:#000;
	position:relative;
	transition:all .3s linear;
}

@media all and (max-width:1024px) {
.list_category li a {
	display:block;
	padding:.7em 50px .7em .7em;
	color:#000;
	position:relative;
	transition:all .3s linear;
}	
}

.list_category li a::after {
	content:"";
	display:block;
	width:9px;
	height:9px;
	border-top:1px solid #999;
	border-right:1px solid #999;
	position:absolute;
	top:50%;
	right:20px;
	transform:rotate(45deg) translateY(-50%);
	transition:all .3s linear;
}

.list_category li a:hover {
	font-weight:600;
}

.list_category li a:hover::after {
	right:15px;
}

.list_article {
	width:100%;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}

.list_article > li {
	width:48%;
	background:#FFF;
	border-radius: 5px;
	box-shadow:0px 5px 10px rgba(0,0,0, .1);
	overflow:hidden;
	margin:0 0 30px;
}

.list_article > li a {
	display:block;
	width:100%;
	padding:20px;
	background:#f8f9f9;
	color:#000;
}

@media all and (max-width:768px) {
.list_article > li a {
	display:block;
	width:100%;
	padding:10px;
	background:#f8f9f9;
	color:#000;
}
}

@media all and (max-width:648px) {
.list_article > li {
	width:100%;
	background:#FFF;
	border-radius: 5px;
	box-shadow:0px 5px 10px rgba(0,0,0, .1);
	overflow:hidden;
	margin:0 0 30px;
}	
}

.info_article {
	width:100%;
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
	margin:0 0 10px;
	font-size:1.4rem;
}

.postedDate {
	width:8em;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
}

.icon_category {
	width:calc(100% - 10em);
}

.icon_category ul {
	width:100%;
	display:inline-block;
	text-align:right;
}

.icon_category ul li {
	display:inline-block;
	font-size:1.2rem;
	margin: 1px;
	padding:.3em .5em;
	border:1px solid orange;
	color:orange;
	text-align:center;
	background:#FFF;
}

.ttl_article {
	font-size:1.6rem;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
}

.img_thumb {
width:100%;
position:relative;
margin:0 0 10px;
background-color:#DDD;
background-image: url(../images/icatch.jpg);
background-repeat: no-repeat;
background-size: cover;
}

.img_thumb::before {
    padding-top:75%;
    content:"";
    display:block;
}


.img_thumb img {
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
    object-fit:contain;
}

.pagination-container {
  display: flex;
  justify-content: center;
  margin: 40px 0;
}

.pagination {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 8px;
  align-items: center;
}

.page-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 10px;
  text-decoration: none;
  font-weight: bold;
  font-size: 14px;
  box-sizing: border-box;
  border-radius: 5px;
  background-color: #fff;
  color: #000;
  border: 1px solid #000;
  transition: all 0.3s ease;
}

.page-link:hover {
  background-color: orange;
  border-color: orange;
  color: #fff;
}

.page-link.is-active {
  background-color: orange;
  border-color: orange;
  color: #fff;
  cursor: default;
}

.page-link.prev,
.page-link.next {
  font-size: 12px;
  letter-spacing: 0.05em;
}

.page-ellipsis {
  color: #000;
  font-weight: bold;
  padding: 0 5px;
}

.ttl_article_detail {
	font-size:2.3rem;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
	padding:0 0 15px;
	border-bottom:1px solid #CCC;
	margin:0 0 15px;
}

.article_body {
	font-size:1.6rem;
}

.article_body h1 {
	font-size:2.3rem;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
	padding:0 0 10px;
	border-bottom:3px solid skyblue;
	margin:0 0 15px;
	position: relative;
}

.article_body h1::after {
	position:absolute;
	content:"";
	display:block;
	border-bottom: solid 3px limegreen;
	bottom:-3px;
	width: 30%;
}

.article_body h2 {
	font-size:2.1rem;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
	padding:0 0 10px;
	border-bottom:1px solid #AAA;
	margin:0 0 15px;
}

.article_body h3 {
	font-size:1.9rem;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
	padding:0 0 10px;
	border-bottom:1px dashed #AAA;
	margin:0 0 15px;
}

.article_body h4 {
	font-size:1.8rem;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
	padding:.7em .5em;
	margin:0 0 15px;
	background: -webkit-repeating-linear-gradient(-45deg, #cce7ff, #cce7ff 3px, #e9f4ff 3px, #e9f4ff 7px);
	background: repeating-linear-gradient(-45deg, #cce7ff, #cce7ff 3px, #e9f4ff 3px, #e9f4ff 7px);
}

.article_body h5 {
	font-size:1.8rem;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
	margin:0 0 15px;
}

.article_body h6 {
	font-size:1.6rem;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight:600;
	margin:0 0 15px;
}

.article_body img {
	display: block;
    width: 100%;
    max-width: 100%;
    width: auto;
    height: auto;
    margin:2em auto;
    vertical-align: bottom;
}

.article_body p {
	font-size:1.6rem;
}

.article_body a {
	color:orange;
	border-bottom:1px dashed orange;
}

.article_body ul {
	list-style-type: disc;
    padding: 1em;
}

.article_body ul li {
    padding: .3em .3em .3em 2em;
	position:relative;
}

.article_body ul li::before {
	content:"";
	display:block;
	width:13px;
	height:13px;
	border-radius: 50%;
    background: forestgreen;
    position:absolute;
	top:12px;
	left:10px;
}

.article_body ol {
	list-style-type: none;
    padding: 1em;
    counter-reset: li;
}

.article_body ol li {
    display: flex;
    align-items: center;
    padding: .3em;
}

.article_body ol li::before {
    display: inline-block;
    min-width: 1.7em;
    margin-right: 5px;
    border-radius: 50%;
    background-color:forestgreen;
    color: #fff;
    font-weight: bold;
    font-size: .75em;
    line-height: 1.7em;
    text-align: center;
    content: counter(li);
    counter-increment: li;
}

.post-navigation {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
  width: 100%;
  max-width: 800px;
  margin: 50px auto;
  padding: 0 10px;
}

.nav-link {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
  height: 50px;
  text-decoration: none;
  font-weight: bold;
  font-size: 14px;
  border-radius: 5px;
  transition: all 0.3s ease;
  background-color: skyblue;
  color: #fff;
  border: 1px solid skyblue;
}

.nav-link.list {
  background-color: orange;
  border-color: orange;
}

.nav-link:hover {
  background-color: #fff;
  color: deepskyblue;
  border-color: deepskyblue;
}

.nav-link.list:hover {
  background-color: #fff;
  color: orange;
  border-color: orange;
}

.material-symbols-outlined {
  font-size: 20px;
}

.nav-text {
  margin: 0 5px;
}

@media (max-width: 480px) {
  .post-navigation {
    gap: 10px;
  }
  
  .nav-text {
    font-size: 11px;
  }
  
  .nav-link {
    height: 45px;
    padding: 0 5px;
  }
}