@charset "utf-8";
/* ------------------------------------------------------------ common */

h2{ font-size: 50px; letter-spacing: 0.06em; font-family: "fot-tsukuardgothic-std", sans-serif; font-weight: 700; font-style: normal; text-align: center; line-height: 150%; font-feature-settings: "palt"; }
h2 img{ display: block; margin: 0 auto 35px; height: auto; }

.fot{ font-family: "fot-tsukuardgothic-std", sans-serif; font-weight: 700; font-style: normal; }
.din{ font-family: "dinosaur", sans-serif; font-weight: 500; font-style: normal; }


.free{ width: 685px; margin: 1.5% auto 3%; }
.free li{ width: 215px; height: 80px; float: left; margin: 0 18px 0 0; padding: 25px 0 0; box-sizing: border-box; border-radius: 10px; color: #fff; font-family: "fot-tsukuardgothic-std", sans-serif; font-weight: 700; font-style: normal; font-size: 30px; text-align: center; }
.free li:first-of-type{ background: #41a2da; }
.free li:nth-of-type(2){ background: #8dce5d; }
.free li:last-of-type{ margin: 0; background: #ef8ea5; }


.quo{ position: relative; display: flex; align-items: center; justify-content: center; width: 830px; height: 140px; margin: 0 auto; background: #ffd150; border-radius: 100px; box-shadow: 6.428px 7.66px 0px 0px rgba(4, 0, 0, 0.15); font-family: "fot-tsukuardgothic-std", sans-serif; font-weight: 700; font-style: normal; }
.quo:before{ position: absolute; content: ""; top: -35px; right: -10px; width: 64px; height: 50px; background: url(../images/campaign/img_04.png) center/cover no-repeat; }

.quo img{ width: 120px; height: auto; margin: 0 20px 0 0; }
.quo span{ line-height: 250%; font-feature-settings: "palt"; }
.quo small{ padding: 0 0 5px; border-bottom: 2px dotted #000; font-size: 29px; }
.quo strong{ padding: 0 0 5px; font-size: 34px; border-bottom: 2px dotted #000; }


.table{ width: 680px; margin: 0 auto; }
.table .box{ display: flex; align-items: center; box-sizing: border-box; padding: 15px 30px; margin: 0 0 30px; border: 3px solid #7d7d7d; border-radius: 10px; background: #fff; font-feature-settings: "palt"; }
.table .box:last-of-type{ margin: 0; }
.table .box .index{ padding: 0 32px 0 0; font-size: 40px; font-family: "dinosaur", "fot-tsukuardgothic-std", sans-serif; font-weight: 500; font-style: normal; width: 150px; text-align: center; }
.table .box .txt{ width: 400px; padding: 0 0 0 32px; border-left: 2px solid #7d7d7d; font-size: 36px; line-height: 150%; font-family: "fot-tsukuardgothic-std", sans-serif; font-weight: 700; font-style: normal; }



/* ------------------------------------------------------------ fv */
#fv{ width: 100%; /* height: 100vh; */ background: url(../images/campaign/bg_01.jpg) center/cover no-repeat; }
#fv .bg{ height: 100vh; min-height: 1200px; box-sizing: border-box; padding: 10vw 0 0; background: url(../images/campaign/bg_02.png) center bottom/100% no-repeat; }

#fv h1{ width: 940px; margin: 0 auto -15px; background: url(../images/campaign/bg_h1.png) center bottom/70% no-repeat; padding: 0 0 1.5%; }
#fv h1 img{ width: 100%; height: auto; }

#fv .date{ text-align: center; }
#fv .date p{ padding: 0 0 1.5%; font-size: 72px; font-family: "dinosaur", sans-serif; font-weight: 500; font-style: normal; }
#fv .date p span{ font-size: 115px; }
#fv .date p small{ padding: 2px 10px; font-size: 51px; color: #fff; background: #000; border-radius: 50px; }
#fv .date p .sky{ font-size: 144px; color: #41a2da; }

#fv .date .time{ width: 832px; margin: 0 auto; }
#fv .date dl{ float: left; display: flex; align-items: center; font-size: 20px; }
#fv .date dl:first-of-type{ margin: 0 20px 0 0; }
#fv .date dl dt{ padding: 10px 23px; color: #fff; background: #000; border-radius: 10px 0 0 10px; border: 2px solid #000; font-weight: 700; }
#fv .date dl dd{ padding: 10px 23px; background: #fff; border-radius: 0 10px 10px 0; border: 2px solid #000; letter-spacing: 0.04em; font-weight: 700; font-family: "dinosaur", "noto-sans", sans-serif; }
#fv .date dl dd.num{ font-size: 24px; padding: 8px 23px; }



/* ------------------------------------------------------------ about */
#about{ padding: 30px 0 40px; background: url(../images/campaign/bg_about.png) center no-repeat; }
#about .item{ width: 100%; height: auto; }

#about h2{ padding: 100px 0 0; background: url(../images/campaign/text.png) calc(50% + 300px) 50px/230px no-repeat; line-height: 120%; }
#about h2 img{ width: 250px; }
#about p{ padding: 30px 0 90px; text-align: center; line-height: 200%; }



/* ------------------------------------------------------------ facility */
#facility{ position: relative; padding: 100px 0 70px; background: #faf8f0; }
#facility:after{ position: absolute; bottom: 155px; left: calc(50% - 300px); content: ""; width: 960px; height: 311px; background: url(../images/campaign/img_03.png) center/cover no-repeat; }
#facility .bg{ background: url(../images/campaign/img_01.png) calc(50% - 55%) top/470px no-repeat; }

#facility h2{ background: url(../images/campaign/img_02.png) calc(50% + 400px) center/170px no-repeat; }
#facility h2 img{ width: 400px; }

#facility ul{ padding: 45px 0 0; }



/* ------------------------------------------------------------ program */
#program{ padding: 85px 0 100px; background: url(../images/campaign/bg_dot.jpg) center; }
#program .bg{ background: url(../images/campaign/bg_program.png) center top no-repeat; }

#program .free{ margin: 30px auto 80px; }

#program h2 img{ width: 350px; }
#program .subttl{ padding: 30px 0 35px; text-align: center; }

#program .quo{ width: 900px; height: 180px; }
#program .quo span{ line-height: 280%; }
#program .quo img{ width: 135px; }
#program .quo small{ font-size: 32px; }
#program .quo strong{ font-size: 38px; }



/* ------------------------------------------------------------ schedule */
#schedule{ padding: 100px 0 60px; }
#schedule h2 img{ width: 400px; }

#schedule .table{ padding: 30px 0 0; }
#schedule .table .box .index,
#schedule .table .box .txt{ font-size: 24px; }

#schedule .map{ width: 100%; height: 450px; margin: 60px 0 50px; }
#schedule .map iframe{ width: 100%; height: 100%; }

#schedule .btn_green a{ display: block; width: 380px; height: 70px; margin: 0 auto; padding: 23px 0 0; border-radius: 50px; box-sizing: border-box; color: #fff; background: #8dce5d; text-align: center; font-size: 15px; }
#schedule .btn_green a svg{ vertical-align: middle; }
#schedule .btn_green a path{ fill: #fff; }



/* ------------------------------------------------------------ contact */
#contact{ padding: 115px 0 145px; background: url(../images/campaign/bg_contact.jpg) center/cover no-repeat; text-align: center; }
#contact h2{ padding: 0 0 30px; font-size: 50px; letter-spacing: 0.06em; font-family: "fot-tsukuardgothic-std", sans-serif; font-weight: 700; font-style: normal; }
#contact h3{ padding: 0 0 30px; font-size: 26px; letter-spacing: 0.06em; font-family: "fot-tsukuardgothic-std", sans-serif; font-weight: 700; font-style: normal; }

#contact .flex{ width: 900px; margin: 0 auto; justify-content: space-between; display: flex; align-items: center; }

#contact .tell{ width: 430px; }
#contact .tell p{ padding: 0 0 20px; font-size: 20px; letter-spacing: 0.06em; line-height: 150%; font-family: "fot-tsukuardgothic-std", sans-serif; font-weight: 700; font-style: normal; }
#contact .tell a{ line-height: 100%; display: block; font-size: 60px; letter-spacing: 0.04em; font-family: "dinosaur", sans-serif; font-weight: 500; font-style: normal; }
#contact .tell a small{ display: block; padding: 20px 0 0; font-size: 16px; letter-spacing: 0.06em; line-height: 100%; font-family: "fot-tsukuardgothic-std", sans-serif; font-weight: 700; font-style: normal; }
#contact .tell a img{ padding: 0 5px 0 0; vertical-align: baseline; }

#contact .btn_w a{ display: block; width: 420px; height: 70px; padding: 27px 0 0 20px; background: #fff url(../images/common/icn_mail.svg) calc(50% - 130px) center/25px no-repeat; box-sizing: border-box; border-radius: 50px; font-size: 15px; box-shadow: 6.428px 7.66px 0px 0px rgba(4, 0, 0, 0.2); }



/* ------------------------------------------------------------ footer */
footer{ padding: 65px 0 40px; }

footer p img{ width: 433px; height: auto; padding: 0 0 20px; }
footer p small{ font-size: 15px; padding: 0; text-align: left; }

footer .btn_green{ width: 380px; }
footer .btn_green a{ display: block; width: 100%; height: 70px; padding: 27px 0 0; text-align: center; color: #fff; box-sizing: border-box; background: #8dce5d; border-radius: 50px; }

footer small{ display: block; padding: 65px 0 0; text-align: center; font-size: 10px; }




/* ------------------------------------------------------------
	mobile 
------------------------------------------------------------ */
@media only screen and (max-width: 640px) {
/* ------------------------------------------------------------ common */

h2{ font-size: 25px; font-feature-settings: "palt"; }
h2 img{ margin: 0 auto 20px; }


.free{ width: 100%; margin: 15px auto 30px; }
.free li{ width: calc(100% / 3 - 1.5%); height: 40px; margin: 0 2% 0 0; padding: 12px 0 0; border-radius: 5px; font-size: 15px; }


.quo,
#program .quo{ flex-direction: column; width: 95%; height: 100px; }

.quo:before,
#program .quo:before{ top: -22px; right: -5px; width: 44px; height: 35px; }

.quo small,
#program .quo small{ padding: 0 0 7px; font-size: 15px; }

.quo strong,
#program .quo strong{ font-size: 18px; padding: 0 50px 0 0; border-bottom: none; line-height: 130%; text-align: center; display: block;  }

.quo img,
#program .quo img{ width: 80px; margin: 0; position: absolute; bottom: 5px; right: 30px; }


.table{ width: 100%; }
.table .box{ padding: 5px 10px; margin: 0 0 15px; border-radius: 5px; }
.table .box .index{ padding: 0 4% 0 0; font-size: 17px; width: 25%; }
.table .box .txt{ width: 70%; padding: 0 0 0 4%; font-size: 19px; }



/* ------------------------------------------------------------ fv */
#fv{ background: url(../images/campaign/bg_01-sp.jpg) center/cover no-repeat; }
#fv .bg{ height: auto; min-height: auto; padding: 5vw 0 0; background: none; }

#fv h1{ width: 100%; margin: 0 auto; padding: 0 0 20px; background: url(../images/campaign/bg_h1.png) center bottom/90% no-repeat; }

#fv .date p{ padding: 0 0 20px; font-size: 28px; }
#fv .date p span{ font-size: 50px; }
#fv .date p .sky{ font-size: 70px; }
#fv .date p small{ padding: 1px 5px; font-size: 25px; }

#fv .date .time{ width: 90%; }

#fv .date dl{ flex-direction: column; font-size: 13px; }
#fv .date dl:first-of-type{ margin: 0 2% 0 0; width: 33%; }
#fv .date dl:last-of-type{ width: 65%; }

#fv .date dl dt{ padding: 5px 5px 6px; border-radius: 5px 5px 0 0; box-sizing: border-box; width: 100%; }
#fv .date dl dd{ padding: 5px 5px 6px; border-radius: 0 0 5px 5px; box-sizing: border-box; width: 100%; }
#fv .date dl dd.num{ font-size: 14px; padding: 5px 5px 6px; }

#fv .free{ width: 90%; }
#fv .item{ width: 100%; height: auto; padding: 20px 0 0; }



/* ------------------------------------------------------------ about */
#about{ padding: 15px 0; background: url(../images/campaign/bg_about-sp.png) center 110px/100% no-repeat; }
#about h2{ position: relative; padding: 60px 0 0; background: none; }
#about h2:before{ position: absolute; content: ""; top: 20px; right: -13px; width: 130px; height: 65px; background: url(../images/campaign/text.png) center/cover no-repeat; }
#about h2 img{ width: 130px; }
#about p{ padding: 10px 0 20px; font-size: 13px; }

#about .pic{ width: 100%; height: auto; margin: 0 auto 20px; }



/* ------------------------------------------------------------ facility */
#facility{ padding: 50px 0 0; }
#facility:after{ display: none; }
#facility .bg{ background: url(../images/campaign/img_01.png) -50px top/170px no-repeat; }

#facility h2{ background: none; }
#facility h2 img{ width: 210px; }

#facility ul{ padding: 30px 0; }



/* ------------------------------------------------------------ program */
#program{ padding: 50px 0; background: url(../images/campaign/bg_dot.jpg) center/30px; }
#program h2 img{ width: 190px; }
#program .subttl{ padding: 10px 0 25px; font-size: 14px; }

#program .free{ margin: 15px auto 40px; }

#program .quo{ width: 100%; }
#program .quo img{ right: 13px; }



/* ------------------------------------------------------------ schedule */
#schedule{ padding: 50px 0; }
#schedule h2 img{ width: 210px; }

#schedule .table .box .index,
#schedule .table .box .txt{ font-size: 16px; }

#schedule .map{ width: 375px; height: 375px;  margin: 40px auto 25px; }

#schedule .btn_green a{ width: 80%; height: 50px; padding: 13px 0 0; font-size: 13px; }



/* ------------------------------------------------------------ contact */
#contact{ padding: 50px 0; background: url(../images/campaign/bg_01-sp.jpg) center/cover no-repeat; }
#contact h2{ padding: 0 0 15px; font-size: 25px; }
#contact h3{ padding: 0 0 25px; font-size: 17px; }
#contact .flex{ width: 100%; flex-direction: column; }

#contact .tell{ width: 100%; }
#contact .tell p{ padding: 0 0 15px; font-size: 15px; }
#contact .tell a{ font-size: 35px; margin: 0 0 20px; }
#contact .tell a img{ width: 25px; height: auto; }
#contact .tell a small{ padding: 10px 0 0; font-size: 13px; }

#contact .btn_w{ width: 95%; }
#contact .btn_w a{ width: 100%; height: 50px; padding: 19px 0 0 20px; font-size: 14px; background: #fff url(../images/common/icn_mail.svg) calc(50% - 110px) center/20px no-repeat; }



/* ------------------------------------------------------------ footer */
footer{ padding: 30px 0; }
footer p{ padding: 0 0 20px; }
footer p img{ width: 280px; padding: 0 0 10px; }
footer p small{ font-size: 12px; }

footer .btn_green{ width: 80%; margin: 0 auto; }
footer .btn_green a{ height: 50px; padding: 19px 0 0; font-size: 14px; }

footer small{ padding: 25px 0 0; }





}



