html {
    width: 100%;
    margin: 0 auto;
    }

body {
    position: relative;
	width: 100%;
    min-height: 100vh;
    box-sizing: border-box;
	margin: 0 auto;
	padding-bottom: 40px;
    background: url("../../assets/images/common/bg.png");
	font-family: 'Noto Sans JP', sans-serif;
    font-size: clamp(0.75rem, 0.659rem + 0.45vw, 1rem); /* 12px-16pxで可変 */
    font-feature-settings: "palt";
    line-height: 2em;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    }

*, *:before, *:after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
    }

h1, h2, h3, h4, h5, h6 {
	font-family: 'Noto Sans JP', sans-serif;
	}

h1 {
    margin: 0;
	padding: 0;
	color: #000000;
    font-size: clamp(1.5rem, 1.227rem + 1.36vw, 2.25rem); /* 24px~36pxで可変 */
    font-weight: 700;
    letter-spacing: -0.05em;
    line-height: 1.2;
	}

h2 {
    clear: both;
    width: 100%;
    margin: 0 auto 40px auto;
    padding: 0;
    color: #000000;
    font-size: clamp(1.25rem, 1.159rem + 0.45vw, 1.5rem); /* 20px~24pxで可変 */
    font-weight: 700;
    letter-spacing: -0.05em;
    line-height: 1.2;
    text-align: center;
    }

h3 {
    width: 100%;
    margin: 0 auto 20px auto;
    padding: 0;
    color: #000000;
    font-size: clamp(1.125rem, 1.08rem + 0.23vw, 1.25rem); /* 18px~20pxで可変 */
    font-weight: 700;
    letter-spacing: -0.05em;
    line-height: 1.2;
    text-align: left;
    }

span.title01 {
    color: #ff9c00;
    }    

@media only screen and (max-width: 768px) {
    h1 {
        margin: 0;
	    padding: 0;
	    }

    h2 {
        margin: 0 auto 30px auto;
        padding: 0;
        }
    
    h3 {
        margin: 0 auto 20px auto;
        padding: 0;
        }
}

a:link {
	background-color: transparent;
	color: #000000;
	text-decoration: underline;
	}

a:visited {
	background-color: transparent;
	color: #000000;
	text-decoration: none;
	}

a:active {
	background-color: transparent;
	color: #000000;
	text-decoration: none;
	}

a:hover {
	background-color: transparent;
	color: #000000;
	text-decoration: none;
	}

.alpha a:hover img {
	opacity: 0.8;
	filter: alpha(opacity=70);
	-ms-filter: "alpha(opacity=70)";
	}

img {
	max-width: 100%;
    width: 100%;
    vertical-align: top;
	}

/*__________________________________________________

  header
  __________________________________________________*/
header {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    background: transparent;
    }

@media only screen and (max-width: 768px) {
    header {
        width: 100%;
        margin: 0 auto;
        padding: 0;
        background: transparent;
        }
}


/*__________________________________________________

  container
  __________________________________________________*/
.container01 {
    width: 100%;
    max-height: 894px;
    height: 100%;
    margin: 0 auto 0 auto;
    padding: 0;
    background: url("../../assets/images/common/intro_bg_pc.png") no-repeat;
    background-size: cover;
    background-position: top;
    text-align: center;
    }

.container02 {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.container03 {
    width: 100%;
    max-height: 4800px;
    height: 100%;
    margin: 0 auto 0 auto;
    padding: 0;
    background: url("../../assets/images/common/group_bg_pc.png") no-repeat;
    background-size: cover;
    background-position: top;
    text-align: center;
    }

@media only screen and (max-width: 768px) {
    .container01 {
        width: 100%;
        max-height: 767px;
        height: 100%;
        margin: 0 auto;
        padding: 0;
        background: url("../../assets/images/common/intro_bg_sp.png") no-repeat;
        background-size: cover;
        background-position: top;
        text-align: center;
        }

    .container02 {
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }

    .container03 {
        width: 100%;
        max-height: 6800px;
        height: 100%;
        margin: 0 auto 0 auto;
        padding: 0;
        background: url("../../assets/images/common/group_bg_pc.png") no-repeat;
        background-size: cover;
        background-position: top;
        text-align: center;
        }
}

/*__________________________________________________    

  heroBox
  __________________________________________________*/
.heroBox {
	width: 100%;
	margin: 0 auto 30px auto;
	padding: 0;
    background: transparent;
    text-align: center;
	}

@media only screen and (max-width: 768px) {
    .heroBox {
	    width: 100%;
	    margin: 0 auto 0 auto;
	    padding: 0;
	    }
}

/*__________________________________________________    

  introBox
  __________________________________________________*/
.introBox {
	width: 100%;
	margin: 60px auto 0 auto;
	padding: 0 0 200px 0;
    text-align: center;
	}

.introBox h2 {
    max-width: 649px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 60px 0 0 0;
    text-align: center;
    }

.introBox .intro-box {
    max-width: 1050px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .introBox {
        width: 100%;
        margin: 30px auto 0 auto;
        padding: 20px 0 0 0;
        text-align: center;
        }

    .introBox h2 {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .introBox .intro-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0 0 40px 0;
        }
}

/*__________________________________________________    

  benefitBox
  __________________________________________________*/
.benefitBox {
	width: 100%;
	margin: 0 auto 0 auto;
	padding: 90px 0 0 0;
    text-align: center;
	}

.benefitBox h2 {
    max-width: 990px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    }

.benefitBox .benefit-box {
    max-width: 1110px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.benefitBox .benefit-box p {
    max-width: 1098px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    }

.benefitBox .benefit-box .box {
    max-width: 964px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .benefitBox {
        width: 100%;
        margin: 0 auto 0 auto;
        padding: 45px 0 0 0;
        text-align: center;
        }
    
    .benefitBox h2 {
        max-width: 100%;
        width: 90%;
        margin: 0 auto 30px auto;
        padding: 0;
        }
    
    .benefitBox .benefit-box {
        max-width: 100%;
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }
}

/*__________________________________________________    

  presentBox
  __________________________________________________*/
.presentBox {
	width: 100%;
	margin: 60px auto 90px auto;
	padding: 0;
    text-align: center;
	}

.presentBox h2 {
    max-width: 608px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    text-align: center;
    }

.presentBox .present-box {
    max-width: 586px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .presentBox {
        width: 100%;
        margin: 45px auto 45px auto;
        padding: 0;
        text-align: center;
        }

    .presentBox h2 {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .presentBox .present-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
}

/*__________________________________________________    

  eventBox
  __________________________________________________*/
.eventBox {
	width: 100%;
	margin: 0 auto 60px auto;
	padding: 0;
    text-align: center;
	}

.eventBox h2 {
    max-width: 578px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    text-align: center;
    }

.eventBox .event-box {
    max-width: 960px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    padding:  0;
    }

.eventBox .event-box dl.event {
    display: flex;
    flex-wrap: wrap;
    max-width: 900px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.eventBox .event-box dl.event dt {
    width: 20%;
    margin: 0 0 15px 0;
    padding: 0 0 15px 10px;
    border-bottom: 1px solid #dddddd;
    font-size: clamp(0.875rem, 0.784rem + 0.45vw, 1.125rem); /* 14px～18pxで可変 */
    font-weight: 700;
    text-align: left;
    }

.eventBox .event-box dl.event dd {
    width: 80%;
    margin: 0 0 15px 0;
    padding: 0 0 15px 0;
    border-bottom: 1px solid #dddddd;
    font-size: clamp(0.875rem, 0.784rem + 0.45vw, 1.125rem); /* 14px～18pxで可変 */
    font-weight: 500;
    text-align: left;
    }

.eventBox .event-box p.txt01 {
    width: 100%;
    margin: 0 0 30px 0;
    padding: 0;
    font-size: clamp(0.875rem, 0.784rem + 0.45vw, 1.125rem); /* 14px～18pxで可変 */
    font-weight: 500;
    text-align: left;
    }

.eventBox .event-box p.txt02 {
    width: 100%;
    margin: 0;
    padding: 0;
    font-size: clamp(0.875rem, 0.784rem + 0.45vw, 1.125rem); /* 14px～18pxで可変 */
    font-weight: 500;
    text-align: left;
    }
    
@media only screen and (max-width: 768px) {
    .eventBox {
        width: 100%;
        margin: 0 auto 0 auto;
        padding: 0;
        text-align: center;
        }
    
    .eventBox h2 {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .eventBox .event-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto 0 auto;
        padding: 0;
        padding: 0;
        }
    
    .eventBox .event-box dl.event {
        display: flex;
        flex-wrap: wrap;
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .eventBox .event-box dl.event dt {
        width: 25%;
        margin: 0 0 15px 0;
        padding: 0 0 15px 0;
        border-bottom: 1px solid #dddddd;
        text-align: left;
        }
    
    .eventBox .event-box dl.event dd {
        width: 75%;
        margin: 0 0 15px 0;
        padding: 0 0 15px 0;
        border-bottom: 1px solid #dddddd;
        text-align: left;
        }

    .eventBox .event-box p.txt01 {
        width: 90%;
        margin: 0 0 15px 0;
        padding: 0;
        }

    .eventBox .event-box p.txt02 {
        width: 90%;
        margin: 0;
        padding: 0;
        }
}

/*__________________________________________________    

  workshopBox
  __________________________________________________*/
.workshopBox {
	width: 100%;
	margin: 60px auto 0 auto;
	padding: 0;
    text-align: center;
	}

.workshopBox h2 {
    max-width: 886px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    text-align: center;
    }

.workshopBox .workshop-box {
    max-width: 959px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .workshopBox {
        width: 100%;
        margin: 30px auto 0 auto;
        padding: 0;
        text-align: center;
        }

    .workshopBox h2 {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .workshopBox .workshop-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
}

/*__________________________________________________    

  groupBox
  __________________________________________________*/
.groupBox {
	width: 100%;
	margin: 60px auto 0 auto;
	padding: 60px 0;
    text-align: center;
	}

.groupBox h2 {
    max-width: 657px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    text-align: center;
    }

.groupBox .group-box {
    max-width: 959px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.groupBox .group-box .box {
    max-width: 968px;
    width: 100%;
    margin: 0 auto 30px auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .groupBox {
        width: 100%;
        margin: 30px auto 0 auto;
        padding: 30px 0 10px 0;
        text-align: center;
        }

    .groupBox h2 {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .groupBox .group-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }

    .groupBox .group-box .box {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 15px auto;
        padding: 0;
        }
}

/*__________________________________________________    

  voiceBox
  __________________________________________________*/
.voiceBox {
	width: 100%;
	margin: 90px auto 40px auto;
	padding: 0;
    background: transparent;
    text-align: center;
	}

.voiceBox h2 {
    max-width: 499px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    text-align: center;
    }

.voiceBox .voice-box {
    max-width: 960px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .voiceBox {
        width: 100%;
        margin: 45px auto 20px auto;
        padding: 0;
        background: transparent;
        text-align: center;
        }

    .voiceBox h2 {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .voiceBox .voice-box {
        max-width: 100%;
        width: 97%;
        margin: 0 auto;
        padding: 0;
        }
}

/*__________________________________________________    

  faqBox
  __________________________________________________*/
.faqBox {
	width: 100%;
	margin: 90px auto 40px auto;
	padding: 0;
    background: transparent;
    text-align: center;
	}

.faqBox h2 {
    max-width: 345px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    text-align: center;
    }

.faqBox .faq-box {
    max-width: 976px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .faqBox {
        width: 100%;
        margin: 45px auto 20px auto;
        padding: 0;
        background: transparent;
        text-align: center;
        }

    .faqBox h2 {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .faqBox .faq-box {
        max-width: 100%;
        width: 97%;
        margin: 0 auto;
        padding: 0;
        }
}

/*__________________________________________________    

  flowBox
  __________________________________________________*/
.flowBox {
	width: 100%;
	margin: 90px auto 90px auto;
	padding: 60px 0;
    background: #bbe1e6;
    text-align: center;
	}

.flowBox h2 {
    max-width: 347px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    text-align: center;
    }

.flowBox .flow-box {
    max-width: 976px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .flowBox {
        width: 100%;
        margin: 45px auto 45px auto;
        padding: 30px 0;
        background: #bbe1e6;
        text-align: center;
        }

    .flowBox h2 {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 10px auto;
        padding: 0;
        text-align: center;
        }
    
    .flowBox .flow-box {
        max-width: 100%;
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }
}

/*__________________________________________________    

  instaBox
  __________________________________________________*/
.instaBox {
	width: 100%;
	margin: 90px auto 90px auto;
	padding: 0;
    text-align: center;
	}

.instaBox h2 {
    max-width: 100%;
    width: 661px;
    margin: 0 auto 60px auto;
    padding: 0;
    }

.instaBox .insta-box {
    max-width: 1110px;
    width: 100%;
    height: 664px;
    margin: 0 auto;
    padding: 200px 0 0 0;
    background: url("../../assets/images/insta_bg.png") no-repeat;
    background-size: 994px;
    background-position: center;
    }

.instaBox .insta-box .unit {
    max-width: 100%;
    width: 300px;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .instaBox {
        width: 100%;
        margin: 45px auto 45px auto;
        padding: 0;
        text-align: center;
        }
    
    .instaBox h2 {
        max-width: 100%;
        width: 90%;
        margin: 0 auto 30px auto;
        padding: 0;
        }
    
    .instaBox .insta-box {
        max-width: 100%;
        width: 100%;
        height: 460px;
        margin: 0 auto;
        padding: 160px 0 0 0;
        background: url("../../assets/images/insta_bg.png") no-repeat;
        background-size: 90%;
        background-position: center;
        }
    
    .instaBox .insta-box .unit {
        max-width: 100%;
        width: 150px;
        margin: 0 auto;
        padding: 0;
        }
}

@media only screen and (max-width: 420px) {
    .instaBox {
        width: 100%;
        margin: 45px auto 45px auto;
        padding: 0;
        text-align: center;
        }
    
    .instaBox h2 {
        max-width: 100%;
        width: 90%;
        margin: 0 auto 30px auto;
        padding: 0;
        }
    
    .instaBox .insta-box {
        max-width: 100%;
        width: 100%;
        height: 240px;
        margin: 0 auto;
        padding: 60px 0 0 0;
        background: url("../../assets/images/insta_bg.png") no-repeat;
        background-size: 90%;
        background-position: center;
        }
    
    .instaBox .insta-box .unit {
        max-width: 100%;
        width: 100px;
        margin: 0 auto;
        padding: 0;
        }
}

/*__________________________________________________    

  achievementBox
  __________________________________________________*/
.achievementBox {
	width: 100%;
	margin: 90px auto 90px auto;
	padding: 0;
    background: transparent;
    text-align: center;
	}

.achievementBox .achievement-box {
    max-width: 676px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .achievementBox {
        width: 100%;
        margin: 45px auto 45px auto;
        padding: 0;
        background: transparent;
        text-align: center;
        }
    
    .achievementBox .achievement-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
}

/*__________________________________________________

  form
  __________________________________________________*/
.formBox {
    clear: both;
    max-width: 100%;
    width: 100%;
    margin: 0 auto 100px auto;
    padding: 0;
    }

.formBox h2 {
    max-width: 100%;
    width: 293px;
    margin: 0 auto 60px auto;
    padding: 0;
    }

.form-box {
    clear: both;
    max-width: 960px;
    width: 100%;
    margin: 0 auto 40px auto;
    padding: 0;
    }

.form-box p.txt01 {
    margin: 0 auto;
    padding: 0;
    text-align: center;
    }

@media only screen and (max-width: 768px) {
    .formBox {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        }

    .formBox h2 {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        }

    .form-box {
        clear: both;
        max-width: 100%;
        width: 90%;
        margin: 0 auto 0 auto;
        padding: 0;
        }
}

/*__________________________________________________

  return
  __________________________________________________*/
.return {
    clear: both;
    width: 50px;
    right: 0;
	margin: 0 0 0 auto;
	padding: 40px 0 100px 0;
    text-align: right;
	}

@media only screen and (max-width: 768px) {
	.return {
        clear: both;
        width: 50px;
        right: 0;
	    margin: 0 0 0 auto;
	    padding: 20px 0 180px 0;
        text-align: right;
	    }
}

/*__________________________________________________

  contactBox
  __________________________________________________*/
.contactBox {
    width: 640px;
    margin: 0 auto;
    padding: 0;
    }

.contactBox .contact-box {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .contactBox {
        width: 90%;
        height: auto;
        margin: 0 auto 0 auto;
        padding: 30px 0 0 0;
        }
}

/*__________________________________________________

  footer
  __________________________________________________*/
.footerBox {
    position: absolute;
    bottom: 0;
    clear: both;
    width: 100%;
	margin: 0 auto;
	padding: 0;
    background: #ffffff;
    border-top: 3px solid #57483d;
	}

.footer-box {
    max-width: 1110px;
    width: 100%;
    margin: 0 auto;
	padding: 20px 0;
	color: #000000;
	}

.footer-box .unit {
    display: flex;
    justify-content: left;
    width: 100%;
    margin: 0;
    padding: 0;
    }

.footer-box .unit .boxL {
    max-width: 122px;
    width: 30%;
    margin: 0 10px 0 0;
    }

.footer-box .unit .boxR {
    width: 70%;
    font-size: clamp(0.75rem, 0.705rem + 0.23vw, 0.875rem); /* 12px-14pxで可変 */
    font-weight: 500;
    line-height: 1.4;
    }

@media (max-width: 768px) {
    .footerBox {
        position: absolute;
        bottom: 0;
        clear: both;
        width: 100%;
        margin: 0 auto;
        padding: 0;
        background: #ffffff;
        border-top: 3px solid #57483d;
        }
    
    .footer-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 20px 0;
        }
    
    .footer-box .unit {
        display: flex;
        justify-content: left;
        width: 100%;
        margin: 0;
        padding: 0;
        }

    .footer-box .unit .boxL {
        max-width: 100%;
        width: 20%;
        margin: 0 10px 0 0;
        }

    .footer-box .unit .boxR {
        width: 80%;
        font-size: clamp(0.75rem, 0.705rem + 0.23vw, 0.875rem); /* 12px-14pxで可変 */
        font-weight: 500;
        line-height: 1.4;
        }
}


/*__________________________________________________

  common
  __________________________________________________*/
@media (max-width: 768px) {
	.pconly {
	    display: none;
	    }
}

@media (min-width: 768px) {
	.sponly {
	    display: none;
	    }
}

@media screen and (max-width: 1024px) {
    .br-sp { display: none; }
}

@media screen and (min-width: 768px) {
    .br-pc { display: none; }
}

hr.type01 {
	margin: 10px 0 40px 0;
	padding: 0;
	border: none;
    border-top: dotted 1px #cccccc;
    height: 1px;
    color: #FFFFFF;
	}

