@charset "utf-8";
/* CSS Document */
body {
  margin: 0;
  padding: 0;
  font-family: YuMincho, 'Yu Mincho', 'Hiragino Mincho ProN', 'serif';
  overflow-x: hidden;
  box-sizing : border-box;
}
a {
  text-decoration: none;
}

a.no-color-change {
  color: #A07A59;
}

.container {
  max-width: 100%;
  margin: 0 auto;
}

.pon10 {margin-top: 10px;}
.pon20 {margin-top: 20px;}
.pon30 {margin-top: 30px;}
.pon40 {margin-top: 40px;}
.pon50 {margin-top: 50px;}
.pon100 {margin-top: 100px;}
.pon150 {margin-top: 150px;}
.pen {margin: 0 8px;}
.pen16 {margin: 0 16px;}
.pun {margin: 8px 0;}
.pun16 {margin: 16px 0;}
.pennotice0 { 
	margin: 0; 
	padding: 0;
}
.not-list {
	width: 100%;
    padding: 0;
}
.not-list1 {
	width: 100%;
	margin-left: 20% ;
    padding: 0;
}
.not-list2 {
	width: 100%;
	margin-left: 25% ;
    padding: 0;
}
.not-list3 {
	width: 100%;
	margin-left: 26% ;
    padding: 0;
}
.not-list4 {
	width: 100%;
	margin-left: 10% ;
    padding: 0;
}
@media screen and (max-width: 420px) {
	
#wrappe .logoid  { display: none; }
        .telid   { display: none; }
	
.logote { 
	width: 120px;
	height: auto;
	margin: 0  auto 0 33% ;
	    }
 #headernav { display: none; }	
	
.finnav {
  max-width: 100%;
  height: 106px;
  background: #fff;
  position: fixed;
  padding: 0 20px;
  top: 0;
  left: 0;
  z-index: 800;
}
	.imgbo{
      border-radius: 10%;
    }
.imgbo001{
     border-radius: 10%;
    }

/* ナビ */
.fixed_btn { 
    position: fixed;
    top: 57px;
	left: 77%;
    padding: 1px;
	background: #e87a87;
	border-radius: 40px;
    z-index: 1000;
}

.hamburger {
    display: block;
    height: 46px;
    margin-left: auto;
    position: relative;
    z-index: 10;
    width: 46px;
    border: none;
    background-color: transparent;
}
.hamburger.-active .hamburger__line {
    background-color: transparent;
}
.hamburger.-active .hamburger__line::before {
    top: 0;
    transform: rotate(45deg);
}
.hamburger.-active .hamburger__line::after {
    top: 0;
    transform: rotate(-45deg);
}
.hamburger.-active .hamburger__text::before {
  content: '閉じる';
}
.hamburger__line {
    display: block;
    height: 2px;
    position: absolute;
    top: 18px;
    left: 50%;
    transform: translateX(-50%);
    width: 24px;
    background-color: #fff;
    transition: 0.4s;
}
.hamburger__line:before,
.hamburger__line:after {
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    width: 100%;
    background-color: #fff;
    transition: inherit;
}
.hamburger__line:before {
    top: -6px;
}
.hamburger__line:after {
    top: 6px;
}
.hamburger__text {
    position: absolute;
    bottom: 8px;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
}
.hamburger__text::before {
    content: "menu";
    text-align: center;
    color: #fff;
    font-size: 10px;
    font-weight: 900;
}
.header {
  width: 300px;
}
.header__nav-area {
    position: fixed;
    top: 0;
    left: -100%;
    z-index: 9;
    height: 100vh;
    width: 90%;
    visibility: hidden;
    padding-top: 10px;
    background-color: #fef2de;
    transition: 0.4s;
}
	
.reason { 
	font-size: 8px; 
	font-family: 'Caveat', cursive;
	width: 100px;
	height: auto;
	text-align: left; 
}
	
.header__nav-area.-active {
    left: 0;
  visibility: visible;
}
.global-navigation {
    padding-top: 40px;
    padding-right: 65px;
    padding-bottom: 120px;
    padding-left: 25px;
}
.global-navigation__list > li {
    padding-bottom: 20px;
    border-bottom: 2px solid #fff;
	list-style:none;
}
.global-navigation__list > li + li {
    margin-top: 20px;
}
.global-navigation__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: #000;
    font-weight: 900;
    transition: color 0.4s;
    font-size: 0.875rem;
}
.global-navigation__link.-accordion {
    position: relative;
    background: none;
    border: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%;
    padding: 0;
}
.global-navigation__link.-accordion::after {
    content: '';
    display: block;
    height: 12px;
    position: absolute;
    top: 50%;
    right: 5px;
    width: 2px;
    background-color: #ed3242;
    transform: translateY(-50%);
    transition: transform 0.4s;
}
.global-navigation__link.-accordion::before {
    content: '';
    display: block;
    height: 2px;
    position: absolute;
    top: 50%;
    right: 0;
    width: 12px;
    background-color: #ed3242;
    transform: translateY(-50%);
    
}
.global-navigation__link.-active::after {
  transform: translateY(-50%) rotate(-90deg);
}
.accordion {
    height: 0;
    overflow: hidden;
    visibility: hidden;
    transition: 0.4s;
}
.accordion.-active {
    height: auto;
    padding-top: 30px;
    visibility: visible;
}
.accordion__list li {
    font-size: 0.75rem;
	
}
.accordion__list li + li {
     margin-top: 21px;
}
.accordion__link {
    color: #172e59;
}
.topmenumo { font-size: 10px; }
	
ul{ padding-left:0; }
h10 {
	font-size: 19px;
	font-weight:bold;
	color: #FF7B24;
}
.topind {
	width: 100%;
	padding: 0;
	margin: 60px auto 0 auto;
    display:flex;
    justify-content: center;
}
	
.topind2 {
	width: 100%;
	padding: 0;
	margin: 0 auto 60px auto;
    display:flex;
    justify-content: center;
}
	
	.sukima {
		padding-top: 45px;
	}
	
.topindex0 {
    display: none;
}
	
.butaida {
	max-width: 100%;
	height: auto;
    display:inline-block;
    text-align:left;
	padding: 2px 0;
	margin: 0 0 0 2%;
}	
	
.fot_01 { font-size:  22px; letter-spacing: 1px; }	

.staffintro {
	   width: 100%;
	   height: auto;
	   margin:  20px auto 50px auto;
}
.staffintro2 {
	   width: 100%;
	   height: auto;
	   margin:  20px auto 50px auto;
}
.staffintro3 {
	   width: 100%;
	   height: auto;
	   margin:  0 auto 20px auto;
}
	
.mateintro {
	   width: 100%;
	   height: auto;
	   margin:  550px 0 10px 0;
	   padding: 0;
}
	
.progtop {
	   width: 80%;
	   height: auto;
	padding: 0;
	   margin:  0 auto 100px auto;
}
.introinde {
	   width: 100%;
	   height: 450px;
	   margin:  0;
	}
.introinde2 {
	   width: 100%;
	   height: auto;
	   margin:  -50px 0 50px 0;
	   padding: 0;
	}
	
.aboutintro {
	   width: 100%;
	   height: 160px;
	   margin:  20px auto ;
}
.aboutintro1 {
	   width: 100%;
	   height: 380px;
	   margin:  0;
	   padding: 0;
}
.aboutintro2 {
	   width: 100%;
	   height: 320px;
	   margin:  0;
	   padding: 0;
}
.aboutintro3 {
	   width: 100%;
	   height: 300px;
	   margin:  0;
	   padding: 0;
}
	
.firs1 {
	   width: 90%;
	   height: auto;
	   margin:  0 auto -100px auto;
	   padding: 0;
}
	
.noticeintro {
	   width: 100%;
	   height: auto;
	   margin:  10px auto ;
}
.noticeintro1 {
	   width: 100%;
	   height: 500px;
	   margin:  20px auto 0;
}
	
.yokonarabi{
    display:flex;
    height:auto;
	padding: 10px;
  margin-bottom:10px;
}
	
/*introポップアップ*/
.tmb {
  width: 48%;
  padding: 10px;
  margin: 0 auto;
}
.tmb2 {
  width: 100%;
  padding: 10px;
  margin: 0 auto 3rem;	
}
.tmb3 {
  width: 95%;
  padding: 10px;
  margin: 0 auto;
}

.tmb_img {
  width: 100%;
  height: auto;
}
.tmb_img:hover {
  transform: translateY(-5px);
}
.popup {
  z-index: 10;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  background-color: rgba(0, 0, 0, 0.8);
  opacity: 0;
  transition: opacity 0.3s, transform 0s 0.3s;
}
.popup__btn {
  display: block;
  z-index: 13;
  position: absolute;
  top: 1vh;
  right: 1vh;
  width: 5vh;
  height: 5vh;
  cursor: pointer;
}
.popup__btn::before,
.popup__btn::after {
  position: absolute;
  top: 50%;
  width: 100%;
  height: 2px;
  margin-top: -1px;
  background-color: #fff;
  content: '';
}
.popup__btn::before {
  transform: rotate(45deg);
}
.popup__btn::after {
  transform: rotate(-45deg);
}
.popup__btnarea {
  z-index: 12;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.popup__img {
  z-index: 11;
  position: absolute;
  top: 5%;
  left: 5%;
  width: 90%;
  height: 90%;
}
.popup__img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
input[type="checkbox"] {
  display: none;
}
input[type="checkbox"]:checked ~ .popup {
  transform: scale(1);
  opacity: 1;
  transition: opacity 0.3s;
}
.ooo {
	transition: all .3s ease-in-out;
}
.ooo:hover  {
	box-shadow: 0 0 15px rgba(0,0,0,.25);
}
.imgshadow {
        filter: drop-shadow(3px 3px 3px rgba(160, 160, 160, 0.6));
}

.noticetop {
	   width: 90%;
	   height: 80vh;
	   padding: 0 10px;
	   margin:  20px auto;
}
	
	
h11 {
  font-size: 18px;
  font-weight: bold;
  padding: 0.5em;/*文字周りの余白*/
  display: inline-block;/*おまじない*/
  line-height: 1.5;/*行高*/
  vertical-align: middle;
  border-radius: 25px 0 0 25px;/*左側の角を丸く*/
}
h11:before {
  content: '●';
  color: white;
  margin-right: 18px;
}
.hp0mo {
  color: #505050;/*文字色*/
  background: #dbebf8;/*背景色*/
}
.ribbon  { display: none; }
.ribbonss {
  width: 100%;
  background: #ffcc99;
  padding: 15px 0;
  margin: 20px 0 10px 0;
  color: #fff;
  font-size: 16px;
  text-align: center;
  letter-spacing: 1.5px;
  line-height: 30px;
  font-weight:bold;
	}
	
.flex_01 {
    display: flex;/*コレ*/
    padding: 0 ;
    justify-content: center;/*コレ*/
    align-items: center;/*コレ*/
}
.flex_01 div{
    width: 100%;
    margin: 0;
    padding: 10px;
}
.flex_01img{
	background-repeat: no-repeat;
}
	
.about2 {
	width:100%;
    height: 800px;
    padding: 0 10px;
	margin: 0 auto;
	text-align: center;
	}
.about2_img {
	width: 70%;
	height: auto;
	margin: 0 auto;
	padding: 2px;
	}	
	
.about2_1 {
	width:100%;
	padding: 10px;
	}	
.about2_2 {
	width: 90%;
	height: auto;
    padding: 10px;
	margin: 0 auto;
	}	
.parent{
  position:relative;
  top: -220px;
  left: -1%;
  width:180px;
  height:180px;
  background-size: contain;
  background-image:url("../img/top300.png");
}
.children1{
  position:relative;
  background-size: contain;
  top:120px;
  left: -15px;
  width:120px;
  height:120px;
  background-image:url("../img/top200.png");
}

.children2{
  position:relative;
  background-size: contain;
  top:20px; 
  left:90px;
  width:80px;
  height:80px;
  background-image:url("../img/top150.png");
}	
.featwa2 {
	wax-width: 100%;
	height: 260px;
	background: #FFFAFA;
	padding: 20px 0 50px 0;
	margin: 0;
    }
.featwa4 {
	wax-width: 100%;
	height: auto;
	background: #FFFAFA;
	padding: 40px 0 20px 0;
	margin: 100px 0 0 0;
    }
.featwa5 {
	wax-width: 100%;
	height: auto;
	background: #FFFAFA;
	padding: 40px 0 60px 0;
	margin: 1px 0 -150px 0;
    }
	
.about1 {
	width: 100%;
	height: 550px;
	background: #FFFAFA;
	padding: 30px 0 0 0;
	margin : 60px 0 0 0;
    }
	
.imgfre01 {
	width: 100%;
	height: auto;
	padding: 0;
	margin:  0;
}
.imgfre011 {
	width: 60%;
	height: auto;
	padding: 0;
	margin:  0 ;
}
	
.mamshi2 {
	width: 100%;
	height: 280px;
	margin:  0;
	padding: 30px 0 ;
	background-color: #fff5f3;
}
.mamshi3 {
	width: 100%;
	height: 490px;
	margin:  50px 0 -70px 0;
	padding: 40px 0 0 0;
	background-color: #fff5f3;
}	
	
.imgmater {
	width: 90%;
	height: auto;
	margin:  0 0 0 5%;
}
.wave {
	margin-top:  20px;
	width: 100%;
    background:repeat-x bottom left / auto;
	background-image: url(../img/parts.png);
    height:100px;
    background-position: 0 0, 10% 10%;
	}
.wavep {
	font-size: 21px;
	font-weight:bold;
	color: #FF7B24;
	text-align: center;
	padding: 80px 0 0 1px;
}
.wavep2 {
	font-size: 21px;
	font-weight:bold;
	color: #FF7B24;
	text-align: center;
	padding: 20px 0 0 1px;
	margin-bottom: -100px;
}
	
.heading-20 {
    padding: .5em .7em;
    background-image: repeating-linear-gradient(-45deg, #FFF0E0, #FFF0E0 3px, #FFD1C6 3px, #FFEFEB 7px); 
	text-align: center;
}
.flexbox {
	width: 100%;
	height: 760px;
	margin:  80px 0 0 0;
	padding: 0;
	gap : 40px 1px;
}
.flexbox01 {
	width: 100%;
	height: 990px;
	margin: 0;
	gap : 20px 1px;
}
.flexbox_02 {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
}
	
.mannak {padding:  12px 20%;
		margin: 0 auto 0 auto;}
	
.hellim {padding:  0;
		margin: 200px 0 0 18%;}
	
.item1 {
  width: 90%;
  margin: 30px auto 0 auto;
padding: 6px;
  text-align: center;
  background-color: #fff5f3;
  border-radius: 20px;
}
.item01h, .item1, .item12 {
  padding: 0 2px;
  border: 10px double #fff;
}
.item12 {
  width: 90% ;
  margin: 30px auto 0 auto;
  padding: 6px;
  background-color: #fff5f3;
  border-radius: 20px;
}

.item5 {
  width: 30%;
  margin: 0 auto;
  text-align: center;
  background-color: #fff5f3;
  border-radius: 20px;
}
	
 .item01 {
	 width: 100%;
  margin: 10px auto;
  text-align: center;
  background-color: #fff5f3;
  border-radius: 20px;
	margin-bottom: 10px;
}
.item01h{
	height: 250px;
	height: auto;
  padding:  6px;
  border: 8px double #fff;
}
.item02h{
	height: auto;
  padding: 0 2px;
  border: 8px double #fff;
}
	
.item01 img {
  max-width: 100%;
  height: auto;
}
	
.item02 {
    width: 48%;
	text-align: center;
}
.item02 p {
	padding: 10px auto 0 auto;
    text-align: center;
	line-height: 0.1;
	margin-bottom: 10px;
}	
.item02 img {
  max-width: 100%;
  height: auto;
}
.item06, .item08 {
    width: 60%;
	margin: 0 auto;
	text-align: center;
}
.item06 img {
  max-width: 100%;
  height: auto;
}
.item08 {
    width: 100%;
	margin: 0;
	text-align: center;
}	
.item08 img { 
  max-width: 100%;
  height: auto;
}

.item01pp {
	width: 100%;
	padding: 0 ;
	margin: 0 auto;
    text-align: center;
	line-height: 1.3;
}	
 .text01 br {
    display: none;
  }	
	
.first_1 {
		height: 1050px;
	}
.box3hp4 {
	width: 80%;
    padding: 0.8em 1.5em -2.5em 1.5em;
    margin: 70px auto 70px auto;
    border: solid 1px #fb9039;
	background-color: #fffaf9;
	border-radius: 15px;
}
	
.box3hp3 {
	width: 99%;
	height: 260px;
    padding: 1.0em 1.5em;
	margin: 35px 0 100px -7%;
    border: solid 1px #fb9039;
	background-color: #fffaf9;
	border-radius: 10px;
}
.ago2 {
	margin-bottom:  30px;
}
.prewaku {
	width: 98%;
	height: 600px;
	margin: 30px auto 0;
	padding: 10px 0 0 0;
}

.matewaku {
	width: 98%;
	height: auto;
	margin: 0;
	auto: 35px auto;
	padding: 10px 0 0 0;
}
	.helloimg  {
		width: 45%;
		height: auto;
		margin: 0 auto;
	padding:200px 30%;
    position: absolute;
}
.staffmo {
  font-size:  14px;
  text-align: left; 
  color: #A07A59;
  letter-spacing: 0.16em;
  line-height: 1.6em;
  display: inline-block;
}

.firstwaku {
	width: 98%;
	height: auto;
	margin: 0;
	auto: 35px auto;
	padding: 10px 0 0 2px

}
.featwa3 {
	width: 100%;
	height: 7200px;
	background: #FFFAFA;
	padding: 50px 0 0 0;
	margin-top:  -150px;
    }
.float01 {
	width:60%;
	height: auto;
	padding:0;
    margin: 180px auto 0 18
		%;
    position: absolute;
}
.float02 {
	width:60%;
	height: auto;
	padding:10px 20%;
    margin: 180px 0 0 auto;
    position: absolute;
}

.firstha {
	width: 100px;
	height: auto;
    float: center;
	padding: 6px;
	display: block;
    margin-left: auto;
    margin-right: auto;
}
	
.float {
	width: 120%;
	height: auto;
    float: right;
    margin: 260px  85% 60px 0;
}
figure {
  float: center;
  margin: 0 15px 15px 0;
  width: 30%;
}	
.hellokidswaku {
	width: 100%;
	height: 230px;
}
.hellokidswaku01 {
	width: 100%;
	height: auto;
	margin: 60px 0 -140px 0;
	padding: 0;
}
.hellokidswaku02 {
	width: 100%;
	height: 390px;
	margin: 60px 0;
}
	
.cp_hr03 {
	border-bottom: 2px dotted #3CB371;
}
	
.firstti {
	font-size: 16px;
	font-weight:bold;
	color: #3CB371;
	text-align: center;
    padding-bottom: 30px;
	letter-spacing: 0.1em;
	padding: 10px 0 20px 0;
}
.featwa {
	width: 100%;
	height: auto;
	background: #f9ffee;
	padding-bottom: 45px;
    border-radius: 160px 160px 0 0;
	}
	
.abouwaku {
	width: 90%;
	height: auto;
	margin: -10px auto -10px 15%;
	padding: 2px;
}
.firsttop {
	width: 100%;
	height: 300px;
	margin:  500px auto 0 0;
}
.firsttop2 {
	width: 100%;
	height: 450px;
	background: #fff;
	margin:  15px auto 0 0;
}
	.firsttop2_0 {
	width: 100%;
	height: 440px;
	background: #fff;
	margin:  450px auto 0 0;
		padding: 0;
}

.firsttop3 {
	width: 100%;
	height: 300px;
	background: #fff;
	margin:  100px 0;
}
.firsttop4 {
	width: 100%;
	height: 300px;
	background: #fff;
	margin:  100px 0;
}

.prevewa {
	wax-width: 100%;
	height: auto;
	background: #FFFAFA;
	padding: 140px 0 120px 0;
	margin-bottom: 100px 0 0 0;
    }
	
.abouttop1 {
	width: 100%;
	height: 2050px;
	background: #fff;
	margin:  15px auto 0 0;
}
	
/*お知らせぺージ*/
.notspace {
	width: 100%;
	height: 550px;
	margin : 0 0 0 0;
	padding: 1px 0 0 0;
}
.notspace01 {
	width: 100%;
	height: 650px;
	padding-top: 1600px;
	margin : 0;
	padding: 0;
}
.notspace02 {
	width: 100%;
	height: 630px;
	margin : 60px 0 -100px 0;
	padding: 0;

}
.notspace03 {
	width: 100%;
	height: 1100px;
	margin : -10px 0 0 0;
	padding: 1px 0;
}
.notspace04 {
	width: 100%;
	height: 550px;
	margin :  0;
	padding:  0;
}

.noti01 {
	width: 100%;
	height: 500px;
	padding:  20px;
	margin-bottom: 5%;
}
.noti03 {
	width: 100%;
	height: 550px;
	padding:  60px 0 -20px 0;
	background-image: repeating-linear-gradient(135deg, #f1fef9, #f1fef9 2px, #f5fbfe 2px, #ebf9ff 6px);
}	
	
.noti02 {
	width: 100%;
	height: 500px;
	padding:  580px 0 0 0;
	margin-bottom: 5%;
}
	
.noticetop {
	   width: 80%;
	   height: auto;
	   padding: 0 2px;
	   margin:  0 auto;
}
.imgnoti {
	width: 150px;
	height: 150px;
	margin: 30px 1% 0 0;
}
.imgnoti2 {
	width: 150px;
	height: 150px;
	margin: -200px 30%;
}
.imgnoti3 {
	width: 200px;
	height: 200px;
	margin:  100px 0 0 -80px;
}
.imgnoti4 {
	width: 210px;
	height: 210px;
	margin:  -30px 0 0 4%;
}

.imgnoti5 {
	width: 280px;
	height: 280px;
	margin: -320px 0 0 40%;
}
.imgnoti6 {
	width: 200px;
	height: 200px;
	margin:  -70px 0 0 1%;
}
.imgnoti7 {
	width: 200px;
	height: 200px;
	margin: -30px 0 0 40%;
}
.imgnoti8 {
	width: 200px;
	height: 200px;
	margin:  10px 15% 0 0;
}
.imgnoti9 {
	width: 180px;
	height: 180px;
	margin: -40px 45% 0 0;
}
.imgnoti_01 {
		width: 60%;
		height: auto;
		padding: 0 60px 50px;
       }
	
.notimo {
	font-size: 18px;
	font-weight:bold;
}

.intromo {
  font-size:  clamp(12px, 1.4vw, 15px);
  font-weight: 500;
  color: #A07A59;
	margin-bottom: 2px;
  letter-spacing: 0.05em;
  line-height: 1.0em;
}

.boxs05 {
	width: 100%;
	height: auto;
	padding: 20px auto;
    display: flex;
    align-items: stretch;
}
	
.materimag_01 {
	width: 100%;
	height: auto;
	}

a.btn_01 {
	display: block;
	text-align: center;
	vertical-align: middle;
	text-decoration: none;
	width: 100px;
	margin: auto;
	font-size: 15px;
	padding: 10px 35px;
	margin-bottom: 40px;
	font-weight: bold;
	color: #A07A59;
	background: #FFFFFF;
	border-bottom: 2px solid #A07A59;
	border-radius: 100vh;
	box-shadow: 0 2px 7px rgba(0, 0, 0, .3);
	-webkit-box-shadow: 0 2px 7px rgba(0, 0, 0, .3);
	transition: 0.5s;
}

a.btn_01:hover {
	color: #e07483;
	background: #fef0db;
	border-bottom: 2px solid #ebb0c1;
	transform: translateY(3px);
}	
	
.ago {
	margin-bottom: -10px;
}

	
/* 手書きノート風 */
.box3-9 {
    margin: 0 auto 2em; /* 外側の余白（上下と中央配置） */
    padding: 3em 2em 2em; /* 内側余白（上・左右・下） */
    position: relative;
    background: #f4f3f2; /* 背景色（ノート風の淡い色） */
}

.box3-9::before {
    content: '';
    position: absolute;
    inset: 0.5em 0 0 0; /* 上から0.5em、左右と下を0に */
    margin: 0 auto; /* 水平方向中央揃え */
    width: 95%; /* ドット線の横幅 */
    border-top: dotted 10px #fff; /* ドット線（太さ10px、白） */
}
.feat {
	width: 100%;
	height: 1600px;
	margin:  100px auto;
}
.prgind {
	width: 100%;
	height: 380px;
	margin:  30px 0;
}
.mateind {
	width: 100%;
	height: 200px;
	margin:  80px 0 -60px 0;
	padding: 0;
}

.fisttop {
	width: 100%;
	height: 1250px;
	margin:  100px auto 0 auto;
}
	
.feat2 {
	width: 100%;
	height: 100vh;
	margin:  30px 0 10px 0;
	padding: 0 0 200px 0;
}
.feat3 {
	width: 100%;
	height: 650px;
	margin:  800px auto 0 auto;	
}
.feat4 {
	width: 100%;
	height: 300px;
	margin:  20px auto 10px auto;
}

.feat1 {
	width: 100%;
	height: 900px;
	margin:  0 auto;
}
.flexbox_01 {
	width: 100%;
	height: auto;
	padding: 0;
	margin:  20px 0 20px 0;
}
 .item10 {
    width: 70%;
	 height: auto;
	margin:  0 auto;
	padding: 20px 60px;
	 text-align:  center;
  }

	.notind_1 {
		width: 100%;
		height: 300px;
		margin:  0 0 0 0;
		padding: 0 0 0 0;
	}
	.notind_2 {
		width: 100%;
		height: 600px;
		margin:  350px 0 -800px 0;
		padding: 0;
	}
	.notind_3 {
		width: 100%;
		height: 620px;
		margin:  250px 0 0 0;
		padding: 0 0 0 0;
	}

.prefeat {
	width: 100%;
	height: 330px;
	margin:  0;
	padding: 0;
}
.stafeat {
	width: 100%;
	height: 4600px;
	margin:  0 auto;
	padding: 0;
}
.intfeat {
	width: 100%;
	height: 2100px;
	margin:  0 auto;
	padding: 0;
}
	
.focus { 
	margin: 6px;
	border: 0px solid #fceffc;
  -webkit-transition: all 0.5s ease;
     -moz-transition: all 0.5s ease;
       -o-transition: all 0.5s ease;
      -ms-transition: all 0.5s ease;
          transition: all 0.5s ease;
}
  
.focus:hover {
  border: 2px solid #FF7B24;
  border-radius: 50%;
}
	
	
.imgcenter {
	 margin: 0 auto;
     display: block; 
	 padding: 0;
}
.h8waku {
		text-align: center;
	    margin-top: 36px;
}
	
h8,h9,h12 {
	font-size: 18px;
	font-weight:bold;
	color: #FF7B24;
}
.tokumo {
	font-size: 18px;
    font-family:"Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体";
	font-weight:bold;
	letter-spacing: 0.1em;
}
	
.imgin_01 {
	width: 200px;
	height: 200px;
	padding: 0px;
}
			
.Ab_1 {
    background-image:
			radial-gradient(1000px 980px , rgba(123,222,217, 0.1) 20%, transparent 20%),
			radial-gradient(700px 730px , rgba(123,222,217, 0.2) 20%, transparent 20%);
	background-size: 100% auto,;
    animation: Grad 2.3s linear infinite;
    animation-delay: 0.5s;
}
.Ab_2 {
    background-image: repeating-linear-gradient(45deg, currentColor 0, currentColor 1px, transparent 0, transparent 50%);
    background-size: 10px 10px;
    color: rgba(123,222,217, 0.1) !important;
}
	
.Ab_3 {
    background-image:
			radial-gradient(750px 750px , rgba(123,222,217, 0.1) 20%, transparent 20%);
		/*background-size: 
			1030px 980px;
		background-position: 
			50px 410px;
		animation: Grad 25s ease infinite;*/
}
.Ab_4 {
    background-image: radial-gradient(currentColor 1px, transparent 1px);
    background-size: calc(10 * 1px) calc(10 * 1px);
    color: rgba(123,222,217, 0.1) !important;
}
	
.Ab_5 {
	  background-image: linear-gradient(360deg, rgba(230, 247, 255, 1), rgba(186, 248, 225, 0.3));
}
.Ab_6 {
	  background-color:  rgba(255,255,255, 0.6);
}
.Ab_7 {
    background-image: radial-gradient(currentColor 1px, transparent 1px);
    background-size: calc(10 * 1px) calc(10 * 1px);
    color: rgba(255,255,255, 0.9) !important;
}
.Ab_8 {
    background-image: repeating-linear-gradient(45deg, currentColor 0, currentColor 1px, transparent 0, transparent 50%);
    background-size: 10px 10px;
    color: rgba(246,207,211, 0.5) !important;
}
.Ab_9 {
	  background-image: linear-gradient(359deg, #ffffff, #baf8e166 50%,#dbfff152 );
}
.sasscode {
	background-size: auto auto;
    background-color: rgba(255, 226, 226, 0.6);
    background-image: repeating-linear-gradient(45deg, transparent, transparent 3px, rgba(255, 243, 243, 0.6) 3px, rgba(255, 243, 243, 0.6) 6px );
}
	
.box-016 {
    position: relative;
    max-width: 800px;
    margin: 3em auto;
    padding: 1em 2.5em 1em 1.5em;
    border-radius: 3px;
    box-shadow: 0 2px 3px rgb(0 0 0 / 20%);
	background-color: #ffffff;
    background-image: linear-gradient(90deg, #fffaf080 13px, transparent 13px), linear-gradient(#fffaf080 13px, transparent 13px);
    background-position: 10px 10px;
    background-size: 26px 26px;
}
.box-016::before,
.box-016::after {
    position: absolute;
    content: '';
}
.box-016::before {
    top: -15px;
    right: 10px;
    height: 50px;
    width: 15px;
    border: 3px solid #999;
    border-radius: 10px;
    box-shadow: 1px 1px 2px rgb(0 0 0 / 30%);
    transform: rotate(10deg);
}
.box-016::after {
    top: 0;
    width: 10px;
    right: 20px;
    border: solid 5px #fffaf0;
}

  .item {
	   width: 50%;
	  margin: 0 auto 40px auto;
	  list-style:none;
     float:left;
    text-align: center;
	}

	.intimg {
		width: 80%;
		height: auto;
	}
.item p {
	padding: 15px auto 0 auto;
    text-align: center;
	line-height: 1.0;
}	
.staffmo00 {
  font-size:  15px;
  text-align: left; 
  color: #A07A59;
  letter-spacing: -0.1em;
  line-height: 1.1em;
}

.staffmo_01 {
  font-size:  16px;
  text-align: center; 
  color: #A07A59;
  letter-spacing: 0.14em;
  line-height: 1.6em;
}
.botmarumo {
  font-size:  10px;
  text-align: center; 
  font-weight: bold;
  display: inline-block;
  margin: 0 0 0 12px;
}
	
.sliderterms {
  height: 40vh;
  margin-top: 85px;
  margin-bottom: 20px;
  background-image: url('../img/cover/terms1.png');
  background-repeat: no-repeat;
  background-position: top;
  background-size: cover;
}
.sliderabout {
  height: 40vh;
  margin-top: 85px;
  margin-bottom: 10px;
  background-image: url('../img/cover/about1.png');
  background-repeat: no-repeat;
  background-position: top;
  background-size: cover;
}
.sliderintro {
  height: 40vh;
  margin-top:  85px; /*画像のナビからの高さ位置*/
  margin-bottom: 10px;
  background-image: url('../img/cover/intro1.png');
  background-repeat: no-repeat;
  background-position: top;
  background-size: cover;
}
.sliderstaff {
  height: 40vh;
  margin-top:  85px; /*画像のナビからの高さ位置*/
  margin-bottom: 20px;
  background-image: url('../img/cover/staff1.png');
  background-repeat: no-repeat;
  background-position: top;
  background-size: cover;
} 
.slider3hp {
  height: 40vh;
  margin-top:  85px; /*画像のナビからの高さ位置*/
  margin-bottom: 1px;
  background-image: url('../img/cover/program1.png');
  background-repeat: no-repeat;
  background-position: top;
  background-size: cover;
}
.slidermaternity {
  height: 40vh;
  margin-top:  85px; /*画像のナビからの高さ位置*/
  margin-bottom: 10px;
  background-image: url('../img/cover/maternity1.png');
  background-repeat: no-repeat;
  background-position: top;
  background-size: cover;
}
.sliderfirst {
  height: 40vh;
  margin-top:  85px; /*画像のナビからの高さ位置*/
  margin-bottom: 10px;
  background-image: url('../img/cover/first1.png');
  background-repeat: no-repeat;
  background-position: top;
  background-size: cover;
}
.slidernotice {
  width: auto;
  height: 40vh;
  margin-top:  85px; /*画像のナビからの高さ位置*/
  margin-bottom: 10px;
  background-image: url('../img/cover/notice1.png');
  background-repeat: no-repeat;
  background-position: top;
  background-size: cover;
}
.sliderprevention {
  height: 40vh;
  margin-top:  85px; /*画像のナビからの高さ位置*/
  margin-bottom: 10px;
  background-image: url('../img/cover/prevention1.png');
  background-repeat: no-repeat;
  background-position: top;
  background-size: cover;
}
	
.dentalmozi{
	width: 350px;
	height: auto;
	padding: 100px auto;
    font-size: clamp(14px, 1.28vw, 18px);
    line-height:24px;
    letter-spacing: 4px;
	margin: 420px  -50px 0 -60px;
}
	
h1 {
	font-size:  26px;
	padding: 2px;
	text-align:center; 
	letter-spacing: 1px;
}
h1:before {
    content: url("../img/..."); 
	position: absolute;
    margin:  -100px 0 0 -24px;  /*画像の余白*/
}

h2 {
	font-size:  18px;
	font-weight:bold;
	padding: 0 auto;
	text-align:center; 
	letter-spacing: 0.5;
}
	
.slider-area {
  margin-top:  100px; /*画像のナビからの高さ位置*/
  height: 220px;
  background-image: url('../img/cover/mv-p.png');
  background-position: center;
  background-size: 100% auto;
  background-repeat: no-repeat;
}

.dentalimg { display: none; }
		
.intro2 {
  font-size:  15px;
  text-align: left; 
  color: #A07A59;
  padding: 12px 1px 0;
  letter-spacing: 1px;
  line-height: 20px;
}
	
.wrap_01 {
  flex-flow: column;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-pack:end;
  -ms-flex-pack:end;
  justify-content:flex-end;
  width:100%;
  height : auto;
  margin : 0  auto 10px auto;
}
.hero {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
}
.wrap_original {
overflow: hidden;
}	
	
#profile {
	width: 90%;
	display: flex;
	align-items: center;
	margin: -10px auto 30px auto;
}

#profile .denl {
	width: 100%;
	padding: 0 auto;
	margin: 20px auto;
}
#profile .img {
	width: 20%;
}
	
.content {
  display: flex;
  justify-content: center;
	margin: 250px 0 -130px 8%;
}
	
.content01 {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}	
	
.dentalmozi01 {
	width: 320px;
	height: auto;
	margin: 50% auto 20px auto;
}
	
.dental {
	display: flex;
	padding: 1px;
	margin:  -40% auto 10px;
    justify-content: center;/*横の中央寄せ*/
}

.mamshi {
	width: 100%;
	max-width: 100%;
	height: auto;
	margin:  -40px 0 0 0;
	padding: 30px 0 30px 0;
	float: left;
	background: #fff5f3;
}

.mammozi{
	width: 300px;
	height: auto;
	padding:  0 0 0 10%;
}

.indextop_00 {
  font-size:  15px;
  text-align: left; 
  color: #A07A59;
  letter-spacing: 0.2em;
  line-height: 1.5em;
  padding-bottom: 16px;
  font-weight: 500;
  display: inline-block;

}
	
	
.titlemama {
	width: 320px;
	height: auto;
	padding: 10px;
	margin: 6px auto 0 0;
}
	
	
h3 {
	font-size:  16px;
	padding:  0 0 0 28%;
	margin: 0 auto;
	text-align:left; 
	letter-spacing: 1px;
}
h30 {
	font-size:  18px;
	padding:  0;
	margin: 0;
	text-align:center; 
	letter-spacing: 3px;
}
	
.intro {
  font-size:  15px;
  text-align: left; 
  color: #A07A59;
  line-height: 19px;
  font-weight: 550;
  letter-spacing: 0.06em;
	display: inline-block;
}
.inmos {
	margin-top: 20px;
	font-size: 15px;
  line-height: 22px;
  font-weight: 550;
  letter-spacing: 0.015em;
}
	
.introtop {
  font-size:  15px;
  text-align: left; 
  color: #A07A59;
  line-height: 19px;
  font-weight: 550;
  letter-spacing: 0.1em;
	display: inline-block;
}

.nitymo {
  font-size:  15px;
  text-align: center; 
  color: #A07A59;
  line-height: 19px;
  font-weight: 550;
  letter-spacing: 0.01em;
	display: inline-block;
}

.float03 {
	padding: 0 0 6px 3px;
	text-align: left;
	font-size: 16px;
	letter-spacing: 1.4px;
	line-height: 2.0 ;
	color: #A07A59;
}
.float03_1 {
	text-align: left;
	font-size: 16px;
	letter-spacing: 1.0px;
	line-height: 1.6em ;
    text-indent: -1em;
    padding-left: 1em;
	margin-left: 4px;
}
	
	
.indexframe {
	width: 80%;
	padding: 16px ;
	margin: -42px auto 10px;
	}
	
.mam01{
    position: relative;
    margin: 40px 0 0 26%;
}

.sabu {
    width: 100%;
	height: auto;
}

/* スライド設定 */
.css-carousel-slider2 {
    width: 100%;
	top : 60px;
    overflow: hidden;
    position: relative;
}
.css-carousel-slider2 img {
    width: 100%;
    height: auto;
    vertical-align: top;
}
	
.css-carousel-slider2 .slide-wrap {
    width: 200%;
    position: absolute;
    display: flex;
    top: 0;
    left: 0;
    z-index: 0;
    animation: css-carousel-slider2 12s infinite;
    animation-delay: 8s;
}
.css-carousel-slider2 .slide-wrap-main {
    width: 100%;
    z-index: 1;
    animation: css-carousel-slider-main2 12s infinite;
    animation-delay: 8s;
}
.css-carousel-slider2 .slide {
    width: 100%;
}
/* スライダーアニメーションの設定 */
@keyframes css-carousel-slider2 {
    0% { transform: translateX(0); }

    40% { transform: translateX(calc(1 / 2 * -100%)); }
    50% { transform: translateX(calc(1 / 2 * -100%)); }

    90% { transform: translateX(calc(2 / 2 * -100%)); }
    100% { transform: translateX(calc(2 / 2 * -100%)); }
}

@keyframes css-carousel-slider-main2 {
    0% { transform: translateX(100%); }
    50% { transform: translateX(100%); }
    90% { transform: translateX(0%);}
}	

.features2 {
	width: 100%;
	height: auto;
	padding: 50px 0 30px 0;
	margin: 16px 0 -330px 0;
	background-image: url("../img/bak01.webp");
    background-position: center center;
    background-repeat: no-repeat;
    background-attachment: fixed;
	animation: move 10s infinite both;
}
	
.wrap {
    height: auto;
	padding: 0;
    margin: 0;
}
.wrap_02 {
    height: auto;
	padding: 0;
    margin: -50px 0 0 0;
}
	
.content0 {
  margin-top: -50px;
  background-image:  repeating-linear-gradient(135deg, #f1fef9, #f1fef9 2px, #f5fbfe 2px, #ebf9ff 6px);
  border-top-left-radius: 50%;
  border-top-right-radius: 50%;
  height: 80px;
  margin-left: -100px;
  margin-right: -100px;
  padding-left: 100px;
  padding-right: 100px;
}
.child01 {
    padding: 0px;
	margin: 0 auto 40px auto;
    text-align: center; 
}
.child01-img {
	width: 25%;
	height: auto;
	margin: -30px 0 0 30px;}

.imgfree_01 {
	width: 80%;
	height: auto;
	margin:  0 45px;
    padding: 8px 4px;
}
.imgfree_02 {
	width: 80%;
	height: auto;
	margin:  0 29px 0 0;
    padding: 8px 4px;
}

.box-015 {
    position: relative;
    max-width: 800px;
    margin: 1em auto;
    padding: 1em 2.5em 1em 1.5em;
    border-radius: 3px;
    box-shadow: 0 2px 3px rgb(0 0 0 / 20%);
    background-color: #fffaf0;
}
.box-015::before,
.box-015::after {
    position: absolute;
    content: '';
}
.box-015::before {
    top: -15px;
    right: 10px;
    height: 50px;
    width: 15px;
    border: 3px solid #999;
    border-radius: 10px;
    box-shadow: 1px 1px 2px rgb(0 0 0 / 30%);
    transform: rotate(10deg);
}
.box-015::after {
    top: 0;
    width: 10px;
    right: 20px;
    border: solid 5px #fffaf0;
}
.box3hp {
	width: 100%; 
	margin: 0 0 0 -20px;
    padding: 20px;
    background: #fff3c0;
    border-radius: 10px;
	text-align:  center;   
}
.box3hp2 {
	width: 80%;
    padding: 0.8em 1.5em;
    margin: 70px auto;
    border: solid 1px #fb9039;
	background-color: #fffaf9;
	border-radius: 10px;
}
.promo {
	font-size: 17px;
    font-weight: bold;
	letter-spacing: 0.07em;
	}

	/* チェックボックス01 */
.checkbox-2 {
    border: none;
}

.checkbox-2 label {
	font-size: 13px;
    display: flex;
    align-items: center;
    gap: 2.5em;
    position: relative;
    margin-bottom: 1.5em;
}

.checkbox-2 label::before {
    display: none; 
}

.checkbox-2 label:has(:checked)::after {
    display: none; 
}

.checkbox-2 input {
    display: none;
}
	.check {}	
.highlight {
  background-image: linear-gradient(0deg, #fbbf248c 0.5em, transparent 0.5em);
}

	.checfot { 
		padding-left: 4px;
		text-align: left; }	
	
	
.hp1mo {
	font-size:  18px;
	text-align:center; 
	letter-spacing: 2px;
	font-weight:bold;
    color: #FFFFFF;
    background: #fb9039;/*背景色*/
    padding: 3px 65px;/*文字まわり（上下左右）の余白*/
	z-index: 10;
}
	
.features {
	height: 560px;
	margin: 0px 0 0 0;
	padding-top: 1px;
	background-image: url("../img/parts2.png");
	background-size: cover;
}
.featurester {
	margin : 0;
	padding-bottom: 100px;
	background-image:  linear-gradient(180deg, rgba(115, 248, 224, 0.1), rgba(150, 167, 241, 0.1));
}

h4 {
	font-size:  19px;
	padding: 6px 0;
	text-align:center; 
	color: #A07A59;
	letter-spacing: 0.5px;
	font-weight: bold;
}
.indextopimg, .indextopimg2 {
	width: 60px;
	height: auto;
}
.indextopwaku {
		width: 95%;
	    text-align: left;
	   padding-left: 10px;
	}
.indextoptext br {
		display: none;
	}
.indexiti {
		display: none;
	}
.indextopss {
	    width: 100%;
	    margin-top: -30px;
		text-align: right;
		font-size:  19px;
	    letter-spacing: 0.5px;
	    font-weight: bold;
	}
.stabox{
	width: 90%;
    padding: 0.5em 1em;
    margin: 2em auto;
    background: white;
    border-top: solid 5px rgba(208, 159, 116,0.32);
    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.22);
}
.stabox p {
    margin: 0; 
    padding: 0;
}
	
	
.companyr {
	margin:  0 15%; 
}
	
.topindlogpimg {
	width: 300px;
	height: auto;
}
	
.imin_1 {
	width: 250px;
	height: 250px;
	padding: 0;
	margin: 0 auto;
}
.imin_2 {
	width: 250px;
	height: 250px;
	padding: 0;
	margin: 30px auto -70px 30%;
}
.imin_2 {
	width: 250px;
	height: 250px;
	padding: 0;
	margin: 30px auto 130px 30%;
}
.imin_3 {
	width: 250px;
	height: 250px;
	padding: 0;
	margin: 0 auto -20px 10%;
}
.space01 {
	width: 99%;
	height: auto;
	padding: 0;
	margin: -210px -1%;
}
	
.childcare01 {
	background-image: url("../img/par01.webp");
    background-position: 52% top;
    background-repeat: no-repeat;
}
.childcare02 {
	background-image: url("../img/par0200.webp");
   background-position: center top;
    background-repeat: no-repeat;
}
.features4 {
	width: 100%;
	height: auto;
	background-image: url("../img/parts3.png");
    background-size:  100%;
    background-repeat: no-repeat;
	}
.childcare03 {
	background-image: url("../img/318x20.png");
   background-position: center top;
    background-repeat: no-repeat;
}

/*スタッフ紹介ぺージ*/	
h7 {
    font-size: 20px;
	font-weight: bold;
    display: block;
    text-align: center;
    color: #70553E;
	margin-top: -10px;
	letter-spacing: 0.5em;
}
.featuresdoc {
	padding: 60px 0 80px 0;
}
	
.featuresback {
	background-image:  linear-gradient(180deg, rgba(115, 248, 224, 0.1), rgba(150, 167, 241, 0.1));
}

	.stabox{
	width: 90%;
    padding: 0.5em 1em;
    margin: 2em auto;
    background: white;
    border-top: solid 5px rgba(208, 159, 116,0.32);
    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.22);
}
.stabox p {
    margin: 0; 
    padding: 0;
}
.featuresstaff {
	width: 100%;
	height: auto;
	padding: 10px 0 100px 0;
	margin: 50px 0 20px 0;
}
.featuresstaff2 {
	width: 100%;
	height: 820px;
	padding: -10px 0 20px 0;
	margin: 0 0 0 0;
}
	
main {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
	margin: 0 auto 0 10%;
}

main div.staffimg {
  /*（全体の幅 - gapでつけた余白の合計）をカラム数で割る */
  width: calc((100% - 20px) / 2);
	margin: 0 auto 0 5px;
}
.smstaffimg {
    width: 130px;
	height: auto;
	}	
	
.space {
	width: 100%;
	height: 400px;
	padding: 10px 0 470px 0;
}
.spacetop {
	width: 97%;
	height: 200px;
	margin-top: -650px;
	margin-bottom: 350px;
	margin-left: 2%;
	margin-right: auto;
	padding: 10px 0 470px 0;
}
	
.tipoz { padding:  0 14px;}
.tipoz01{ margin:  0 50px;}
.poz02{ padding:  0 35px 0 10px;}
.poz { margin: 0 20px 10px 20px; }
.poz01 { padding: 0 16px;}	
.poz00 { padding: 0 7px;}	
.poz08 { padding: 0 0 0 3.8px;}	
.chizimi { margin-top: -350px;}
.chizimi01 { margin-top: -600px;}	

.waku {
	 width: 400px;
     max-width: 100%;
     height: auto;
}
		
.features3 {
	width: 100%;
	height: auto;
	padding: 20px 0 20px 0;
	margin: -320px 0 -50px 1% ;
	background: #FFFFFF;
}
.imgfree2 {
	width: 80%;
	height: auto;
	margin-top:  25px;
	margin-bottom: -15px;
	}
.imgpar01 {
	width: 80%;
	height: auto;
	margin-top:  0;
	margin-bottom: 30px;
	}
	
.imgfree6 {
	width: 100%;
	height: auto;
	margin-top:  40px;
	}
	
.elephant{
position: relative;
top: -10px;
}
	
h5,h6 { 
	font-size:  clamp(15px, 3.75vw, 18px);
	padding: 20px;
	text-align: center; 
	color: #A07A59;
	letter-spacing: 2px;
    }
	
h5:before {
    content: url("../img/ints.png"); 
	position: absolute;
    margin:  -110px 0 0 -28px;  /*画像の余白*/
}
h6:before {
    content: url("../img/ints3.png"); 
	position: absolute;
    margin:  -110px 0 0 -20px;  /*画像の余白*/
}

.featuresinst {
	width: 100%;
	height: auto;
	padding: 60px 0 60px 0;
	margin: -600px 0 -300px 0;
	background: #fffcf5;
	text-align: center;
}

.featuresbelow {
  height: auto;
  padding: 20px 0 60px 0;
  margin: 200px 0 -70px 0;
  background-image: linear-gradient(180deg, rgba(242, 230, 234, 1), rgba(219, 213, 236, 1));
}
	
.featuresbelow2 {
  height: auto;
  padding: 20px 0 60px 0;
  margin: 300px 0 -60px 0;
  background-image: linear-gradient(180deg, rgba(242, 230, 234, 1), rgba(219, 213, 236, 1));
}

.featuresbelow3 {
  height: auto;
  padding: 20px 0 80px 0;
  margin: -100px 0 -50px 0;
  background-image: linear-gradient(180deg, rgba(242, 230, 234, 1), rgba(219, 213, 236, 1));
}
	
.featuresbelow4 {
  height: auto;
  padding: 20px 0 60px 0;
  margin: 120px 0 -50px 0;
  background-image: linear-gradient(180deg, rgba(242, 230, 234, 1), rgba(219, 213, 236, 1));
}

.featuresbelow5 {
  height: auto;
  padding: 20px 0 20px 0;
  margin: 50px 0 -50px 0;
  background-image: linear-gradient(180deg, rgba(242, 230, 234, 1), rgba(219, 213, 236, 1));
}
.featuresbelow6 {
  height: auto;
  padding: 20px 0 50px 0;
  margin: 120px 0 -50px 0;
  background-image: linear-gradient(180deg, rgba(242, 230, 234, 1), rgba(219, 213, 236, 1));
}
	
.flex-item2 {
	width: 100%;
	 padding: 20px;              /* 余白指定 */
    text-align:  center;        /* 中央寄せ */
	margin: 0;
	}
	
.painfulmap {
	display: inline-block;      
    width : 100%;
	height:  400px;
	text-align:  center;
	margin: 0 auto 0 -10px;
	padding: 10px;
	 background: rgba(255,255,255,0.5);
    border-radius: 10px;

}
.painful {
    display: inline-block;
    width : 100%;
    height: auto;
    padding: 14px;
    text-align: center;
    background: rgba(255,255,255,1);
    border-radius: 10px;
    top : -10px;
	margin: 0 0 0 -4%;
}
.notice-table{
  width: 100%;
  border-collapse:separate;
  border-spacing: 0;
}

.notice-table th:first-child{
  border-radius: 1px 0 0 0;
}

.notice-table th:last-child{
  border-radius: 0 2px 0 0;
  border-right: 2px solid #f4cc7a;
}

.notice-table th{
  text-align: center;
  color:#6F4E37;
  background: linear-gradient(#ffdc93,#f4cc7a);
  border-left: 2px solid #f9f1dc;
  border-top: 2px solid #f9f1dc;
  border-bottom: 2px solid #f9f1dc;
  box-shadow: 0px 1px 1px rgba(255,255,255,1.0) inset;
  width: 8%;
  padding: 10px 0;
}

.notice-table td{
  text-align: center;
  border-left: 2px solid #f9f1dc;
  border-bottom: 2px solid #f9f1dc;
  border-top:none;
  box-shadow: 0px -3px 5px 1px #fff inset;
  width: 5%;
  padding: 6px 0;
  background: #FFFFFF;
  font-size: 12px;
 font-weight: bold;
}

.notice-table td:last-child{
  border-right: 2px solid #f9f1dc;
}

.notice-table tr:last-child td:first-child {
  border-radius: 0 0 0 5px;
}

.notice-table tr:last-child td:last-child {
  border-radius: 0 0 5px 0;
}	
.example{
	font-size: 85%;}
.painful p {
  font-size:  13px;
  color: #735741;
  letter-spacing: 0.12em;
  line-height: 1.4em;
  padding-bottom: 18px;
}	
.flex-container {
  display: flex;
  flex-wrap: wrap;
}
.flex-item {
	margin: 60px auto;
	padding: 2px;
	}
.bbs{
  align-items: center;
  color:  rgba(252, 239, 252, 0.5);
  display: flex;
  height: 30px;
  line-height: 40px;
  overflow:hidden;
  width: 100%;
  white-space:nowrap;
  margin: 30px 0;
  z-index: 1;
}
.bbs ul {
  /*animation: flowing 120s linear infinite;*/
  font-size: 40px;
  transform:translateX(100%);
  margin: 0;
  padding: 0;
}
.bbs ul li{
  display: inline-block;
  padding-right: 10px;
}
@keyframes flowing {
  0% { transform:translateX(0); }
  100% { transform:translateX(-100%); }
}
a.btn_06 {
	display: block;
	text-align: center;
	vertical-align: middle;
	text-decoration: none;
	position: relative;
	width: 90%;
	margin: 20px 0 100px 2%;
	padding: 10px;
	border-radius: 10px;
	color: #735741;
	font-size: 16px;
	background: #FFFFFF;
	border: 3px solid #ebb0c1;
	transition: 0.3s ease-in-out;
}
.title:before {
  content: url('../img/wata.png');
	padding: 0 10px 0 0;
}
.titletel:before {
  content: url('../img/tespare.png');
  padding: 0 14px 100px 0;
}
.mamshi-bot {
	width: 100%;
	height: auto;
	margin:  -30px 0 0 0;
	padding: 30px 0 20px 0;
	float: left;
	background: #fff5f3;
}
.shiorimozi {
  font-weight: bold;
  font-size:  16px;
  color: #A07A59;
	}

a.shiorimozi:hover 
 {
	color: black;
  text-decoration: none;}

.shiorizi {
  font-size:  16px;
  color: #A07A59;
	}
.shiorizi2 {
  font-size:  13px;
  color: #A07A59;
	}
.mamshi-bot {
	width: 100%;
	height: auto;
	margin:  -30px 0 0 0;
	padding: 80px 0 20px 0;
	float: left;
	background: #fff5f3;
}
.shioriitem {
	width: 300px;
	height: 20px;
    margin: 3px auto;
    padding: 8px 50px 1px 50px;
    text-align: left;
}
.cp_link {
	width: 50%;
	padding: 8px;
  font-size:  13px;
  position: relative;
  display: inline-block;
  transition: .3s;
  color: #000000;
  text-decoration: none;/*元々のアンダーラインを非表示にしておく*/
}
.cp_link::after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: '';
  width: 0;
  height: 1px;
  background-color: #000000;
  transition: .3s;
}
.cp_link:hover::after {
  width: 100%;
}
.shioribox2 {
	width: 100%;
	height: 70px;
	text-align:  right;  
}
.termsmo {
	font-size: 15px;
	text-align: left;
	letter-spacing: 0.1em;
	line-height: 1.5;
}
.termsmo_01 {
	font-size: 16px;
	text-align: left;
	letter-spacing: 0.1em;
	line-height: 1.5;
	text-indent: -1.0em;
    padding-left: 1.5em;
}
.firsttitle {
	font-size: 16px;
	text-align: center;
	letter-spacing: 0.38em;
	line-height: 1.8;
	margin:  5px 2px;
}

.box-018 {
	top: 15px;
	bottom: 10px;
    position: relative;
    max-width: 800px;
    margin: 0 auto;
    padding: 0.8em calc(1.3em + 8px);
    border-top: 2px solid #FF7B24;
    border-bottom: 2px solid #FF7B24;
}
.box-018::before,
.box-018::after {
    position: absolute;
    width: 2px;
    top: 50%;
    transform: translateY(-50%);
    height: calc(100% + 20px);
    background-color: #FF7B24;
    content: '';
}
.box-018::before {
    left: 9px;
}
.box-018::after {
    right: 9px;
}
.imgkeap_01 {
	width: 300px;
	height: auto;
	padding: 20px -10px 0 90%;
	margin: 30px 0 0 8%;
}
.firsttiorange {
	font-size: 18px;
	font-weight:bold;
	color: #FF7B24;
	text-align: center;
    padding: 0.5rem 1rem;
    border-top: 2px dashed #FF7B24;
    border-bottom: 2px dashed #FF7B24;
	letter-spacing: 0.1em;
	margin-bottom: 50px;
	background-color: #FFFAF3;
}
	
.firstindex {
	width: 100%;
	height: auto;
	margin: 20px 0 -60px 0;
	padding: 0;
}
.firstindex2 {
	width: 100%;
	height: auto;
	margin: 30px 0 -50px 0;
	padding: 0;
}

.featfirs {
	width: 100%;
	height: auto;
	margin: 60px 0 20px 0;
	padding: 0;
}
	
.tokumoscen {
	text-align: center;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 0.08em;
}
.tokumoscen2 {
	text-align: center;
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0.07em;
}
	
.firstintro {
	   width: 80%;
	   height: 80px;
	   padding:  20px;
	   margin: 0 auto 20px 5%;
	   float: left;
       text-align: center;
	  background-color: #FFFFFF; 
}	
.box-019 {
    position: relative;
    margin-top: 1em;
    padding: 1.8em 1.5em 1em 1.5em;
    border: 2px solid #3CB371;
	 background-color: #fff;
}
.box-020 {
    position: relative;
    margin-top: 0.8em;
    padding: 3.0em 0.5em 0.05em 1.5em;
    border: 2px solid #3CB371;
	 background-color: #fff;
}

.box-019 > div {
    position: absolute;
    top: -1.15em;
    left: -.5em;
    padding: .4em 1.4em;
    border-radius: 5px;
    background-color: #3CB371;
    color: #fff;
    font-size: .9em;
}

.box-019 > div::before {
    position: absolute;
    bottom: -8px;
    left: 50%;
    transform: translateX(-50%);
    width: 16px;
    height: 8px;
    background-color: #3CB371;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
}

.box-019 p {
    margin: 0;
}
	
.ribbon1 {
  display: inline-block;
  position: relative;
  width: 100%;
  height: 50px;/*リボンの高さ*/
  line-height: 50px;/*リボンの高さ*/
  text-align: center;
  padding: 0 120px;/*横の大きさ*/
  font-size: 18px;/*文字の大きさ*/
  background: #f67a90;/*塗りつぶし色*/
  color: #FFF;/*文字色*/
  box-sizing: border-box;
}

.ribbon2 {
  display: inline-block;
  position: relative;
  width: 100%;
  height: 50px;/*リボンの高さ*/
  line-height: 50px;/*リボンの高さ*/
  text-align: center;
  padding: 0 80px;/*横の大きさ*/
  font-size: 18px;/*文字の大きさ*/
  background: #64bdef;/*塗りつぶし色*/
  color: #FFF;/*文字色*/
  box-sizing: border-box;
}

.ribbon3 {
  display: inline-block;
  position: relative;
  width: 100%;
  height: 50px;/*リボンの高さ*/
  line-height: 50px;/*リボンの高さ*/
  text-align: center;
  font-size: 18px;/*文字の大きさ*/
  background: #f49249;/*塗りつぶし色*/
  color: #FFF;/*文字色*/
  box-sizing: border-box; 
}

.ribbon7 {
  display: inline-block;
  position: relative;
  width: 100%;
  height: 50px;/*リボンの高さ*/
  line-height: 50px;/*リボンの高さ*/
  text-align: center;
  padding: 0 120px;/*横の大きさ*/
  font-size: 18px;/*文字の大きさ*/
  background: #bfd123;/*塗りつぶし色*/
  color: #FFF;/*文字色*/
  box-sizing: border-box;
}

.ribbon6 {
  display: inline-block;
  position: relative;
  width: 100%;
  height: 50px;/*リボンの高さ*/
  line-height: 50px;/*リボンの高さ*/
  text-align: center;
  padding: 0 120px;/*横の大きさ*/
  font-size: 18px;/*文字の大きさ*/
  background: #cf81ec;/*塗りつぶし色*/
  color: #FFF;/*文字色*/
  box-sizing: border-box;
}
	
.firstmoko {
	font-size: 17px;
	text-align: left;
	font-weight:bold;
	letter-spacing: 0.1em;
	line-height: 1.5;
	color: #7b4e27;
}
	
.firstmoko2 {
	font-size: 16px;
	text-align: left;
	font-weight:bold;
	letter-spacing: 0.1em;
	line-height: 1.5;
	color: #7b4e27;
}

.firstmo {
	font-size: 15px;
	text-align: left;
	font-weight:bold;
	letter-spacing: 0.1em;
	line-height: 1.5;
}

.rule {
	width: 80%;
	height: auto;
	padding: 0;
	margin:  0 auto;
}
.rule2 {
	width: 80%;
	height: auto;
	padding: 20px;
	margin:  300px auto -60px  auto;
}
.rule3 {
	width: 80%;
	height: auto;
	padding: 20px;
	margin:  220px auto -20px auto;
}
	
.imgbt {
	width: 70%;
	height: auto;
  margin: auto;
  display: block;
}
	
.balloon-005 {
    display: flex;
    justify-content: center;
    position: relative;
    max-width: 180px;
	margin-left: 10px;
    margin-bottom: -45px;
    padding: .5em .3em;
    border: 3px solid rgba(123,222,217, 0.5);
    border-radius: 25px;
    background-color: #fff;
    color: #A07A59;
}

.balloon-005::before,
.balloon-005::after {
    position: absolute;
    bottom: -15px;
    width: 30px;
    height: 15px;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
}

.balloon-005::before {
    background-color: rgba(123,222,217, 0.5);
}

.balloon-005::after {
    bottom: -11px;
    background-color: #fff;
}	
	
.footbottom {
    width: 100%;
	padding: 0 0 10px 0;
	margin-bottom: -30px;
	font-weight: bold;
	text-align: center;
	background: #fff5f3;
}
}
