@charset "UTF-8";
/*
Theme Name:ystandard child
Template:ystandard
Author:PLUS N
Version:1
*/

@media (min-width:1025px){}
@media (max-width:1024px){}
@media (max-width:599px){}


/* 本文 */
body,
button,
input,
select,
textarea {
  font-family: "Noto Sans JP", sans-serif;
}

/* 見出し */
h1, h2, h3, h4, h5, h6,
.entry-title,
.singular-header__title {
  font-family: "Noto Sans JP", sans-serif;
	font-weight:800;
}

.sp-only{display:none;}
.PcCenterSpLeft{text-align: center;}
@media(max-width:599px){
.pc-only{display:none;}	
.sp-only{display:inline;}
.PcCenterSpLeft{text-align: left;}
}


.clearfix::after {
   content: "";
   display: block;
   clear: both;
}


.text_mini{
	font-size: 0.85em;
	line-height: 1.5;
}

a:hover img{
    opacity: 0.5;
}

.green{color: #79b943;}
.orange{color: #eaa646;}
.blue{color: #6fb3de;}

hr {
  border: 0;
  height: 1px;
  margin: 1px 0;
padding: 50px 0;
  display: flex;
  align-items: center;
  justify-content: center;
	  }
hr::before {
    content: '••••••••••';
	  color: #82c9b9;
    font-size: 1.25em;
    letter-spacing: .75em;
    
  }

/* ボタン */
.btn_wrap {
  text-align: center;
}
a.btn_03 {
  display: inline-flex;   /* ← これ重要 */
  justify-content: center;
  align-items: center;
  width: auto;
	max-width: 90%;
  height: 50px;
  position: relative;
  background: #79b943;
  border: 1px solid #79b943;
  border-radius: 30px;
  box-sizing: border-box;
  padding: 0 45px 0 25px;  /* ← 文字数対応の余白 */
  color: #fff;
  font-size: 1em;
	font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1.3;
  text-align: center;
  text-decoration: none;
  transition: all 0.3s ease;
  margin: 0 auto;         /* 中央寄せ */
}
a.btn_03:before {
  content: '';
  width: 8px;
  height: 8px;
  border: 0;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 25px;
  margin-top: -6px;
}
a.btn_03:hover {
  background: #fff;
  color: #79b943;
}
a.btn_03:hover:before {
  border-top: 2px solid #79b943;
  border-right: 2px solid #79b943;
}

@media (max-width: 600px) {
	
}


/*header */
header#masthead.site-header{
	height: auto;
}
.site-header{
	background: url("img/bg_head_top.png") center top no-repeat;
	background-size: 100% auto;
}

header.site-header div.container{
	width: 100%;
	max-width: none;

}

@media (max-width: 599px) {
	.site-header{background-size: 150% ;}	
}




/* navi */
@media (min-width:901px){
.global-nav,
.global-nav__container{
	background-color: transparent;
}
}

li.menu-item{font-size:1em}

li.navi_toiawase{
background: #79b943;
color: #fff;
padding: 0 10px;
display: block;
border-radius: 5px;
line-height: 1;
}

li.navi_toiawase a{
color: #fff;
font-weight: bold;
display: block;
font-size: 1.1em;
}

li.navi_toiawase:hover{
background: #6fb3de;
text-decoration: none;
}





/* content部分 */
.site-content{
	margin: 0 0 20px 0;
	width: 100%;
	padding: 0;
	
}

.site-content .container{
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0;
	
}

.content__wrap{
	margin-top: 0;
	padding: 0;
	width: 100%;
	
	
}

.content__main{
	width: 100%;
	max-width: 100%;
	background: #f0f6e8;
	padding-bottom: 20px;
}

.singular-header {
	width: 100%;
	text-align: center; 	
	background:#fff url("img/bg_head_bottom04.png") center bottom no-repeat; 
	background-size: 100% auto;
	margin-bottom: 80px;
	box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.2)
}
@media (max-width:599px){
	.singular-header{margin-bottom: 40px;}
}

.singular-header_innerBg{
padding: 80px 0 150px 0;
background: url("img/bg_entry-title.png") no-repeat center center;
background-size: 60%;	
}


@media (max-width:1024px){
	.singular-header_innerBg{
		padding: 40px 0 100px 0;
	}
}
@media (max-width:599px){
	.singular-header_innerBg{
		padding: 20px 0 50px 0;
	}
}

.singular-header  h1.entry-title{
	color: #79b943;
	font-size: 3em;
	margin: 0;
	padding: 0;
}


.singular-header  p.entry-title_en{
	font-weight: bold;
	font-size: 1.1em;
	padding: 0;
	margin: 0;
	color: #6fb3de;
}

@media (max-width:1024px){
	.singular-header  h1.entry-title{font-size: 2.5em;}
}
@media (max-width:599px){
	.singular-header  h1.entry-title{font-size: 2em;}
}


/* 文字アニメーション用 */
.split-char {
	display: inline-block;
	transform: translateY(1em);
	opacity: 0;
	animation: charUp 0.6s ease forwards;
}

@keyframes charUp {
	to {
		transform: translateY(0);
		opacity: 1;
	}
}

.js-split-text .split-char:nth-child(1) {
	color: #eaa646
}
.js-split-text .split-char:nth-child(2) {
	color: #6fb3de;
}


.entry-content{
	width: 90%;
	max-width: 1200px;
	margin: 0 auto 30px auto;
	font-size: 1.2em;
	line-height: 2;
	background: #fff;
	border-radius: 20px;
	padding: 40px 60px;
}

@media (max-width:599px){
	.entry-content{width: 95%; font-size: 1em; padding: 10px;}
	
}



.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4{
	text-align: center;
}

.entry-content h1{
	margin-bottom: 50px;
	font-size: 2.1em;
	letter-spacing: normal;
	color: #79b943;
}

.entry-content h2{
	margin-bottom: 20px;
	font-size: 1.6em;
	letter-spacing: normal;
	color: #79b943;
	line-height: 1.6;
}

@media (max-width:1024px){
	.entry-content h1{font-size: 1.7em;margin-bottom: 30px;}
	.entry-content h2{font-size: 1.5em;margin-bottom: 20px;}
}
@media (max-width:599px){
	.entry-content h1{font-size: 1.5em;margin-bottom: 20px;}
	.entry-content h2{font-size: 1.3em;margin-bottom: 15px;}
}

.entry-content img{
	border-radius: 20px;
}

.underlineBold{
  text-decoration: underline; /* 下線 */
  text-decoration-thickness: 0.1em; /* 線の太さ */
  text-decoration-color: rgba(239,240,201, 1); /* 線の色 */
  text-underline-offset: 0.5em; /* 線の位置。テキストに重なるようにやや上部にする */
  text-decoration-skip-ink: none; /* 下線と文字列が重なる部分でも下線が省略されない（線が途切れない） */	
}

.entry-content strong.underline{
  text-decoration: underline; /* 下線 */
  text-decoration-thickness: 0.5em; /* 線の太さ */
  text-decoration-color: rgba(239,240,201, 1); /* 線の色 */
  text-underline-offset: -0.2em; /* 線の位置。テキストに重なるようにやや上部にする */
  text-decoration-skip-ink: none; /* 下線と文字列が重なる部分でも下線が省略されない（線が途切れない） */
}



.box_yellow{
background: #fffae8;
	border-radius: 20px;
	padding: 30px 30px;
	margin-bottom: 30px;	
}

.box_glay{
background: #f2f2f2;
	border-radius: 20px;
	padding: 30px 30px;
	margin-bottom: 30px;	
}

.box_dot{
	border: 5px dotted #bcd0ed;
	border-radius: 20px;
	padding: 30px 30px;
	margin-bottom: 30px;	
}

.bg_tama-blue{
	background: url("img/bg_tama-blue.png") no-repeat  90% 90%;
	background-size: 20%;
}

.bg_tama-green{
	background: url("img/bg_tama-greenpng.png") no-repeat  20% 40%;
	background-size: 10%;
}

@media (max-width: 599px){
	.box_yellow{padding: 15px;}
	.box_dot{padding: 15px 15px;}
}

/* 写真を並べる */
.img-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* PC：3枚 */
  gap: 16px; /* 画像の間隔 */
}

@media (max-width: 599px){
  .img-grid{
    grid-template-columns: repeat(2, 1fr); /* SP：2枚 */
    gap: 12px;
  }
}

/* 画像を同サイズで揃える */
.img-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* PC：3枚 */
  gap: 16px;
}

@media (max-width: 599px){
  .img-grid{
    grid-template-columns: repeat(2, 1fr); /* SP：2枚 */
    gap: 12px;
  }
}

/* 画像を同サイズで揃える */
.img-grid img{
  width: 100%;
  aspect-ratio: 4 / 3;  /* ← 好きな比率に変更OK（1/1で正方形） */
  object-fit: cover;
  display: block;
  border-radius: 8px;   /* 任意 */
}
	


/*吹き出し*/
.fukidashi {
  position: relative;
  display: inline-block;
  margin:auto 20px;
  padding: 16px;
  border-radius: 8px;
  background-color: #ffe2ef;
  text-align: left;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  color: #000000;
	font-weight: 500;
}

.fukidashi::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 70%;
  border-style: solid;
  border-width: 20px 10px 0 10px;
  border-color: #ffe2ef transparent transparent;
  translate: -50% 100%;
  transform: skew(-28deg);
  transform-origin: top;
}

.parent {
  display: flex;
  justify-content: center;  /* 横中央 */
}
.balloon1 {
  position: relative;
  display: inline-block;
  margin: 0 auto;   /* ← 横中央配置 */
  padding: 0px 30px;
  min-width: 120px;
  max-width: 100%;
  color: #3b9edd;
  font-size: 16px;
  background: #e0edff;
  text-align: center;   /* 吹き出し内テキスト中央 */
	border-radius:15px;
 font-size: 1.2em;
	font-weight: 800;
}

.balloon1:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 15px solid transparent;
  border-top: 15px solid #e0edff;
}

/*線二本*/
.title-wrap{
  text-align:center;
}

.double-line-title{
  position: relative;
  display: inline-block !important;
  width: fit-content;
  max-width: 100%;
  padding: 0 6rem;     /* 文字と線の距離 */
  margin: 0;
  line-height: 1.2;
}

/* ===================== */
/* 左側： 外＝短 / 内＝長 */
/* 傾き：＼（右下がり） */
/* ===================== */

/* 左：外側（短） */
.double-line-title::before{
  content:"";
  position:absolute;
  left: 55px;
  top: 50%;
  width: 30px;         /* 短 */
  height: 2.5px;
  background: #bcd0ed;
  transform-origin: left center;
  transform: translateY(-50%) rotate(40deg);  /* ＼ */
}

/* 左：内側（長） */
.double-line-title .l2{
  position:absolute;
  left: 60px;          /* 隙間 */
  top: 30%;
  width: 50px;         /* 長 */
  height: 3px;
  background: #bcd0ed;
  transform-origin: left center;
  transform: translateY(10px) rotate(50deg);  /* ＼ */
}

/* ===================== */
/* 右側： 外＝短 / 内＝長 */
/* 傾き：／（左下がり） */
/* ===================== */

/* 右：外側（短） */
.double-line-title::after{
  content:"";
  position:absolute;
  right: 55px;
  top: 50%;
  width: 30px;         /* 短 */
  height: 2.5px;
  background: #bcd0ed;
  transform-origin: right center;
  transform: translateY(-50%) rotate(-40deg);   /* ／ */
}

/* 右：内側（長） */
.double-line-title .r2{
  position:absolute;
  right: 60px;         /* 隙間 */
  top: 30%;
  width: 50px;         /* 長 */
  height: 3px;
  background: #bcd0ed;
  transform-origin: right center;
  transform: translateY(10px) rotate(-50deg);   /* ／ */
}



/* footer */
.footer_toiawase{
	width: 90%;
	max-width: 1200px;
	margin: -20px auto 60px auto;
	font-size: 1.2em;
	line-height: 2;
	background: #fff;
	border-radius: 20px;
	padding: 0;
}

@media (max-width:599px){
	.footer_toiawase{width: 95%; font-size: 1em; margin: -20px auto 30px auto;}	
}

.footer_osugi{
	width: 70%;
	margin: 0 auto;
	font-size: 1.2em;
	line-height: 2;
	padding: 20px 10px;
	background: #fff;
	border-radius: 15px;
}

table.footer_osugiTable{
	width: auto;
	margin: 0 auto;
	border: none;
	padding-bottom: 20px;
}

table.footer_osugiTable tr{
	border: none;
}

table.footer_osugiTable th{
	width: 150px;
	padding: 0;
	border: none;
	line-height: 1;
	text-align: center;
	background: #fff;
}

table.footer_osugiTable th img{
	width: 100%;
	line-height: 1;
	margin: 0;
	padding: 0;
	border:1px solid #ccc;
}

table.footer_osugiTable td{
	width:auto;
	font-size: 0.75em;
	line-height: 1.4;
	padding: 0 15px;
	border: none;
}


@media (max-width:599px){
	.footer_osugi{width: 95%; font-size: 1em; margin: -20px auto 30px auto;}
	table.footer_osugiTable th{width: 100%;display: inline-block;}
	table.footer_osugiTable th img{ width: 50%; margin-bottom: 10px;}
	table.footer_osugiTable td{width: 100%;display: inline-block;font-size: 0.85em;}
	
}

.footer_info{
	margin: 30px auto 20px auto;
	
}

.footer_info h5{
	text-align: center;
	font-size:1.1em;
	padding: 0;
	margin: 0 auto 5px auto;
}

.footer_info p{
	text-align: center;
	font-size: 1em;
	line-height: 1.5;
}

.footer_info a{
	text-decoration: underline;
}

.footer_info a:hover{
	text-decoration:none;
}

.footer_sns{
	text-align:center;
	
}

.footer_sns img{
	width: 50px;
	padding:  0 10px;
}


p.copyright{
	font-size: 0.85em;
	text-align: center;
	margin: 10px auto;
}



/* トップページ  */
.n2-ss-slider img {
	overflow: hidden;
  border-radius: 30px;
	box-shadow: none !important;
}

.n2-ss-slide {
  box-shadow: none !important;
margin: 0;
}

div.header-media{
	padding:0;
	margin:0;

}

.n2-ss-slider-3
{
padding:20px !important;
	margin:0;
	height: auto;
}

.slider_bottom{width: 100%;margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); width:100vw; max-width:100%;}
.slider_bottom .n2-ss-slider img {border-radius: 0px;}
.slider_bottom .n2-ss-slider-3{padding: 0 !important;}



.top_title{
	margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); width:100vw; max-width:100%;
	background: #fff url("img/bg_top_bottom.jpg") no-repeat center bottom;
	background-size: 100%;
	margin: 0px 0 0 0;
	padding: 0;
}
@media (max-width:599px){
	.top_title{background-size: 200%;}
}

.top_title_inner{
	margin: 0 auto;
	width: 90%;
	max-width: 1200px;
	text-align: center;
	font-size: 1em;
}



h1.top_maincopy{
	width: 50%;
	margin: 0px auto 40px auto;
}

h1.top_maincopy img{
	margin-bottom: 15px;
}

@media (max-width:1024px){
	h1.top_maincopy{width: 70%; margin: 0px auto 5px auto;}	
}
@media (max-width:599px){
	.top_title_inner{font-size: 0.7em; line-height: 1em}
	h1.top_maincopy{width: 90%; margin: 0px auto 5px auto;}
	h1.top_maincopy img{margin-bottom: 5px;}
}

.top_main_info{
	width: 80%;
	margin: 0 auto 0px auto;
	padding-bottom: 30px;
}

.top_main_infoBox{
	width: 49%;
	margin: 0 0.5%;
	float: left;
}

.top_main_infoBox h5{
	width: 30%;
	float: left;
	padding: 0;
	margin: 0;
}

.top_main_infoBox p{
	width: 68%;
	float: right;
	text-align: left;
	font-size: 1em;
	line-height: 1.7;
}

.top_main_infoBox p img{
	width: 100%;
	max-width: 250px;
	padding-top: 10px;
	border-radius: 10px;
}

@media (max-width:800px){
	.top_main_info{padding-bottom: 10px;}
	.top_main_infoBox{float: none; width: 100%; margin: 15px 0;}
	.top_main_infoBox p{font-size: 1.2em;}
	.top_main_infoBox p img{width: 80%;}
}




.info-row{
  display: inline-flex;   /* ← flex → inline-flex */
  justify-content: space-between;
  align-items: center;
  gap: 10px;
	margin-bottom: 20px;
}

/* 各ブロック */
.info-item{
  display: flex;
  align-items: center;
  gap: 20px;
}
.no-break{
  white-space: nowrap;
}

/* 左右の幅バランス */
.info-item:first-child{ flex: 0 0 45%; }
.info-item:last-child { flex: 0 0 55%; }

/* ラベル（カプセル） */
.info-label{
  display: inline-flex;
  align-items: center;
  justify-content: center;
	width: 8em;
  height: 2em;
  padding: 0 28px;
  border-radius: 999px;
  color: #fff;
  font-weight: 600;
  letter-spacing: .12em;
  white-space: nowrap;
  font-size: 0.75em;
}

/* 色 */
.label-blue{ background: #74B7E5; }
.label-orange{ background: #E7A447; }

/* テキスト */
.info-text{
  font-size: font-size: 0.8em;
  font-weight: 600;
  line-height: 1.3;
  color: #222;
	text-align: left;
}

/* ===== スマホレイアウト ===== */
@media (max-width: 800px){

  /* 全体を縦積み */
  .info-row{
    flex-direction: column;
    align-items: stretch;
    gap: 22px;
  }

  /* 各行は横並び（ラベル左・テキスト右） */
  .info-item{
    display: flex;
    align-items: flex-start;
    gap: 14px;
  }

  /* 幅リセット */
  .info-item:first-child,
  .info-item:last-child{
    flex: 1 1 auto;
  }

  /* ラベルサイズ調整 */
  .info-label{
    height: 1.5em;
    font-size: 1em;
    padding: 0 18px;
  }

  /* テキスト調整 */
  .info-text{
    font-size: 1em;
    line-height: 1.4;
  }
}


/* ===== トップ news ===== */
.top-news{
  margin: 24px 0;
}

.top-news__inner{
  display: flex;
  gap: 0;
  border: 4px solid #bfe6dc;      /* 外枠の薄緑 */
  padding: 0;
  background: #fff;
}

/* 左：見出しボックス */
.top-news__head{
  flex: 0 0 25%;                /* 左枠の幅（お好みで） */
border-right: 4px solid #bfe6dc; 
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 120px;
  margin-right: 18px;
}

.top-news__ttl{
  margin: 0;
  font-size: 1em;
  font-weight: 700;
  color: #7fb8e6;                  /* “お知らせ”の水色 */
  letter-spacing: .08em;
}

/* 右：一覧 */
.top-news__body{
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  padding: 6px 15px;
}

.top-news__list{
  list-style: none;
  padding: 0;
  margin: 0;
  width: 100%;
  display: grid;
  gap: 14px;
}

.top-news__item{
  display: flex;
  align-items: center;
  gap: 18px;
}

/* 日付ラベル（緑の角丸） */
.top-news__date{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 150px;
  height: 1.5em;
  padding: 0 18px;
  background: #4fb9a6;
  color: #fff;
	font-size: 0.8em;
  font-weight: 400;
  border-radius: 6px;
  white-space: nowrap;
}

/* タイトルリンク */
.top-news__link{
  font-size: 0.8em;
  font-weight: 400;
  text-decoration: underline;
  line-height: 1.3;
}

.top-news__link:hover{
  text-decoration: none;
}

/* スマホ：縦積み */
@media (max-width: 900px){
  .top-news__inner{
    flex-direction: column;
  }
  .top-news__head{
    flex: 0 0 auto;
    min-height: auto;
    margin-right: 0;
	  border-right: none; 
	 border-bottom: 4px solid #bfe6dc;
	  padding: 10px;
  }
	.top-news__body{
		padding: 15px;
		align-items: flex-start;
	}
.top-news__item{
    flex-direction: column;
    align-items: flex-start;
    gap: 1px;
	text-align: left; 
  }
  .top-news__ttl{
    font-size: 1em;
	  line-height: 1;
	  padding: 0;
	  text-align: left; 
  }
  .top-news__link{
    font-size: 0.9em;
  }
  .top-news__date{
    min-width: 120px;
    height: 1.5em;
  }
}


/* ---トップ メッセージ -- */
.top_message{
	background: #fffae8;
	padding: 20px 40px;
}

.top_message h6{
	text-align: center;
	margin: 20px auto 5px auto;
	padding: 0;
	font-size: 1.5em;
}

.top_message h2{
	text-align: center;
	font-size: 3em;
	margin: 0 auto 40px auto;
	padding: 0;
}

.box_white{
background: #fff;
	border-radius: 20px;
	padding: 30px 30px;
	margin-bottom: 30px;	
}

.box_whiteL{
	width: 50%;
	float: left;
	background: url("img/bg_tama-greenpng.png") no-repeat  10% 30%;
	background-size: 30%;
}

.box_whiteL p{
	font-size: 1.3em;
	line-height: 1.8;
	font-weight: 500;
	text-align: center;
}

.box_whiteL h3{
	font-size: 1.6em;
	line-height: 1.7;
	font-weight: 800;
	text-align: center;
	margin: 20px 0;
}

.box_whiteR{
	width: 48%;
	float: right;
}

.box_whiteR img{
	border-radius: 15px;
}

.top_manabino{
	text-align: center;
	max-width: 1200px;
	margin: 0 auto 20px auto;
}

.top_manabino img{
	width: 18%;
	padding: 0 2%;
}

@media (max-width: 900px){
.box_whiteL p{line-height: 1.7;}
.box_whiteL h3{ margin: 20px auto 15px auto;}	
.box_whiteL{width: 100%; float: none;}
	.box_whiteR{width: 100%; float: none;}
}

@media (max-width: 800px){
	.top_message{
	padding: 10px 10px;
	}
	.box_white{padding: 20px;}
	.top_message h6{font-size: 1em;}
	.top_message h2{font-size: 2em;}
	.box_whiteL p{font-size: 1.1em; text-align: left; line-height: 1.7;}
	.box_whiteL h3{margin: 20px auto 15px auto;}
	.top_manabino img{width: 23%; padding: 0 1%;}
}

/*--------------------------------------
  カード型_01
--------------------------------------*/
.top_card{
	background: #f2fff5;
	padding: 15px 15px;
	
}

.card_wrapper {
	flex: 0 0 100%;
  width: 100%;
  max-width: 100%;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 1rem;
    padding: 0;

}

.card {
    display: flex;
    flex-direction: column;
    word-wrap: break-word;
    background-color: #fff;
    box-sizing: border-box;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    color: #79b943;
    text-decoration: none;
    overflow: hidden;
    transition: transform 0.3s ease-in-out;
}

.card-image-box {
    overflow: hidden;
}

.card-image {
    width: 100%;
    height: 100px;
    object-fit: cover;
	margin: 0;
}

.card-image-box img{
	border-radius: 8px; 
}


.card-box {
    padding: 1rem;
}

h2.card-title {
    margin-bottom: 0.5rem;
    font-size: 0.9rem;
    font-weight: bold;
	margin: 0;
	padding: 0;
	line-height: 1.3;
	color: ##79b943;
	text-align: center;
}

h2.card-title span{
	font-size: 0.6em;
}

.card-description {
    margin-bottom: 0.5rem;
    line-height: 1.5;
}

.card:hover {
    transform: scale(1.02);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

@media (min-width: 900px){
	.top_card{padding: 20px 40px;}
  .card{
    flex-basis: calc((100% - 3rem) / 4); /* gapが1remなので 3つ分引く */
  }
	.card-image {height: 150px;}
	h2.card-title{font-size: 1.1rem;}
}

/* ===== デフォルト（スマホ）：2列 ===== */
/* スマホ：2列 */
@media (max-width: 767px){
  .card_wrapper > .card{
    flex: 0 0 calc((100% - 1rem) / 2);
    max-width: calc((100% - 1rem) / 2);
  }
}

/* タブレット：3列 */
@media (min-width: 768px){
	.card_wrapper{width: 90%; margin: 0 auto;}
  .card_wrapper > .card{
    flex: 0 0 calc((100% - 2rem) / 3);
    max-width: calc((100% - 2rem) / 3);
  }
}

/* PC：4列 */
@media (min-width: 900px){
  .card_wrapper > .card{
    flex: 0 0 calc((100% - 3rem) / 4);
    max-width: calc((100% - 3rem) / 4);
  }
}









/* PC：4列 */
@media (min-width: 1200px){
  .wrapper > .card{
    flex: 0 0 calc((100% - 3rem) / 4);
    max-width: calc((100% - 3rem) / 4);
  }
}

/* ===== ボタン一覧：PC基準 ===== */
*, *:before, *:after {
    box-sizing: border-box;
}
.col_4{
	width: 100%;
	display: flex;
	flex-wrap: wrap;
}
.col_4 div{
	width: calc( 25% - 9px );
	margin-right: 12px;
	margin-bottom: 12px;
	color: #79b943;
	font-weight: 600;
	text-align: center;
}
.col_4 > *:nth-child(4n){
	margin-right: auto;
}
.col_4 div img{
border-radius: 5px;
	padding: 0;
	margin: 0 0 5px 0;
}
.col_4 div a{
	color:#79b943;
	text-decoration: none;
}

@media screen and (max-width: 960px) {
	.col_4 > *{
		width: calc( 33.33333% - 8px ) ;
	}
	.col_4 > *:nth-child(4n){
		margin-right: 12px;
	}
	.col_4 > *:nth-child(3n){
		margin-right: auto;
	}
}
@media screen and (max-width: 580px) {
	.col_4 > *{
		width: calc( 50% - 6px ) ;
	}
	.col_4 > *:nth-child(3n){
		margin-right: 12px;
	}
	.col_4 > *:nth-child(2n){
		margin-right: auto;
	}
}



/*googlea map*/
.map-full{
  width: 100%;
}

.map-full iframe{
  width: 100%;
  height: 450px;   /* お好みで */
  border: 0;
  display: block;
}




/* News */

.archive__item{
	border-bottom: 3px dotted #bcd0ed;
	padding: 10px 0;
	width: 100%;
	max-width: 800px;
	margin: 0 auto 10px auto;
}

.archive__date{
	font-size: 0.65em;
	color: #fff;
	margin: 0;
	background: #5cbea8;
	padding: 5px 15px;
	border-radius: 5px;
}
h2.archive__title{
text-align: left;
}
h2.archive__title a.archive__link{
	font-size: 0.8em;
	line-height: 1.5;
	text-align: left;
	text-decoration: underline;
}

h2.archive__title a.archive__link:before {
  content: '';
  width: 8px;
  height: 8px;
  border: 0;
  border-top: 2px solid #5cbea8;
  border-right: 2px solid #5cbea8;
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 25px;
  margin-top: -6px;
}

h2.archive__title a.archive__link:hover{
	text-decoration: none;
}

@media (max-width:599px){
	.archive__date{font-size: 0.85em;}
	h2.archive__title a.archive__link{font-size: 1em;}
	
}


h2.news_title{
	margin: 0 0 10px 0;
}
.news_day{
	text-align: center;
	font-size: 0.9em;
	color: #fff;
	margin: 0;
}

.news_day span{
background: #5cbea8;
	padding: 5px 15px;
	border-radius: 5px;
}


/* ご利用案内 */
.hyou dl {
width: 100%;
}
.hyou dt {
padding: 15px 20px;
background-color: #e8f1fa;
	border-radius: 25px;
}
.hyou dd {
padding: 10px 20px  10px 20px;
	margin-left: -10px;
	margin-bottom: 40px;
}

@media (max-width:599px){
	.hyou dt{padding: 10px 20px;}
}


.table01{
	border: none;font-size: 0.9em;
	border-top: 1px dashed #9E9E9E;
	font-size: 1em;
	line-height: 1.5;
}

.table01 tr{
	border-left: none;
	border-bottom: 1px dashed #9E9E9E;
}

.table01 th{
	border: none;
	font-weight: bold;
	font-size: 0.9em;
	line-height: 1.5;
}

.table01 td{
	border: none;
	font-size: 0.9em;
}



/* コンセプト */
.concept_box{
padding: 1em 1em;
    color: #565656;
    background: #fbf6e5;
    border-radius: 20px;
	margin-bottom: 30px;
	font-size: 1.1em;
	font-weight: 600;
	line-height: 2;
		
}

.concept_box h1{
	margin-top: 30px;
}

.concept_box p{
	text-align: center;
	margin-bottom: 30px;
	line-height: 2;
}


.daihyou_box{
	margin-bottom: 20px;
}



.daihyouL{
	width: 35%;
	float: left;
}

.daihyouR{
	width: 62%;
	float: right;
}

.makiko_name{
	
}

.makiko_name h6{
	margin: 0;
	font-size: 1em;
	padding-top: 50px;
}

.makiko_name h2{
	margin: 0;
	font-size: 1.5em;
	text-align: left;
	color: #1D1D1D;
}

.makiko_name h2 span.roma{
	font-size: 0.6em;
	font-weight: normal;
	color: #555555;
}
.daihyouR p{
	font-size: 0.9em;
	line-height: 1.6;
	padding: 0 10px;
}

@media (max-width:599px){
	.daihyouL{width: 60%;float: none;margin: 0 auto;}
	.daihyouR{width: 100%;float: none;margin: 0 auto;}
	.makiko_name h2{text-align: center;}
	.makiko_name h6{padding-top: 10px; text-align: center;}
	.daihyouR p{font-size: 1em;}
}

/* 一日の流れ */
.schedule dl {
width: 100%;
}
.schedule dt {
padding: 15px 20px;
background-color: #f7ebc6;
border-radius: 10px;
}

.schedule dt span.schedule_time{
padding: 5px 20px;
background-color: #88b855;
border-radius: 20px;
color: #fff;
	margin-right: 15px;
}
.schedule dd {
padding: 15px 20px  10px 20px;
	margin-left: -10px;
	margin-bottom: 40px;
}

.schedule dd div.schedule_photo{
	float: left;
	width: 40%;
}

.schedule dd div.schedule_photo img{
	width: 100%;
	border-radius: 10px;
}
.schedule dd div.schedule_text{
	float: right;
	width: 58%;
}

.schedule dd div.schedule_text p{
	font-size: 0.9em;
	line-height: 1.5;
	margin-top: 0;
}

@media (max-width:599px){
	.schedule dt{padding: 10px 20px;}
	.schedule dd div.schedule_photo{float: none; width: 100%; margin: 0 auto 10px auto;}
	.schedule dd div.schedule_text{float: none; width: 100%;}
}


/**利用者の声**/
.voiceBox{
	background: #fffae8;
	border-radius: 20px;
	padding: 30px 30px;
	margin-bottom: 30px;
}

.voicePhoto{
	width: 20%;
	float: left;
	text-align: center;
}

.voicePhoto img{
	width: 100%;
	border-radius:50%;
	border: 6px #fff solid;
	
}

.voicePhoto p{
	padding: 0;
	margin: 0;
	font-weight: 800;
	line-height: 1.3;
}

.voiceComment{
	width: 78%;
	float: right;
}

@media (max-width:599px){
	.voiceBox{padding: 15px;}
	.voicePhoto{width: 40%; float: none; margin: 0 auto;}
	.voiceComment{width: 100%; float: none; }
}


/* 学習システム */
.s-system_box{
background: #f2f2f2;
	border-radius: 8px;
	padding: 30px 20px;
	margin-bottom: 30px;	
}
.s-systemL{
	width: 18%;
	float: left;
}

.s-systemR{
	width: 78%;
	float: right;
	font-size: 0.95em;
	line-height: 1.6;
}

@media (max-width:599px){
	.s-systemL{ float: none; width: 30%; text-align: center; margin: 0 auto 20px auto;}
	.s-systemR{ float: none; width: 100%}
}

/* プロジェクト　活動内容 */

.project_box{
	padding: 30px 0px 0px 0px;
	margin-bottom: 0px;
	border-top: 2px dotted #7CCAD6;
}


.projectL{
	width: 40%;
	float: left;
}

.projectL img{
	border-radius: 10px;
}

.projectR{
	width: 58%;
	float: right;
	font-size: 0.85em;
	line-height: 1.6;
}

.projectR h6{
	margin: 0 0 10px 0;
	padding: 0;
	color: #6fb3de;
}

@media (max-width:599px){
	.project_box{}
	.projectL{float: none; width: 100%; margin: 0 auto 10px auto;}
	.projectR{float: none; width: 100%; }
	.projectR h6{ text-align: center; margin-bottom: 5px;}
}

/**Q&A アコーディオン**/
.accordion-006 {
    max-width: 100%;
    margin-bottom: 7px;
    background-color: #f2f2f2;
    border-radius: 25px;
}

.accordion-006 summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    padding: 1em 2em;
    color: #5b9a27;
    font-weight: 600;
	line-height: 1.6;
    cursor: pointer;
}

.accordion-006 summary::-webkit-details-marker {
    display: none;
}

.accordion-006 summary::before,
.accordion-006 summary::after {
    width: 3px;
    height: .9em;
    border-radius: 5px;
    background-color: #c2c2c2;
    content: '';
}

.accordion-006 summary::before {
    position: absolute;
    right: 2em;
    rotate: 90deg;
}

.accordion-006 summary::after {
    transition: rotate .3s;
}

.accordion-006[open] summary::after {
    rotate: 90deg;
}

.accordion-006 p {
    transform: translateY(-10px);
    opacity: 0;
    margin: 0;
    padding: .3em 2em 1.5em;
    color: #000;
    transition: transform .5s, opacity .5s;
}

.accordion-006[open] p {
    transform: none;
    opacity: 1;
}




/*ContactForm7カスタマイズ*/
/******************************/
/** コンタクトフォームの装飾 **/
/******************************/
/* フォーム全体のスタイル */
.wpcf7-form {
	width: 100%;
	max-width: 700px;
	margin: 0 auto 30px auto;
}

/* 入力フィールドのスタイル */
.wpcf7-form .form-group label {
display: block;
margin-bottom: 8px;
font-weight: 600;
font-size: 0.9em;
	
}

.wpcf7-form .form-group label span.required{
	background: #EE2528;
	padding: 3px 10px;
	color: #FFffff;
	border-radius: 5px;
	font-size: 0.7em;
}

.wpcf7-form .form-group label span.f-mini{
	font-size: 0.8em;
	color: #6D6D6D;
	line-height: 1.3;
	font-weight: normal;
}

.wpcf7-form input[type="text"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="email"],
.wpcf7-form textarea,
.wpcf7-form input[type="file"] {
width: 100%;
padding: 14px;
border: 1px solid #cccccc;
border-radius: 6px;
margin-bottom: 25px;
}

/* フォーカス時のスタイル */
.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="email"]:focus,
.wpcf7-form textarea:focus,
.wpcf7-form input[type="file"]:focus {
border-color: #a07b5c;
box-shadow: 0 0 5px rgba(160,123,92,0.2);
}

/* 送信ボタンのスタイル */
.wpcf7-form input[type="submit"] {
background-color: #79b943;
	border: 1px solid #79b943;
color: #FFFFFF;
font-size: 17px;
padding: 14px 40px;
border-radius: 10px;
border: 2px solid #79b943;
transition: background-color 0.3s ease;
	margin: 0 auto;
	font-weight: 600;
}

.wpcf7-form input[type="submit"]:hover {
background-color: #fff;
	color: #79b943;
	box-shadow:none;
}



/*slider*/
.slider1 {
  display: flex;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  height:200px;
  overflow: hidden;
}
.slider1 ul{
	display:flex;
	padding: 0;
	margin:0;
}
.slider1 li{
	width:300px;
	list-style: none;
	padding: 0;
	margin:0;
}

.slider1 li img{
	border-radius: 0;
}
.slider1 ul:first-child {
  animation: slide1 120s -60s linear infinite;
}

.slider1 ul:last-child {
  animation: slide2 120s linear infinite;
}
@keyframes slide1 {
  0% {
    transform: translateX(100%);
  }
  to {
    transform: translateX(-100%);
  }
}

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

