@charset "UTF-8";
html {
    height: 100%;
    margin: 0;
    padding: 0;
    font-size: 62.5%;
}
body {
    width: 100%;
    height: 100%;
    color: #404040;
    font-family: 'Noto Sans JP', sans-serif;
    position: relative;
    line-height: 2.0rem;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

a {
  text-decoration: none;
  color: #404040;
}
a:hover {
  text-decoration: underline;
  color: #404040;
}

/****** header ******/
header {
  width: 100%;
  box-sizing: border-box;
  padding: 20px;
  background: #ffffff;
}
header h1 {
  box-sizing: border-box;
}

/****** main visual ******/
.main-visual {
  width: 100%;
  height: 695px;
  background-image: url('../img/main_visual.png');
  background-size: cover;
  background-position: center;
  position: relative;
}
.main-visual .key-comment{
  position: absolute;
  bottom: 60px;
  left: 40px;
  color: #ffffff;
  font-size: 3.6rem;
  line-height: 5.6rem;
  font-weight: bold;
}
/****** main key ******/
.main-key-area {
  width: 100%;
  background-image: url('../img/main_key_bg.png');
  background-size: cover;
  background-position: center;
  padding: 40px;
  box-sizing: border-box;
}
.main-key-area .inner-key-area{
  width: 1000px;
  box-sizing: border-box;
  background: rgba(255, 255, 255, 0.8);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;;
  padding: 30px;
  margin: 0 auto;
  font-size: 2.0rem;
  line-height: 3.4rem;
}

/****** main ttl ******/
.main-ttl-area {
  width: 100%;
  text-align: center;
  margin: 0 auto;
  padding: 30px 0;
  color: #ffffff;
  background: #ee86b3;
}
.main-ttl-area .main-ttl {
  font-size: 3.6rem;
  line-height: 4.8rem;
  font-weight: bold;
}

/****** about ******/
.about-area {
  width: 100%;
  padding: 40px 0;
  box-sizing: border-box;
  background: #fdf4f7;
}
.about-area .about-inner-area {
  width: 1000px;
  box-sizing: border-box;
  margin: 0 auto;
}
.about-area .about-inner-area img {
  width: 100%;
  height: auto;
}

/****** video ******/
.video-area {
  width: 100%;
  padding: 40px 0;
  box-sizing: border-box;
  background: #ffffff;
}
.video-area .video-inner-area {
  width: 1000px;
  box-sizing: border-box;
  margin: 0 auto;
}
.video-area .video-inner-area .video-exp-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 20px;
  text-align: center;
}

.video-area .video-inner-area .video-exp-area .video-wrapper {
  position: relative;
  padding-top: 56.25%;
  height: 0;
  overflow: hidden;
}
.video-area .video-inner-area .video-exp-area iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/****** experience ******/
.experience-area {
  width: 100%;
  padding: 40px 0;
  box-sizing: border-box;
  background: #fdf4f7;
}
.experience-area .experience-inner-area {
  width: 1000px;
  box-sizing: border-box;
  margin: 0 auto;
}
.experience-area .experience-inner-area .experience-cont-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 30px;
  font-size: 1.6rem;
  line-height: 2.6rem;
  font-weight: bold;
}
.experience-area .experience-inner-area .experience-cont-area .expe-main-ttl {
  font-size: 2.0rem;
  line-height: 3.0rem;
  color: #ee86b3;
  font-weight: bold;
  padding-bottom: 10px;
}
.experience-area .experience-inner-area .experience-cont-area .expe-cont-txt {
  font-size: 1.6rem;
  line-height: 2.6rem;
  font-weight: bold;
  padding-bottom: 10px;
}
.experience-area .experience-inner-area .experience-cont-area .expe-sub-cont-txt {
  font-size: 1.6rem;
  line-height: 2.6rem;
  padding-bottom: 20px;
  font-weight: normal;
}
.experience-area .experience-inner-area .experience-cont-area .expe-strong {
  color: #ee86b3;
}

/****** contact ******/
.contact-area {
  width: 100%;
  padding: 40px 0;
  box-sizing: border-box;
  background: #ffffff;
}
.contact-area .contact-inner-area {
  width: 1000px;
  box-sizing: border-box;
  margin: 0 auto;
}
.contact-area .contact-inner-area .contact-cont-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 30px;
  font-size: 1.6rem;
  line-height: 2.6rem;
  font-weight: bold;
}
.contact-area .contact-inner-area .contact-cont-area .contact-cont-pos {
  box-sizing: border-box;
  padding-bottom: 30px;
  display: flex;
  align-items: center;
}
.contact-area .contact-inner-area .contact-cont-area .contact-cont-pos .contact-txt-pos {
  box-sizing: border-box;
  flex: 1;
  font-size: 2.0rem;
  line-height: 3.0rem;
}
.contact-area .contact-inner-area .contact-cont-area .contact-cont-pos .contact-txt-pos span {
  color: #ee86b3;
}
.contact-area .contact-inner-area .contact-cont-area .contact-cont-pos .contact-pic-pos {
  box-sizing: border-box;
  width: 200px;
  padding-left: 50px;
}
.contact-area .contact-inner-area .contact-cont-area .contact-cont-pos .contact-pic-pos img {
  width: 150px;
  height: auto;
}
.contact-area .contact-inner-area .contact-cont-area .contact-btn-pos {
  box-sizing: border-box;
  text-align: center;
}
.contact-area .contact-inner-area .contact-cont-area .contact-btn-pos .contact-btn-wrapper a {
  display: inline-flex;
  align-items: center;
  padding: 10px 20px;
  height: 60px;
  box-sizing: border-box;
  background-color: #06c755;
  color: #fff;
  text-decoration: none;
  border-radius: 30px;
  font-size: 2.0rem;
}
.contact-area .contact-inner-area .contact-cont-area .contact-btn-pos .contact-btn-wrapper a:hover {
  opacity: 0.8;
}
.contact-area .contact-inner-area .contact-cont-area .contact-btn-pos .contact-btn-wrapper .line-icon {
  margin-right: 10px;
  line-height: 1;
}

/****** contact bottom ******/
.contact-btm-area {
  width: 100%;
  padding: 40px 0 100px 0;
  box-sizing: border-box;
  background: #fdf4f7;
}
.contact-btm-area .contact-btm-inner-area {
  width: 1000px;
  box-sizing: border-box;
  margin: 0 auto;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 30px;
  font-size: 1.6rem;
  line-height: 2.6rem;
  font-weight: bold;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-cont-pos {
  box-sizing: border-box;
  padding-bottom: 30px;
  display: flex;
  align-items: center;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-cont-pos .contact-btm-txt-pos {
  box-sizing: border-box;
  flex: 1;
  font-size: 2.0rem;
  line-height: 3.0rem;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-cont-pos .contact-btm-txt-pos span {
  color: #ee86b3;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-cont-pos .contact-btm-pic-pos {
  box-sizing: border-box;
  width: 200px;
  padding-left: 50px;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-cont-pos .contact-btm-pic-pos img {
  width: 150px;
  height: auto;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-btn-pos {
  box-sizing: border-box;
  text-align: center;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-btn-pos .contact-btm-btn-wrapper a {
  display: inline-flex;
  align-items: center;
  padding: 10px 20px;
  height: 60px;
  box-sizing: border-box;
  background-color: #06c755;
  color: #fff;
  text-decoration: none;
  border-radius: 30px;
  font-size: 2.0rem;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-btn-pos .contact-btm-btn-wrapper a:hover {
  opacity: 0.8;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-btn-pos .contact-btm-btn-wrapper .btm-line-icon {
  margin-right: 10px;
  line-height: 1;
}

/****** example ******/
.exp-area {
  width: 100%;
  padding: 40px 0;
  box-sizing: border-box;
  background: #fdf4f7;
}
.exp-area .exp-inner-area {
  width: 1000px;
  box-sizing: border-box;
  margin: 0 auto;
}
.exp-area .exp-inner-area .boccia-exp-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  margin-bottom: 40px;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-ttl-pos {
  box-sizing: border-box;
  background: #fdf4f7;
  padding: 20px 0;
  text-align: center;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-ttl-pos .boccia-ttl {
  font-size: 2.4rem;
  line-height: 3.4rem;
  color: #ee86b3;
  font-weight: bold;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-cont-pos {
  box-sizing: border-box;
  padding: 30px;
  display: flex;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-cont-pos .boccia-pic-pos {
  box-sizing: border-box;
  width: 210px;
  padding-right: 30px;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-cont-pos .boccia-pic-pos img {
  width: 180px;
  height: auto;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-cont-pos .boccia-txt-pos{
  box-sizing: border-box;
  flex: 1;
  font-size: 1.6rem;
  line-height: 2.6rem;
}
.exp-area .exp-inner-area .supervision-exp-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-ttl-pos {
  box-sizing: border-box;
  background: #fdf4f7;
  padding: 20px 0;
  text-align: center;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-ttl-pos .supervision-ttl {
  font-size: 2.4rem;
  line-height: 3.4rem;
  color: #ee86b3;
  font-weight: bold;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos {
  box-sizing: border-box;
  padding: 30px;
  display: flex;
  justify-content: space-between;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-left-pos {
  box-sizing: border-box;
  width: 470px;
  display: flex;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-left-pos .sup-l-pic {
  box-sizing: border-box;
  width: 140px;
  padding-right: 20px;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-left-pos .sup-l-pic img {
  width: 120px;
  height: auto;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-left-pos .sup-l-txt {
  box-sizing: border-box;
  flex: 1;
  font-size: 1.6rem;
  line-height: 2.6rem;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-left-pos .sup-l-txt .sup-l-name {
  font-size: 2.0rem;
  line-height: 3.0rem;
  padding-bottom: 10px;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-right-pos {
  box-sizing: border-box;
  width: 470px;
  display: flex;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-right-pos .sup-r-pic {
  box-sizing: border-box;
  width: 140px;
  padding-right: 20px;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-right-pos .sup-r-pic img {
  width: 120px;
  height: auto;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-right-pos .sup-r-txt {
  box-sizing: border-box;
  flex: 1;
  font-size: 1.6rem;
  line-height: 2.6rem;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-right-pos .sup-r-txt .sup-r-name {
  font-size: 2.0rem;
  line-height: 3.0rem;
  padding-bottom: 10px;
}

/****** recommend ******/
.recommend-area {
  width: 100%;
  padding: 40px 0;
  box-sizing: border-box;
  background: #ffffff;
}
.recommend-area .recommend-inner-area {
  width: 1000px;
  box-sizing: border-box;
  margin: 0 auto;
}
.recommend-area .recommend-inner-area .recommend-list {
  list-style: none;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 30px;
  margin-bottom: 30px;
}
.recommend-area .recommend-inner-area .recommend-list:last-child {
  list-style: none;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 30px;
  margin-bottom: 0;
}
.recommend-area .recommend-inner-area .recommend-list .check-cont {
  display: flex;
  align-items: center;
  font-size: 1.8rem;
  line-height: 2.8rem;
}
.recommend-area .recommend-inner-area .recommend-list .check-cont img {
  width: 30px;
  height: 30px;
  margin-right: 10px;
  display: block;
}
.recommend-area .recommend-inner-area .recommend-list .check-cont .check-txt {
  color: #ee86b3;
}

/****** program ******/
.program-area {
  width: 100%;
  padding: 40px 0;
  box-sizing: border-box;
  background: #fdf4f7;
}
.program-area .program-inner-area {
  width: 1000px;
  box-sizing: border-box;
  margin: 0 auto;
}
.program-area .program-inner-area .program-cont-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 30px;
  display: flex;
  align-items: center;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .info-list {
  list-style: none;
  font-size: 1.6rem;
  line-height: 2.6rem;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .info-list li {
  margin-bottom: 20px;
  box-sizing: border-box;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .info-list li:last-child {
  margin-bottom: 0;
  box-sizing: border-box;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos {
  box-sizing: border-box;
  flex: 1;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .label {
  display: inline-flex;
  align-items: center;
  font-weight: bold;
  padding-left: 20px;
  position: relative;
  color: #ee86b3;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .label::before {
  content: "";
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background-color: #ebbb37;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .program-note {
  font-size: 1.4rem;
  line-height: 2.4rem;;
  padding-top: 20px;
  padding-left: 20px;
}
.program-area .program-inner-area .program-cont-area .program-pic-pos {
  box-sizing: border-box;
  width: 297px;
  padding-left: 20px;
}
.program-area .program-inner-area .program-cont-area .program-pic-pos img {
  width: 277px;
  height: auto;
}

/****** schedule ******/
.schedule-area {
  width: 100%;
  padding: 40px 0;
  box-sizing: border-box;
  background: #ffffff;
}
.schedule-area .schedule-inner-area {
  width: 1000px;
  box-sizing: border-box;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  gap: 40px;
}
.schedule-area .schedule-inner-area .sche-left-box {
  width: 480px;
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 30px;
}
.schedule-area .schedule-inner-area .sche-left-box .sche-sub-ttl {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  text-align: center;
}
.schedule-area .schedule-inner-area .sche-left-box .sche-sub-ttl span {
  color: #ee86b3;
}
.schedule-area .schedule-inner-area .sche-left-box .sche-main-ttl {
  font-size: 3.2rem;
  line-height: 4.2rem;
  font-weight: bold;
  text-align: center;
  padding-bottom: 10px;
}
.schedule-area .schedule-inner-area .sche-left-box .sche-main-ttl span {
  font-size: 7.4rem;
  line-height: 8.4rem;
  color: #ee86b3;
}
.schedule-area .schedule-inner-area .sche-left-box .sche-l-note {
  font-size: 1.4rem;
  line-height: 2.4rem;
}

.schedule-area .schedule-inner-area .sche-right-box {
  width: 480px;
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 30px;
}
.schedule-area .schedule-inner-area .sche-right-box .sche-date-txt {
  font-size: 1.8rem;
  line-height: 2.8rem;
  color: #ee86b3;
  font-weight: bold;
  padding-bottom: 10px;
}
.schedule-area .schedule-inner-area .sche-right-box .sche-cont-txt {
  font-size: 1.6rem;
  line-height: 2.6rem;
  padding-bottom: 10px;
}
.schedule-area .schedule-inner-area .sche-right-box .sche-caution-txt {
  font-size: 1.4rem;
  line-height: 2.4rem;
}

/****** footer ******/
footer {
  box-sizing: border-box;
  background: #ffffff;
  padding: 50px 20px;
  border-top: 1px solid #e4e4e4;
}
footer .footer-info-area {
  max-width: 100%;
  margin: 0 auto;
  text-align: center;
  box-sizing: border-box;
}
footer .footer-info-area .footer-copyright {
  box-sizing: border-box;
  font-size: 1.2rem;
  line-height: 1.8rem;
}

a.floating-link {
  color: #404040;
  text-decoration: none;
}
a.floating-link:hover {
  color: #404040;
  text-decoration: none;
  opacity: 0.8;
}
.floating-btn {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  background-color: #ffffff;
  color: #ffffff;
  padding: 25px 25px;
  border-radius: 50px;
  box-shadow: 0 0 10px rgba(0,0,0,0.2);
  box-sizing: border-box;
  border: 5px solid #ee86b3;
}
.floating-btn .floating-btn-txt {
  display: flex;
  align-items: center;
  font-size: 3.0rem;
  line-height: 3.0rem;
  font-weight: bold;
  color: #404040;
}
.floating-btn .floating-btn-txt img {
  width: 30px;
  height: 30px;
  margin-right: 10px;
  display: block;
}


/******************************************************
smartphone
******************************************************/
@media screen and (max-width: 768px) {
/****** header ******/
header {
  width: 100%;
  box-sizing: border-box;
  padding: 10px;
  background: #ffffff;
}
header h1 {
  box-sizing: border-box;
}
header h1 img {
  width: 300px;
  height: auto;
}

/****** main visual ******/
.main-visual {
  width: 100%;
  height: 350px;
  background-image: url('../img/main_visual.png');
  background-size: cover;
  background-position: right;
  position: relative;
}
.main-visual .key-comment{
  position: absolute;
  bottom: 10px;
  left: 10px;
  color: #ffffff;
  font-size: 2.0rem;
  line-height: 3.0rem;
  font-weight: bold;
}

/****** main key ******/
.main-key-area {
  width: 100%;
  background-image: url('../img/main_key_bg.png');
  background-size: cover;
  background-position: center;
  padding: 20px;
  box-sizing: border-box;
}
.main-key-area .inner-key-area{
  width: 100%;
  box-sizing: border-box;
  background: rgba(255, 255, 255, 0.8);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;;
  padding: 15px;
  margin: 0 auto;
  font-size: 1.6rem;
  line-height: 2.6rem;
}
/****** main ttl ******/
.main-ttl-area {
  width: 100%;
  text-align: center;
  margin: 0 auto;
  padding: 15px 10px;
  color: #ffffff;
  box-sizing: border-box;
  background: #ee86b3;
}
.main-ttl-area .main-ttl {
  font-size: 2.0rem;
  line-height: 3.0rem;
  font-weight: bold;
}

/****** about ******/
.about-area {
  width: 100%;
  padding: 20px 10px;
  box-sizing: border-box;
  background: #fdf4f7;
}
.about-area .about-inner-area {
  width: 100%;
  box-sizing: border-box;
  margin: 0 auto;
}
.about-area .about-inner-area img {
  width: 100%;
  height: auto;
}

/****** video ******/
.video-area {
  width: 100%;
  padding: 20px 10px;
  box-sizing: border-box;
  background: #ffffff;
}
.video-area .video-inner-area {
  width: 94%;
  box-sizing: border-box;
  margin: 0 auto;
}
.video-area .video-inner-area .video-exp-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 10px;
  text-align: center;
}

/****** experience ******/
.experience-area {
  width: 100%;
  padding: 20px 10px;
  box-sizing: border-box;
  background: #fdf4f7;
}
.experience-area .experience-inner-area {
  width: 94%;
  box-sizing: border-box;
  margin: 0 auto;
}

/****** contact ******/
.contact-area {
  width: 100%;
  padding: 20px 10px;
  box-sizing: border-box;
  background: #ffffff;
}
.contact-area .contact-inner-area {
  width: 94%;
  box-sizing: border-box;
  margin: 0 auto;
}
.contact-area .contact-inner-area .contact-cont-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 30px;
  font-size: 1.6rem;
  line-height: 2.6rem;
  font-weight: bold;
}
.contact-area .contact-inner-area .contact-cont-area .contact-cont-pos {
  box-sizing: border-box;
  padding-bottom: 30px;
  display: block;
}
.contact-area .contact-inner-area .contact-cont-area .contact-cont-pos .contact-txt-pos {
  box-sizing: border-box;
  font-size: 1.6rem;
  line-height: 2.6rem;
  padding-bottom: 20px;
}
.contact-area .contact-inner-area .contact-cont-area .contact-cont-pos .contact-pic-pos {
  box-sizing: border-box;
  width: 100%;
  padding-left: 0;
  text-align: center;
}
.contact-area .contact-inner-area .contact-cont-area .contact-cont-pos .contact-pic-pos img {
  width: 150px;
  height: auto;
}

/****** contact bottom ******/
.contact-btm-area {
  width: 100%;
  padding: 20px 10px;
  box-sizing: border-box;
  background: #fdf4f7;
}
.contact-btm-area .contact-btm-inner-area {
  width: 94%;
  box-sizing: border-box;
  margin: 0 auto;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 30px;
  font-size: 1.6rem;
  line-height: 2.6rem;
  font-weight: bold;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-cont-pos {
  box-sizing: border-box;
  padding-bottom: 30px;
  display: block;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-cont-pos .contact-btm-txt-pos {
  box-sizing: border-box;
  font-size: 1.6rem;
  line-height: 2.6rem;
  padding-bottom: 20px;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-cont-pos .contact-btm-pic-pos {
  box-sizing: border-box;
  width: 100%;
  padding-left: 0;
  text-align: center;
}
.contact-btm-area .contact-btm-inner-area .contact-btm-cont-area .contact-btm-cont-pos .contact-btm-pic-pos img {
  width: 150px;
  height: auto;
}

/****** example ******/
.exp-area {
  width: 100%;
  padding: 20px 20px;
  box-sizing: border-box;
  background: #ffffff;
}
.exp-area .exp-inner-area {
  width: 100%;
  box-sizing: border-box;
  margin: 0 auto;
}
.exp-area .exp-inner-area .boccia-exp-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  margin-bottom: 40px;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-ttl-pos {
  box-sizing: border-box;
  background: #fdf4f7;
  padding: 10px 10px;
  text-align: center;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-ttl-pos .boccia-ttl {
  font-size: 1.8rem;
  line-height: 2.8rem;
  color: #ee86b3;
  font-weight: bold;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-cont-pos {
  box-sizing: border-box;
  padding: 15px;
  display: block;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-cont-pos .boccia-pic-pos {
  box-sizing: border-box;
  width: 100%;
  padding-right: 0;
  text-align: center;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-cont-pos .boccia-pic-pos img {
  width: 180px;
  height: auto;
}
.exp-area .exp-inner-area .boccia-exp-area .boccia-cont-pos .boccia-txt-pos {
  box-sizing: border-box;
  font-size: 1.4rem;
  line-height: 2.4rem;
}
.exp-area .exp-inner-area .supervision-exp-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-ttl-pos {
  box-sizing: border-box;
  background: #fdf4f7;
  padding: 10px 10px;
  text-align: center;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-ttl-pos .supervision-ttl {
  font-size: 1.8rem;
  line-height: 2.8rem;
  color: #ee86b3;
  font-weight: bold;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos {
  box-sizing: border-box;
  padding: 15px;
  display: block;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-left-pos {
  box-sizing: border-box;
  width: 100%;
  display: flex;
  padding-bottom: 20px;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-left-pos .sup-l-pic {
  box-sizing: border-box;
  width: 90px;
  padding-right: 10px;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-left-pos .sup-l-pic img {
  width: 80px;
  height: auto;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-left-pos .sup-l-txt {
  box-sizing: border-box;
  flex: 1;
  font-size: 1.4rem;
  line-height: 2.4rem;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-left-pos .sup-l-txt .sup-l-name {
  font-size: 1.6rem;
  line-height: 2.6rem;
  padding-bottom: 10px;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-right-pos {
  box-sizing: border-box;
  width: 100%;
  display: flex;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-right-pos .sup-r-pic {
  box-sizing: border-box;
  width: 90px;
  padding-right: 10px;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-right-pos .sup-r-pic img {
  width: 80px;
  height: auto;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-right-pos .sup-r-txt {
  box-sizing: border-box;
  flex: 1;
  font-size: 1.4rem;
  line-height: 2.4rem;
}
.exp-area .exp-inner-area .supervision-exp-area .supervision-cont-pos .supervision-right-pos .sup-r-txt .sup-r-name {
  font-size: 1.6rem;
  line-height: 2.4rem;
  padding-bottom: 10px;
}

/****** recommend ******/
.recommend-area {
  width: 100%;
  padding: 20px;
  box-sizing: border-box;
  background: #fdf4f7;
}
.recommend-area .recommend-inner-area {
  width: 100%;
  box-sizing: border-box;
  margin: 0 auto;
}
.recommend-area .recommend-inner-area .recommend-list {
  list-style: none;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 15px;
  margin-bottom: 20px;
}
.recommend-area .recommend-inner-area .recommend-list:last-child {
  list-style: none;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 15px;
  margin-bottom: 0;
}
.recommend-area .recommend-inner-area .recommend-list .check-cont {
  display: flex;
  align-items: flex-start;
  font-size: 1.6rem;
  line-height: 2.6rem;
}
.recommend-area .recommend-inner-area .recommend-list .check-cont img {
  width: 20px;
  height: 20px;
  margin-right: 10px;
  display: block;
  margin-top: 0.2em;
}

/****** program ******/
.program-area {
  width: 100%;
  padding: 20px;
  box-sizing: border-box;
  background: #ffffff;
}
.program-area .program-inner-area {
  width: 100%;
  box-sizing: border-box;
  margin: 0 auto;
}
.program-area .program-inner-area .program-cont-area {
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 15px;
  display: block;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .info-list {
  list-style: none;
  font-size: 1.4rem;
  line-height: 2.4rem;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .info-list li {
  margin-bottom: 20px;
  box-sizing: border-box;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .info-list li:last-child {
  margin-bottom: 0;
  box-sizing: border-box;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos {
  box-sizing: border-box;
  flex: 1;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .label {
  display: inline-flex;
  align-items: center;
  font-weight: bold;
  padding-left: 15px;
  position: relative;
  color: #ee86b3;
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .label::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #ebbb37;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.program-area .program-inner-area .program-cont-area .program-txt-pos .program-note {
  font-size: 1.2rem;
  line-height: 2.42rem;;
  padding-top: 10px;
  padding-left: 0;
}
.program-area .program-inner-area .program-cont-area .program-pic-pos {
  box-sizing: border-box;
  width: 100%;
  padding-top: 20px;
  padding-left: 0;
  text-align: center;
}
.program-area .program-inner-area .program-cont-area .program-pic-pos img {
  width: 180px;
  height: auto;
}

/****** schedule ******/
.schedule-area {
  width: 100%;
  padding: 20px;
  box-sizing: border-box;
  background: #fdf4f7;
}
.schedule-area .schedule-inner-area {
  width: 100%;
  box-sizing: border-box;
  margin: 0 auto;
  display: block;
}
.schedule-area .schedule-inner-area .sche-left-box {
  width: 100%;
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 15px;
  margin-bottom: 20px;
}
.schedule-area .schedule-inner-area .sche-left-box .sche-sub-ttl {
  font-size: 1.8rem;
  line-height: 2.8rem;
  font-weight: bold;
  text-align: center;
}
.schedule-area .schedule-inner-area .sche-left-box .sche-main-ttl {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  text-align: center;
  padding-bottom: 10px;
}
.schedule-area .schedule-inner-area .sche-left-box .sche-main-ttl span {
  font-size: 5.4rem;
  line-height: 6.4rem;
  color: #ee86b3;
}
.schedule-area .schedule-inner-area .sche-left-box .sche-l-note {
  font-size: 1.2rem;
  line-height: 2.2rem;
}

.schedule-area .schedule-inner-area .sche-right-box {
  width: 100%;
  box-sizing: border-box;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 15px;
}
.schedule-area .schedule-inner-area .sche-right-box .sche-date-txt {
  font-size: 1.6rem;
  line-height: 2.6rem;
  color: #ee86b3;
  font-weight: bold;
  padding-bottom: 10px;
}
.schedule-area .schedule-inner-area .sche-right-box .sche-cont-txt {
  font-size: 1.4rem;
  line-height: 2.4rem;
  padding-bottom: 10px;
}
.schedule-area .schedule-inner-area .sche-right-box .sche-caution-txt {
  font-size: 1.2rem;
  line-height: 2.2rem;
}

/****** footer ******/
footer {
  box-sizing: border-box;
  background: #ffffff;
  padding: 25px 10px;
  border-top: 1px solid #e4e4e4;
}

.floating-btn {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  background-color: #ffffff;
  color: #ffffff;
  padding: 15px 10px;
  border-radius: 50px;
  box-shadow: 0 0 10px rgba(0,0,0,0.2);
  box-sizing: border-box;
  border: 5px solid #ee86b3;
  max-width: 90%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.floating-btn .floating-btn-txt {
  display: flex;
  align-items: center;
  font-size: 2.0rem;
  line-height: 2.0rem;
  font-weight: bold;
  color: #404040;
}
.floating-btn .floating-btn-txt img {
  width: 30px;
  height: 30px;
  margin-right: 10px;
  display: block;
}
}



/****** clearfix ******/
.clearfix::after {
    content: "";
    display: block;
    clear: both;
}

/****** common style ******/
.mb5 { margin-bottom: 5px; }
.mb10 { margin-bottom: 10px; }
.mb20 { margin-bottom: 20px; }
.mb30 { margin-bottom: 30px; }
.mb40 { margin-bottom: 40px; }
.mb50 { margin-bottom: 50px; }
.mb60 { margin-bottom: 60px; }
.mb70 { margin-bottom: 70px; }
.mb80 { margin-bottom: 80px; }
.mb90 { margin-bottom: 90px; }
.mb100 { margin-bottom: 100px; }