@charset "utf-8";

/* ブラウザスタイル初期化用ＣＳＳ */
html {
	width: 100%;
	font-size: 0;
	line-height: 0;
}
body{
	margin: 0px;
	padding: 0px;
	width: 100%;
	background-color: #ffffff;
	overflow-x: hidden;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	-webkit-text-size-adjust: 100%;
}
h1,h2,h3,h4,h5,h6,p,pre,blockquote,ul,ol,li,dl,dt,dd{
	margin: 0px;
	padding: 0px;
}
li,dt,dd{
	list-style-type: none;
}
p {
	margin: 0;
}
img {
	border: 0;
	border: none;
}
a {
	text-decoration: none;
}
a:hover {
	color: #2d60ad;
	text-decoration: none;
}
a:hover img{
	/*モダンブラウザ用*/
	opacity:0.8;
	/*IE7以下用*/
	filter:alpha(opacity=80);
	/*IE8用*/
	-ms-filter:"alpha(opacity=80)";
}


body{
  background: url('images/main_bg.png') repeat center top;
  text-align: center;
  padding-top: 117px;
}
img{
	max-width: 100%;
}
.wrap{
  width: 960px;
  margin: 0 auto;
}


header{
    height: 117px;
    position: fixed;
  top: 0;
  left: 0;
    z-index: 999;
    width: 100%;
    text-align: left;
    background-color: #ffffff;
}
header:after{
  content: url('images/header_s/line.png');
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -2;
}
header .logo{
  padding: 16px 0 0 16px;
}
header .menu{
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  text-align: right;
}
header .menu > div{
    display: none;
    background: url('images/header_s/bg.png');
    padding-top: 4px;
}
header .menu > div ul{
    position: relative;
    text-align: left;
    padding-bottom: 4px;
    overflow-y: scroll;
    max-height: 1000px;
}
header .menu > div ul li{
    background-color: #f4af0d;
    margin-top: 2px;
    padding: 8px 0 8px 16px;
}
header .menu > div ul li.idx{
    background-color: #f59e00;
    margin-top: 4px;
    padding: 12px 0 12px 16px;
}
header .menu > div ul li.telfax{
    background-color: #f59e00;
    text-align: center;
    padding: 24px 0;
    margin-top: 0;
}
header .menu > div ul li.recruit{
    background-color: #f59e00;
    text-align: center;
    padding: 24px 0;
    margin-top: 4px;
}
header .menu > div ul li.tel{
    position: absolute;
    top: 48px;
    left: 102px;
    opacity: 0;
}
header .menu > div ul li.tel a{
    display: block;
    width: 270px;
    height: 30px;
}




footer{
  text-align: center;
  background: url('images/footer_s/bg.png') no-repeat;
  background-position: center bottom 320px;
  position: relative;
  margin-top: -100px;
  padding-top: 100px;
  z-index: 1;
}
footer .access{
  margin: 0 30px;
}
footer .access > img{
}
footer .access .address{
  text-align: left;
  font-size: 30px;
  line-height: 160%;
}
footer .access .box{
  font-size: 24px;
  line-height: 160%;
  margin-top: 10px;
  text-align: left;
}
footer .access .box:after{
  content: '';
  display: block;
  clear: both;
}
footer .access .box img{
  float: left;
  padding-right: 18px;
}
footer .access .box span{
  display: block;
  font-weight: bold;
}
footer #idx_map{
  width: 100%;
  height: 380px;
  overflow: hidden;
  border-radius: 6px;
  margin-top: 40px;
}
footer #idx_map *{
  line-height: 160%;
}

footer .contact {
  display: inline-block;
  zoom: 1;
  vertical-align: middle;
  font-size: 28px;
  font-weight: bold;
  line-height: 100%;
  color: #111111;
  padding: 0 20px;
  padding-top: 240px;
  margin-bottom: 14px;
}

footer .contact span {
  color: #ff9900;
}

footer .telfax{
  padding-top: 300px;
}
footer .link{
  padding-top: 30px;
}
footer .link > div{
  padding-bottom: 30px;
}
footer .link a{
  display: inline-block;
  zoom: 1;
  vertical-align: middle;
  font-size: 24px;
  line-height: 100%;
  color: #111111;
  padding: 0 20px;
  margin-bottom: 14px;
  border-left: solid 1px #3e3e3e;
}
footer .link a:last-child{
  border-right: solid 1px #3e3e3e;
}
footer .copy{
  margin: 10px auto 160px;
  font-size: 20px;
  line-height: 140%;
}


/*
*/



#totop{
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  visibility: hidden;
  overflow: hidden;
}
#totop img{
  visibility: visible;
  position: absolute;
  bottom: 20px;
  right: -100px;
}


#idx{
}
#idx .visual{
  position: relative;
}
#idx .visual div{
  position: absolute;
  top: 0;
  left: 50%;
}
#idx .visual .blog{
  position: absolute;
  top: 408px;
  left: 120px;
  display: block;
  width: 194px;
  height: 140px;
}
#idx .news{
  padding-top: 50px;
}
#idx .news .title{
  margin: 0 30px;
  text-align: left;
  position: relative;
}
#idx .news .title .news_title{
}
#idx .news .title .news_more{
  position: absolute;
  top: 0;
  right: 0;
}
#idx .news dl{
  margin: 20px 30px 0;
  background: url('images/idx_s/news_line1.png') repeat-x center top, url('images/idx_s/news_line2.png') repeat-x center bottom;
  text-align: left;
}
#idx .news dt{
  display: inline-block;
  zoom: 1;
  vertical-align: top;
  padding: 16px 0;
  width: 160px;
  font-size: 19px;
  line-height: 40px;
}
#idx .news dt span{
  display: inline-block;
  zoom: 1;
  vertical-align: middle;
  background-color: #ffff99;
  font-size: 18px;
  line-height: 100%;
  color: #333333;
  padding: 12px 0;
  width: 120px;
  text-align: center;
  border-radius: 6px;
  margin-right: 20px;
  letter-spacing: 2px;
}
#idx .news dd{
  display: inline-block;
  zoom: 1;
  vertical-align: top;
  padding: 16px 0 0 0;
  width: 400px;
  font-size: 19px;
  line-height: 40px;
}
#idx .news dl div{
  width: 100%;
  height: 1px;
  background: url('images/idx_s/news_line2.png') repeat-x center bottom;
}

#idx .cont_1{
  padding-top: 76px;
}
#idx .cont_2,
#idx .cont_3,
#idx .cont_4{
  position: relative;
}
#idx .cont_2t1,
#idx .cont_2t2,
#idx .cont_3t1,
#idx .cont_3t2,
#idx .cont_3t3,
#idx .cont_4t1{
  position: absolute;
  top: 0;
  left: 50%;
  z-index: 3;
  font-size: 24px;
  line-height: 150%;
  text-align: left;
}
#idx .cont_2t1{
  margin: 460px 0 0 -150px;
}
#idx .cont_2t2{
  margin: 1050px 0 0 -150px;
}
#idx .cont_3t1{
  margin: 490px 0 0 -150px;
}
#idx .cont_3t2{
  margin: 990px 0 0 -150px;
}
#idx .cont_3t3{
  margin: 1510px 0 0 -150px;
}
#idx .cont_4t1{
  margin: 470px 0 0 0;
  position: absolute;
  top: 0;
  left: 0;
  font-size: 24px;
  line-height: 176%;
  text-align: center;
  width: 100%;
}
#idx .cont_4t1 span{
  display: block;
  font-size: 40px;
  line-height: 100%;
  padding-top: 50px;
}
#idx .cont_4i1,
#idx .cont_4i2,
#idx .cont_4i3,
#idx .cont_4i4{
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
}
#idx .cont_4i1{
  margin: 770px 0 0 160px;
}
#idx .cont_4i2{
  margin: 1100px 0 0 0px;
}
#idx .cont_4i3{
  margin: 1210px 0 0 310px;
}
#idx .cont_4i4{
  margin: 1350px 0 0 40px;
}
#idx .cont_4m{
  position: absolute;
  top: 850px;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 550px;
}
#idx .cont_4m iframe{
  width: 100%;
  height: 100%;
}


#about{
}
#about .visual{
}
#about .visual .title{
}

#about .cont{
}

#about .cont_1,
#about .cont_2,
#about .cont_3,
#about .cont_4,
#about .cont_5,
#about .cont_6,
#about .cont_7{
  position: relative;
  width: 640px;
  margin: 0 auto;
}
#about .cont_1t1,
#about .cont_1t2{
  position: absolute;
  left: 0;
  z-index: 1;
  font-size: 28px;
  line-height: 42px;
  text-align: center;
  width: 100%;
  color: #ffffff;
}
#about .cont_1t1{
  top: 200px;
}
#about .cont_1t2{
  top: 610px;
}

#about .cont_2t1,
#about .cont_2t2,
#about .cont_2t3{
  position: absolute;
  left: 180px;
  z-index: 1;
  font-size: 32px;
  line-height: 140%;
  text-align: left;
}
#about .cont_2t1{
  top: 210px;
}
#about .cont_2t2{
  top: 420px;
}
#about .cont_2t3{
  top: 635px;
}

#about .cont_3t1{
  position: absolute;
  left: 180px;
  top: 155px;
  z-index: 1;
  font-size: 26px;
  line-height: 140%;
  text-align: left;
}

#about .cont_5t1,
#about .cont_5t2,
#about .cont_5t3,
#about .cont_5t4,
#about .cont_5t5,
#about .cont_5t6{
  position: absolute;
  left: 180px;
  z-index: 1;
  font-size: 31px;
  line-height: 42px;
  text-align: left;
  letter-spacing: -1px;
}
#about .cont_5t1{
  top: 230px;
}
#about .cont_5t2{
  top: 350px;
}
#about .cont_5t3{
  top: 470px;
}
#about .cont_5t4{
  top: 590px;
}
#about .cont_5t5{
  top: 710px;
}

#about .cont_6t1,
#about .cont_6t2,
#about .cont_6t3,
#about .cont_6t4,
#about .cont_6t5,
#about .cont_6t6{
  position: absolute;
  left: 70px;
  z-index: 1;
  width: 500px;
  font-size: 30px;
  line-height: 42px;
  text-align: left;
  letter-spacing: -1px;
}
#about .cont_6t1{
  top: 720px;
}
#about .cont_6t2{
  top: 1650px;
}
#about .cont_6t3{
  top: 2600px;
}


#about .cont_7t1,
#about .cont_7t2,
#about .cont_7t3,
#about .cont_7t4,
#about .cont_7t5,
#about .cont_7t6{
  position: absolute;
  left: 50px;
  z-index: 1;
  width: 550px;
  font-size: 28px;
  line-height: 42px;
  text-align: left;
  letter-spacing: -1px;
}
#about .cont_7t1{
  top: 340px;
}
#about .cont_7t2{
  top: 1175px;
}
#about .cont_7t3{
  top: 1790px;
}
#about .cont_7t4{
  top: 2540px;
}
#about .cont_7t5{
  top: 3240px;
}
#about .cont_7t6{
  top: 3930px;
}

#about .cont_8 .title,
#about .cont_9 .title{
	margin: 30px auto 20px;
}
#about .cont_8 p{
  padding: 30px 0 40px 0px;
}
#about .cont_8 ul{
  display: block;
  padding: 8px;
  margin: 10px 30px 0;
  text-align: left;
  background: url('images/noise.png') repeat center center;
  border-radius: 12px;
}
#about .cont_8 ul li{
  display: block;
  padding: 0 14px;
  background-color: #ffffff;
  border-bottom: 1px solid #ff9900;;
}
#about .cont_8 ul li:first-child{
  border-radius: 8px 8px 0 0;
}
#about .cont_8 ul li:last-child{
  border-radius: 0 0 8px 8px;
  border-bottom: none;
}
#about .cont_8 ul li span:first-child{
  display: inline-block;
  zoom: 1;
  vertical-align: middle;
  font-size: 26px;
  line-height: 38px;
  color: #333333;
  padding: 24px 12px 24px 8px;
  width: 140px;
  text-align: left;
}
#about .cont_8 ul li span:last-child{
  display: inline-block;
  zoom: 1;
  vertical-align: middle;
  font-size: 26px;
  line-height: 38px;
  color: #333333;
  padding: 24px 0px 24px 22px;
  width: 350px;
  text-align: left;
  border-left: 1px solid #ff9900;;
}
#about .cont_8 ul li span:last-child span{
  display: inline-block;
  zoom: 1;
  vertical-align: middle;
  font-size: 22px;
  line-height: 38px;
  color: #333333;
  padding: 0;
  width: auto;
  text-align: left;
  border-left: none;
}
#about .cont_9 .map{
	margin-bottom: 60px;
}


#program{
}
#program .visual{
}
#program .visual .title{
}

#program .cont{
}

#program .cont_1,
#program .cont_2,
#program .cont_3{
  position: relative;
  width: 640px;
  margin: 0 auto 50px;
}

#program .cont_1 ul {
	width: 100%;
	margin: 15px auto 20px;
	display: table;
}
#program .cont_1 ul li {
	display: table-cell;
}

#program .cont table {
	border-collapse: collapse;	
	box-sizing: border-box;
}

#program .cont table td {
	height: 90px;
	margin: 0;
	padding: 30px 0 15px;;
	vertical-align: middle;
	box-sizing: border-box;
}

#program .cont_1t1,
#program .cont_2t1,
#program .cont_3t1 {
  position: absolute;
  left: 60px;
  z-index: 1;
  width: 500px;
  font-size: 28px;
  font-weight: bold;
  line-height: 42px;
  text-align: left;
  top: 435px;
}

#program .cont_2t1,
#program .cont_3t1{
  position: absolute;
  top: 100px;
}

#program .cont_1t1 p,
#program .cont_2t1 p,
#program .cont_3t1 p{
  font-size: 28px;
  font-weight: normal;
  line-height: 42px;
  margin-top: 25px;
  text-align: center;
}


#life{
}
#life .visual{
}
#life .visual .title{
}

#life .cont{
  position: relative;
  z-index: 10;
}

#life .cont_1{
  position: relative;
  width: 640px;
  margin: 30px auto;
}

#life .cont_1 ul {
	width: 100%;
	margin: 15px auto 20px;
	display: table;
}
#life .cont_1 ul li {
	display: table-cell;
}

#life .cont table {
	border-collapse: collapse;	
	box-sizing: border-box;
}

#life .cont table td {
	height: 135px;
	margin: 0;
	padding: 30px 0 15px;;
	vertical-align: middle;
	box-sizing: border-box;
}

#life .cont_1t1 table {
  position: absolute;
  left: 170px;
  z-index: 1;
  width: 460px;
  font-size: 28px;
  line-height: 42px;
  text-align: left;
  top: 115px;
}

#life .cont_1t1 p{
  font-size: 28px;
  font-weight: normal;
  line-height: 42px;
  margin-top: 25px;
  padding: 0 20px;
  text-align: left;
}


#lunch{
}
#lunch .visual{
}
#lunch .visual .title{
}

#lunch .cont{
}

#lunch .cont_1,
#lunch .cont_2,
#lunch .cont_3{
  position: relative;
  width: 640px;
  margin: 0 auto 50px;
}
#lunch .cont_1t1 {
  position: absolute;
  left: 40px;
  z-index: 1;
  width: 560px;
  font-size: 28px;
  line-height: 42px;
  text-align: left;
  top: 330px;
}

#lunch .cont_2t1,
#lunch .cont_2t2,
#lunch .cont_2t3{
  position: absolute;
  left: 40px;
  z-index: 1;
  width: 550px;
  font-size: 28px;
  line-height: 140%;
  text-align: left;
}
#lunch .cont_2t1{
  top: 260px;
}
#lunch .cont_2t2{
  top: 960px;
}
#lunch .cont_2t3{
  top: 1745px;
}

#lunch .cont_3t1,
#lunch .cont_3t2,
#lunch .cont_3t3{
  position: absolute;
  left: 30px;
  z-index: 1;
  font-size: 28px;
  line-height: 140%;
  text-align: left;
}
#lunch .cont_3t1{
  top: 300px;
}
#lunch .cont_3t2{
  top: 1245px;
}
#lunch .cont_3t3{
  top: 2185px;
}



#guidance .cont_1,
#guidance .cont_1_2,
#guidance .cont_2,
#guidance .cont_2_2,
#guidance .cont_3 {
  position: relative;
  width: 640px;
  margin: 0 auto 50px;
  z-index: 10;
}

#guidance .cont_1 {
  margin-top: 30px;
}

#guidance .cont_1 ol {
    position: absolute;
  top: 110px;
  left: 140px;
  margin: 0 auto;
  overflow: hidden;
}
#guidance .cont_1 ol li {
  height: 125px;
  padding: 40px 0 64px;
  font-size: 28px;
  text-align: left;
  line-height: 1.5em;
}
#guidance .cont_1 ol li.cont_1n4,
#guidance .cont_1 ol li.cont_1n7 {
  padding: 60px 0 44px;
}
#guidance .cont_1n7 {
  color: #FC9923;
}  
#guidance .cont_1 ol li span {
  font-weight: bold;
  font-size: 32px;
}
#guidance .cont_1 ol li small {
  font-size: 88%;
}
#guidance .btn {
  margin-top: 50px;
}

#guidance .cont_2 {
  padding: 20px;
  text-align: center;
  box-sizing: border-box;
}
#guidance .cont_2 p {
  font-size: 28px;
  text-align:left;
  line-height: 1.5em;
  }
#guidance .cont_2txt {
  position: absolute;
  top: 230px;
  left: 35px; 
  width: 370px;
}
   
#guidance .cont_2_2 {
  position: relative;
  text-align: center;
}
#guidance .cont_2_2 p {
  font-size: 16px;
  text-align:left;
  line-height: 1.5em;
  }
#guidance .cont_2_2 li {
  display: inline-block;
  padding: 2px 5px;
  font-size: 15px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5em;
  }

#guidance .cont_2_2 li small {
  font-size: 14px;
  }
#guidance .cont_2txt2 {
  position: absolute;
  top: 510px;
  left: 35px; 
  width: 600px;
  text-align: left;
}
#guidance p.cont_2txt3 {
  position: absolute;
  top: 80px;
  left: 20px; 
  width: 400px;
  font-size: 22px;
}
#guidance p.cont_2txt4 {
  width: 100%;
  font-size: 22px;
}
#guidance p.cont_2txt5 {
  position: absolute;
  top: 670px;
  left: 70px;
  line-height: 1.4em;
  width: 500px;
  text-align: center;
  font-size: 28px;
  overflow: hidden;
}
#guidance p.cont_2txt5 span {
  font-weight: bold;
}

#guidance .cont_2 table{
  margin: -150px auto 0;
  font-size: 24px;
  text-align: left;
  line-height: 1.5em;
  border-collapse: collapse;
  border-bottom: 1px solid #cdcdcd;
}

#guidance .cont_2 table.cont2_table{
  margin: 50px auto 30px;
}

#guidance .cont_2 table th {
  padding: 10px;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  color: #010100;
  line-height: 1.5em;
  vertical-align: bottom;
  width: 16%;
}
#guidance .cont_2 table tbody th {
  text-align: left;
  background: #fff;
  border-top: 1px solid #cdcdcd;
  width: 36%;
}
#guidance .cont_2 table thead th img {
  width: 100%;
  height: auto;
}
#guidance .cont_2 table th small {
  font-size: 22px;
  font-weight: normal;
  }
#guidance .cont_2 table td {
  padding: 10px 0;
  font-size: 25px;
  text-align: center;
  line-height: 1.5em;
  background: #fff;
  border-top: 1px solid #cdcdcd;
  width: 16%;
 }
#guidance .cont_2 table td.age0 {
  color: #ff83a8;
  font-size: 20px;
  background: #fff8fa;
}
#guidance .cont_2 table td.age1 {
  color: #faaf3b;
  font-size: 20px;
  background: #fff8ef;
}

#guidance .cont_2 table td.age2 {
  color: #29aae1;
  font-size: 20px;
  background: #eaf7fc;
}
#guidance .cont_2 table td.age3 {
  color: #c993c6;
  font-size: 20px;
  background: #f3e6f2;
}

#guidance .cont_3 {
  position: relative;
  margin-top: 30px;
  
}
#guidance .cont_3 div.inner {
  position: absolute;
  top: 200px;
  margin-left: -10px;
  margin-right: -10px;
}

#guidance .cont_3 ul {
  position: absolute;
  font-size: 16px;
  left: 20px;
  line-height: 160%;
  width: 600px;
  margin: 0 10px;
  padding: 15px;
  text-align: left;
  vertical-align: top;
  box-sizing: border-box;
}

#guidance .cont_3 li {
  display: inline-block;
  padding: 2px 5px;
  padding-left: 1.5em;
  text-indent: -1em;
  font-size: 28px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5em;
  color: #000000;
}

#guidance .cont_3 ul.cont_3t1 {
  top: 110px;
}
#guidance .cont_3 ul.cont_3t2 {
  top: 810px;
}
#guidance .cont_3 ul.cont_3t3 {
  top: 1400px;
}
#guidance .cont_3 ul.cont_3t4 {
  top: 1910px;
}

#guidance .cont_3 li:before {
  content: "●";
  color: #faaf3b;
  margin-right: 5px;
  font-size: 88%;
}
#guidance .cont_3 p {
  margin-bottom: 15px;
  font-size: 28px;
  text-align: center;
  line-height: 1.5em;
  color: #000000;
  }





#access .visual {
}
#access .access{
  margin: 0 30px;
}
#access .access > img{
}
#access .access .address{
  text-align: left;
  font-size: 30px;
  line-height: 160%;
}
#access .access .box{
  font-size: 24px;
  line-height: 160%;
  margin-top: 10px;
  text-align: left;
}
#access .access .box:after{
  content: '';
  display: block;
  clear: both;
}
#access .access .box img{
  float: left;
  padding-right: 18px;
}
#access .access .box span{
  display: block;
  font-weight: bold;
}
#access #idx_map{
  width: 100%;
  height: 380px;
  overflow: hidden;
  border-radius: 6px;
  margin-top: 40px;
}
#access #idx_map *{
  line-height: 160%;
}


/*ブログ */
#blog .visual{
  margin-top: 20px;
}
#blog .cont {
}
#blog .cont .box{
    text-align: left;
    margin: 30px 30px 0;
}
#blog .cont .box h2{
    background-color: #ff9900;
    font-size: 32px;
    line-height: 100%;
    font-weight: normal;
    color: #ffffff;
    padding: 14px 30px 42px;
    border-radius: 8px;
    position: relative;
}
#blog .cont .box h2 span{
    position: absolute;
    bottom: 14px;
    right: 30px;
    font-size: 20px;
    line-height: 100%;
}
#blog .cont .box p{
    font-size: 18px;
    line-height: 220%;
    padding: 30px;
    word-break: break-all;
}
#blog .cont .box p img{
    display: block;
    width: 100%;
    margin: 30px 0;
    border-radius: 10px;
}
#blog .cont .box figure {
	margin: 20px 0 0;
}
#blog .cont .box figure.alignleft {
	text-align: left;
}
#blog .cont .box figure.aligncenter {
	text-align: center;
}
#blog .cont .box figure.alignright {
	text-align: right;
}
#blog .cont .box figure img {
	max-width: 100%;
	height: auto;
}
#blog .cont .box figure figcaption {
	font-size: 16px;
	line-height: 1.6;
	margin: 4px 0 0;
}
#blog .cont .box figure.wp-block-embed-youtube iframe {
	max-width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
}
#submenu_blog{
    margin-top: 70px;
}
#submenu_blog > img{
}
#submenu_blog ul{
    background: url('images/blog_s/bg.png') repeat center center;
    padding: 5px 0 4px;
    text-align: left;
}
#submenu_blog ul li{
    background-color: #ffffff;
    margin-bottom: 2px;
    font-size: 20px;
    line-height: 100%;
    padding: 18px 0 16px 32px;
    z-index: 1;
    position: relative;
}
#submenu_blog ul li.idx{
    font-size: 22px;
    line-height: 100%;
    margin-bottom: 5px;
    padding: 18px 0 18px 18px;
    font-weight: bold;
}
#submenu_blog ul li a{
    color: #030303;
}
#submenu_blog ul li a:before{
    content: url('images/blog_s/ar_r.png');
    padding: 0px 8px 2px 0;
    display: inline-block;
    vertical-align: middle;
}
#submenu_blog ul li.idx a:before{
    content: url('images/blog_s/ar_d.png');
}






#idx .posts {
	text-align: center;
	width: 100%;
	max-width: 1000px;
	margin: 20px auto 0;
}
#idx .posts h1 {
	font-size: 32px;
	line-height: 1;
	font-weight: bold;
	padding: 25px 0 20px;
	color: #f39f10;
	font-family: "ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO";
}
#idx .posts article {
	padding: 20px 0 0;
}
#idx .posts article a {
	display: inline-block;
	vertical-align: top;
	width: calc(50% - 40px);
	margin: 0 15px 40px;
	text-align: left;
}
#idx .posts article a figure {
	margin: 0;
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	position: relative;
	border-radius: 6px;
	overflow: hidden;
}
#idx .posts article a figure::after {
	content: attr(data-category);
	font-size: 18px;
	line-height: 1;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 1;
	color: white;
	padding: 5px 12px;
	border-radius: 0 4px 0 0;
}
#idx .posts article a figure[data-category="日記"]::after {
	background: #5555e0;
}
#idx .posts article a figure[data-category="給食"]::after {
	background: #e75959;
}
#idx .posts article a h2 {
	font-size: 20px;
	line-height: 1;
	font-weight: bold;
	color: #333;
	margin: 10px 0 0;
}
#idx .posts article a .date {
	font-size: 16px;
	line-height: 1;
	color: #333;
	margin: 9px 0 0;
}
#idx .posts .more {
	font-size: 16px;
	line-height: 1;
	color: #333333;
	background: lightgrey;
	padding: 11px 40px;
	display: inline-block;
	margin: 20px 0 0;
	border-radius: 4px;
}



.has-dark-gray-color {
	color: #1a1a1a;
}
.has-dark-gray-background-color {
	background-color: #1a1a1a;
}
.has-medium-gray-color {
	color: #686868;
}
.has-medium-gray-background-color {
	background-color: #686868;
}
.has-light-gray-color {
	color: #e5e5e5;
}
.has-light-gray-background-color {
	background-color: #e5e5e5;
}
.has-white-color {
	color: #fff;
}
.has-white-background-color {
	background-color: #fff;
}
.has-blue-gray-color {
	color: #4d545c;
}
.has-blue-gray-background-color {
	background-color: #4d545c;
}
.has-bright-blue-color {
	color: #007acc;
}
.has-bright-blue-background-color {
	background-color: #007acc;
}
.has-light-blue-color {
	color: #9adffd;
}
.has-light-blue-background-color {
	background-color: #9adffd;
}
.has-dark-brown-color {
	color: #402b30;
}
.has-dark-brown-background-color {
	background-color: #402b30;
}
.has-medium-brown-color {
	color: #774e24;
}
.has-medium-brown-background-color {
	background-color: #774e24;
}
.has-dark-red-color {
	color: #640c1f;
}
.has-dark-red-background-color {
	background-color: #640c1f;
}
.has-bright-red-color {
	color: #ff675f;
}
.has-bright-red-background-color {
	background-color: #ff675f;
}
.has-yellow-color {
	color: #ffef8e;
}
.has-yellow-background-color {
	background-color: #ffef8e;
}