@charset "utf-8";
/* CSS Document */
body {
  font-size: 16px;
  color: #333;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-style: normal;
}
strong, #form strong {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
    color: mediumpurple;
}
p {
  line-height: 1.75;
  padding: 5px 0px;
    text-align: justify;
}
#news a, #actas_lesson a{
  color: deeppink;
}

#news a:visited, #actas_lesson a:visited{
  color: deeppink;
}
#news a:hover, #actas_lesson a:hover{
  color:deeppink;
}
ul {
  line-height: 1.75;
  list-style: none;
}
.red {
  color: red;
  font-size: 0.7rem;
}
.end {
  text-align: right;
  padding-right: 10px;
}
i {
  margin-right: 10px;
}
#about, #news, #actas_lesson, #technique, #form {
  padding: 0px 10px;
}
/*header*/
.header_wrapper {
  width: 100%;
    padding-top:5px;
}
header {
  padding-bottom: 10px;
}
.header_container {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.header_container img {
  align-self: flex-start;
}
.header_container h1 {
  font-size: 0.7rem;
}
/*見出し*/
#main_visual h2 {
  font-family: "Aoboshi One", serif;
  font-weight: 400;
  font-style: normal;
  text-align: center;
  font-size: 3rem;
  color: #fff;
}
h3 img {
  width: 30%;
  display: block;
  margin: 0 auto;
}
#news h4, #actas_lesson h4, #technique h4, #form h4 {
  font-size: 110%;
  margin-top: 30px;
  padding-bottom: 5px;
  margin-bottom: 5px;
  border-bottom: 1px solid #ccc;
  font-weight: 500;
}
#team_details h5 {
  padding: 20px 0px 0px 0px;
  font-size: 2.5rem;
  color: mediumpurple;
  font-family: "Kosugi", serif;
  font-weight: 400;
  font-style: normal;
    	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
    letter-spacing: 0.1em;
}

h5::before,
h5::after {
	content: '';
	width: 3px;
	height: 40px;
	background-color: mediumpurple;
}

h5::before {
	margin-right: 30px;
	transform: rotate(-35deg)
}
h5::after {
	margin-left: 30px;
	transform: rotate(35deg)
}

/*g-nav*/
.nav_wrapper {
  width: 100%;
  padding: 15px 0px;
}
#g_nav ul {
  display: flex;
  justify-content: space-around;
  list-style: none;
}
#g_nav li a {
  text-decoration: none;
  color: gray;
  font-family: "UD Shin Go Conde90 M", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  font-weight: bold;
}
/*main_visual*/
.main_visual_wrapper {
  width: 100%;
  padding: 15px 0px;
  background-color: mediumpurple;
}
/*about*/
.about_wrapper {
  width: 100%;
  padding: 15px 10px 40px 10px;
}
.about_container h4 {
  color: mediumpurple;
  font-weight: 500;
  margin: 10px 0px 0px 0px;
    font-size: 110%;
}
.about_container {
  display: flex;
}
.about_container img {
  margin: 10px 20px;
  width: 40%;
  align-self: flex-start;
}
.about_container p {
  padding: 5px 0px 10px 0px;
}
.about_team {
  display: block;
  text-align: right;
  font-weight: 500;
  color: deeppink;
  padding-top: 10px;
}

/*news*/
.news_wrapper {
  width: 100%;
  background-color: #EFE9F9;
  padding: 15px 10px 40px 10px;
}


/*youtube*/
.movie_container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
    margin-top:20px;
}
.movie_container .movie {
  margin: 0px 10px;
}
.movie p {
  text-align: center;
  margin-top: 5px;
  margin-bottom: 0px;
}
/*photo*/
.photo_2022 {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.photo_2022 {
  margin: 20px 0px 10px 0px;
}
/*lesson*/
.actas_lesson_wrapper {
  width: 100%;
  padding: 15px 10px 40px 10px;
}
#actas_lesson .team_photo {
    width:70%;
}

/*所属チームについて*/
ul.team {
  display: flex;
  flex-wrap: wrap;
}
ul.team li {
  background-color: #EFE9F9;
  padding: 10px 20px;
  margin: 10px;
  width: 40%;
  font-weight: 500;
border-radius: 10px;
    color:#333;
}
ul.team li a {
  display: block;
  height: 100%;
  width: 100%;
}
ul .name_font {
    display: block;
    font-size: 120%;
    font-family: "Kosugi", serif;
  font-weight: 400;
  font-style: normal;
    letter-spacing: 0.1em;
        
}

#team_details h6, #technique h6 {
    font-weight: 500;
    font-size: 110%;
    text-align: center;
    padding:20px 0px 0px 0px;
    color:deeppink;
}

#team_details h6::before,
#team_details h6::after,
#technique h6::before,
#technique h6::after{
	content: '\f005';
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
    margin:10px;
    color: deeppink;
	width: 3px;
	height: 40px;
}

#team_details p.sub_ttl {
  text-align: center;
  margin-top: 0px;
}

#team_details .team {
  margin: 20px auto;
}

#team_details img.team_photo {
  width: 40%;
  margin: 20px auto;
  display: block;
}
#team_details .team p{
    width:90%;
    margin:0 auto;
}
/*チーム詳細表*/
#team_details dl {
  width: 90%;
  line-height: 1.75;
  margin: 20px auto 50px auto;
}
#team_details dt {
  background-color: #EFE9F9;
  padding: 5px 10px;
  font-weight: 500;
}
#team_details dd {
  background-color: #f8f8f8;
  padding: 5px 10px;
  font-weight: 400;
}
/*technique*/
.technique_wrapper {
  width: 100%;
  background-color: #EFE9F9;
  padding: 15px 10px 40px 10px;
}
/*youtube*/
#technique .movie iframe {
  margin: 0 auto;
  display: block;
  margin-top: 20px;
}
#technique .movie p {
  margin-top: 0px;
}
#technique ul.technique_more, #actas_lesson ul.technique_more {
    line-height: 2;
    margin:20px auto;
    width:90%;
}

#technique ul li, #actas_lesson ul.technique_more li {
    font-weight: 500;
}

#technique ul li::before, #actas_lesson ul.technique_more li::before {
  content: '\e533';
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
    margin-right:10px;
    color:mediumpurple;
}
/*schedule*/
#schedule {
    padding:20px 0px;
    margin-top:0px;
}

#schedule td.month {
    background-color: #EFE9F9;
    width:10%;
    text-align: center;
}

#schedule td.day {
background-color: #EFE9F9;
    padding:5px 10px;
    width:13%;
    text-align: center;
}

#schedule td.place {
    background-color: #EFE9F9;
    width:75%;
    text-align: center;
}
#schedule table , td, th {
	border: 1px solid #ccc;
	border-collapse: collapse;
    margin:0 auto;
    text-align: center;
}
#schedule td, th {
	padding: 5px;
}

#schedule .even {
	background: #fbf8f0;
}
#schedule .odd {
	background: #fefcf9;
}

/*#form*/


#form legend {
  text-align: center;
  font-size: 1.2rem;
  padding: 0px 20px;
}
/*poinat*/
#form .point ul li {
  margin-bottom: 20px;    
}

#form .point ul li::before{
    content: '\f058';
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
    margin-right:10px;
    color: rebeccapurple;
    
}
#form .form_name input {
  height: 30px;
  border: 1px solid #ccc;
  margin: 5px 0px;
  padding-left: 10px;
}
#form .rule ul {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
#form .rule li {
  text-align: center;
  margin-bottom: 10px;
}
#form .rule input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin-right: 10px;
}
#form dl {
  margin: 0 auto;
  width: 80%;
}
#form input[type="text"] {
  width: 100%;
    height:50px;
}
#form .agree {
  font-size: 120%;
  padding-top: 5px;
  margin-bottom: 20px;
    font-weight: 500;
}
#form ul.team_check {
  margin: 20px auto 10px auto;
  width: 80%;
}
/*form select*/
#form .select {
  display: inline-block;
  position: relative;
  border: 1px solid #ccc;
  vertical-align: middle;
  margin-bottom: 20px;
}
#form .select select {
  appearance: none;
  width: 80%;
  padding: 11px 15px;
  padding-right: 1em;
  border: none;
  outline: 0;
  background: #fff;
  background-image: none;
  box-shadow: none;
  text-indent: 0.01px;
  text-overflow: ellipsis;
  cursor: pointer;
}
#form .select::before {
  position: absolute;
  top: 18px;
  right: 16px;
  width: 0;
  height: 0;
  border-width: 10px 5px 0 5px;
  border-style: solid;
  border-color: #ccc transparent transparent transparent;
  content: "";
  pointer-events: none;
}
#form textarea.textline {
  border: 1px solid #ccc;
  padding: 10px;
  margin: 0 auto;
  width: 100%;
}
#form fieldset {
  border: 1px solid #ccc;
  line-height: 1.75;
  margin: 20px auto;
  padding: 30px 20px;
  width: 80%;
}
#form fieldset input[type="checkbox"] {
  margin-right: 10px;
}
#form dt{
    font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
}
img.pdf {
  width: 200px;
}
#form .submit_reset {
  text-align: center;
  margin-bottom: 50px;
}
#form .submit_reset input {
  border: 1px solid #ccc;
  margin-top: 20px;
  margin-right: 10px;
  padding: 10px 20px;
  background-color: #ccc;
  color: #333;
  border-radius: 5px;
}
#form .submit_reset p{
    font-size: 90%;
    padding-top:20px;
    text-align: center;
}
/*footer*/
.footer_wrapper {
  width: 100%;
  background-color: #ccc;
  padding: 20px 0px 20px;
}
footer {
  text-align: center;
  line-height: 1.75;
}

/*800px以下
-------------------------------------------------*/
@media (max-width: 800px) {
  body {
    font-size: 15px;
  }
    
  /*header*/
  header img.logo {
    display: block;
    margin: 0 auto;
    width: 40%;
  }
  /*main_visual*/
  #main_visual h2 {
    padding: 10px;
    margin: 0px;
  }
  #about img {
    width: 100%;
    display: block;
    margin: 0 auto;
    margin-bottom: 10px;
  }
  /*about*/
  .about_container {
    flex-direction: column;
    justify-content: center;
  }
  .about_container p {
    padding-top: 10px;
  }
  .about_container img {
    display: block;
    margin: 0 auto;
  }
  #actas_lesson h4, #technique h4, #form h4 {
    text-align: center;
  }
    .photo_2022 img {
    max-width:50%;
}
    
  h3 img {
    width: 70%;
    display: block;
    margin: 0 auto 20px auto;
  }
  /*lesson*/
    .actas_lesson_wrapper {
        width:15px 0px 40px 0px;
    }
  #actas_lesson h4 {
    text-align: center;
  }
#actas_lesson .team {
        width:100%;
    }    
  #team_details dl {
    width: 100%;
  }
  #team_details img.team_photo {
    width: 90%;
  }
  #team_details p.text {
    width: 100%;
  }
  #team_details h5 {
    font-size: 2rem;
  }
  ul.team {
    flex-direction: column;
    margin-top: 20px;
  }
  ul.team li {
    width: 100%;
    margin: 10px auto;
  }   
    
  /*form*/
  #form fieldset {
    margin: 20px auto;
    padding: 30px 10px;
      width:100%;
  }
    
    #form dl {
        width:100%;
    }
  
  img.pdf {
    width: 30%;
    display: block;
    margin: 0 auto;
  }
  #form .textline {
    width: 100%;
  }
    #form ul.team_check {
  width: 100%;
}
    
    .actas_taiken {
        width:60%;
        margin:2% auto;
        
    }
}
/*1201px以上のpc*/
@media (min-width: 1201px) {
  header, #g_nav, #main_visual, #about, #news, #actas_lesson, #technique, #form, footer {
    width: 1200px;
    margin: 0 auto;
  }
     .actas_taiken {
        width:50%;
        margin:2% auto;
    }
}