
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&display=swap');

.img_respoinsive {
width: 100%;
height: auto;
}
.btm_cap {
position: relative;
}
.btm_cap span {
font-size: 11px;
text-align: right;
position: absolute;
bottom: 3px;
right: 5px;
color: #fff;
}
.col-red {
color: #d2000f;
}
.txt_link {
color: #0E3B8B;
transition: .3s;
}
.txt_link:hover {
color: #B62405;
}


@media (max-width: 767px) {
.isPC {
display: none;
}
.isSP {
display: block;
}


#soccer_cont {
width: 100%;
margin: 0 auto;
background-color: #001E55;
background: url("../img/ft_bg_sp.png") #001E55;
padding-bottom: 400px;
background-position: bottom center;
background-repeat: no-repeat;
background-size: 100%;
position: relative;
}
#mainv {
width: 100%;
margin: 0 auto;
}
.main_obi {
border-top:1px solid #fff;
border-bottom: 1px solid #fff;
background-color: #001E55;
width: 100%;
margin: 0 auto;
padding: 10px 0;
text-align: center;
font-size: 18px;
color: #fff;
font-weight: 700;
line-height: 1;
}
.main_obi span {
font-family: "Oswald", sans-serif;
font-weight: 500;
}
.main_nav {
width: 100%;
margin: 0 auto 100px;
display: flex;
flex-wrap: nowrap;
justify-content: space-between;
}
.main_nav .item {
width: 50%;
	position: relative;

}
.main_nav .item a.link_page {
display: block;
text-decoration: none;
transition: .3s;
position: relative;
background:#0064b5;
background: linear-gradient(to right,  #0064b5 0%,#1c2c6f 100%);
padding: 20px;
box-sizing: border-box;
}
.main_nav .item  {

}
	
.main_nav .item a::after {
display: block;
content: '';
  width: 30px;
  height: 30px;
  background-image: url("../img/icon_arrow.png");
  background-size: contain;
  vertical-align: middle;
  position: absolute;
  bottom: -30px;
  left: 50%;
  transform: translate(-50%, -50%);
}
	.main_nav .item a.link_page:hover{
		opacity: 0.6;
  background-color: #fff;
	}
.main_nav .item a.link_page::after:hover {
opacity: 0.6;
}



.main_nav .btn_cont {
width: 98%;
display: flex;
align-items: stretch;
margin:5px auto;
flex-direction: column;
}
.main_nav .btn_cont .name_course {
font-size: 36px;
font-family: "Oswald", sans-serif;
font-weight: 500;
color: #e3f854;
line-height: 18px;
text-align: center;
}
.main_nav .btn_cont .name_course span {
font-size: 18px;
}
.main_nav .btn_cont .course_cont {
}
.main_nav .btn_cont .course_cont .course_date {
font-size: 18px;
font-family: "Oswald", sans-serif;
font-weight: 500;
padding: 5px;
border:solid #fff;
border-width: 1px 1px 1px 0;
color:#fff;
line-height: 1;
margin: 10px 0;
text-align: center;
}
.main_nav .btn_cont .course_cont .course_name {
font-size: 16px;
color:#fff;
line-height: 1.4;
font-weight: 700;
text-align: center;
}
.main_nav .btn_cont .course_cont .course_name span {
font-size: 13px;
}
.cont_block {
width: 100%;
margin: 0 auto 50px;
background-color: #fff;
}
.cont_block  .cont_inner {
padding: 15px;
}
.cont_ttl {
width: 100%;
margin: 0 auto 20px;
background-color: #e3f854;
padding: 10px;
box-sizing: border-box;
display: flex;
flex-direction: column;
}
.cont_ttl .name_c {
color: #001E55;
font-family: "Oswald", sans-serif;
font-weight: 500;
font-size: 40px;
text-align: center;
line-height: 1.2;
}
.cont_ttl .name_c span {
font-size: 18px;
padding-left: 10px;
}
.cont_ttl .date_box {
background-color: #001E55;
color: #fff;
padding: 10px;
font-family: "Oswald", sans-serif;
font-weight: 500;
font-size: 18px;
line-height: 1;
text-align: center;
}
.cont_ttl .ttl_name {
color: #001E55;
font-weight: 700;
font-size: 18px;
line-height: 1.2;
padding: 10px;
}
.course_outline {
width: 100%;
margin: 0 auto 50px;
display: flex;
flex-direction: column;
}
.course_outline .phbox {
width: 100%;
}
.course_outline .txtbox {
width: 100%;
margin-bottom: 30px;
}
.course_outline .date_time {
font-size: 18px;
color: #001E55;
font-family: "Oswald", sans-serif;
font-weight: 700;
}
.course_outline .date_time span {
margin-left: 16px;
color: #000;
font-size: 18px;
font-weight: 700;
}
.course_outline .loca {
font-size: 16px;
color: #000;
font-weight: 700;
}
.course_outline .vsbox {
margin-top: 20px;
display: flex;
flex-direction: column;
}
.course_outline .vsbox .samurai {
background-color: #001E55;
color: #fff;
padding: 10px 20px;
text-align: center;
line-height: 1;
font-size: 20px;
font-weight: 700;
}
.course_outline .vsbox .samurai span {
font-size: 16px;
}
.course_outline .versus {
font-size: 26px;
color: #D2000F;
font-family: "Oswald", sans-serif;
font-weight: 700;
margin: 0 10px;
text-align: center;
}
.course_outline .vsbox .taisen {
color: #001E55;
padding: 20px 80px;
box-sizing: border-box;
text-align: center;
line-height: 1;
font-size: 20px;
font-weight: 700;
border: 1px solid #001E55;
}
.kids_kakomi {
background-color: #ebe9db;
padding: 20px 25px;
margin: 20px auto;
/*clip-path: polygon(0 0, 100% 0%, 96% 100%, 0% 100%);*/
}
.kakomi_honbun {
font-size: 14px;
line-height: 1.5;
color: #000;
font-weight: 400;
}


.about_kids {
font-size: 16px;
font-weight: 700;
text-align: left;
position: relative;
display: flex;
align-items: center;
}
.about_kids::after {
content: "";
    height: 1px; /* 線の高さ */
    flex-grow: 1; /* 横幅いっぱい */
    background-color:#000;
    margin-left: 20px;
}
.oubo_ttl {
background-image: url("../img/ttl-bar_sp.png");
background-position: top center;
background-repeat: no-repeat;
background-size: 100% auto;
margin-bottom: 20px;
}
.oubo_ttl div {
font-size: 17px;
color: #fff;
line-height: 1.2;
text-align: center;
padding: 10px;
}
ul.oubo_list {
margin: 0 auto;
padding: 0;
list-style-type: none;
}
ul.oubo_list li {
display: flex;
flex-direction: column;
font-size: 14px;
border-bottom: 1px solid #001E55;
line-height: 1.5;
}
ul.oubo_list li .oubo_item {
background-color: #eaeaea;
display: flex;
flex-direction: column;
justify-content: center;
color: #000;
padding: 10px;
}

ul.oubo_list li .oubo_detail {
padding:10px 0;
}
.oubo_scroll {
width: 100%;
overflow-y: auto;
height: 240px;
box-sizing: border-box;
}
.oubo_scroll ul {
margin: 0;
padding: 0;
}
.oubo_scroll ul li {
border: none;
text-indent: -1em;
padding-left: 1em;
}
.qand_q {
color: #001E55;
font-weight: 700;
}
.qand_q::before {
content: "Q.";
  color: #001E55;
  padding-right: 5px;
}
.qand_a:not(:last-child) {
color: #444;
margin-bottom: 10px;
}
.qand_a {
text-indent: -1em;
padding-left: 1em;
}
.qand_a::before {
content: "A.";
  color: #444;
  padding-right: 5px;
}
.howto_ttl {
color: #001E55;
font-size: 24px;
padding: 50px 0 80px;
text-align: center;
font-weight: 700;
}
.how_flow {
width: 100%;
margin: 0 auto 20px;
display: flex;
flex-direction: column;
}
.flow_item {
box-sizing: border-box;
border:1px solid #001E55;
background-color: #F0F1F5;
padding: 30px 0 20px;
position: relative;
}
.flow_arrow {
font-size: 24px;
font-weight: bold;
display: flex;
flex-direction: column;
justify-content: center;
padding: 0 0 50px 0;
text-align: center;
}

.flow_item .flow_num {
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #001E55;
  width: 60px;
  height: 60px;
  border-radius: 60px;
  border: 1px solid #fff;
}
.flow_item .flow_num div {
  color: #fff;
  font-family: "Oswald", sans-serif;
font-weight: 700;
font-size: 16px;
text-align: center;
line-height: 1;
padding-top: 12px;
}
.flow_item .flow_num div span {
font-size: 24px;
}


.flow_icon {
width: 120px;
margin: 10px auto;
}
.flow_txt {
font-size: 14px;
text-align: center;
line-height: 1.8;
}
.contact_ttl {
font-size: 32px;
padding-bottom: 20px;
text-align: center;
  font-family: "Oswald", sans-serif;
font-weight: 700;
color: #001E55;
}
.contact_name {
font-size: 17px;
text-align: center;
font-weight: 500;
color: #001E55;
}
.btn_jimu {
margin: 20px auto 0;
font-size: 16px;
width:100%;
text-align: center;
line-height: 1.2;
}
.btn_jimu a {
color: #fff;
text-decoration: none;
background-color: #001E55;
display: block;
padding: 10px 30px;
border-radius: 8px;
transition: .3s;
}
.btn_jimu a:hover {
opacity: 0.7;
}
.contact_time {
font-size: 16px;
color: #001E55;
text-align: center;
padding: 10px 0;
}
.contact_anno {
color: #001E55;
font-size: 13px;
text-align: center;
line-height: 1.5
}
.logo_dream {
width: 50%;
margin: 50px auto 0;
}
.ft_caption {
position: absolute;
bottom: 10px;
right: 10px;
color: #fff;
font-size: 11px;
}

.kiyaku_check {
padding: 20px;
margin: 10px auto;
background-color: #DDE1FF;
}
.kiyaku_checkbox {
display: flex;
margin: 0 auto;
align-items: center;
}
.kiyaku_checkbox label{
 display: flex;
align-items: center;
}

.kiyaku_checkbox #oubocheck {
  margin-right: 15px;
	width: 28px;
	height: 28px;
	accent-color: #000;
}
.kiyaku_checkbox .item_txt {
font-size: 13px;
line-height: 1.5;
}
	


	
.btn_oubo {
margin: 20px auto 100px;
font-size: 24px;
width: 100%;
text-align: center;	
}
.btn_oubo a {
color: #fff;
text-decoration: none;
	background-color: #999;
display: block;
padding: 10px 30px;
border-radius: 8px;
transition: .3s;
pointer-events: none;
}
	.btn_oubo.is-active a{
		background-color: #D2000F;
		pointer-events: auto;
	} 
.btn_oubo.is-active a:hover {
opacity: 0.7;
}






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


#soccer_cont {
width: 100%;
margin: 0 auto;
background-color: #001E55;
background: url("../img/ft_bg.png") #001E55;
padding-bottom: 740px;
background-position: bottom center;
background-repeat: no-repeat;
background-size: contain;
position: relative;
}
#mainv {
width: 100%;
margin: 0 auto;
}
.main_obi {
border-top:1px solid #fff;
border-bottom: 1px solid #fff;
background-color: #001E55;
width: 100%;
margin: 0 auto;
padding: 10px 0;
text-align: center;
font-size: 42px;
color: #fff;
font-weight: 700;
line-height: 1;
}
.main_obi span {
font-family: "Oswald", sans-serif;
font-weight: 500;
}
.main_nav {
width: 100%;
margin: 0 auto 100px;
display: flex;
flex-wrap: nowrap;
justify-content: space-between;
}
.main_nav .item {
width: 50%;
	position: relative;

}
.main_nav .item a.link_page {
display: block;
text-decoration: none;
transition: .3s;
position: relative;
background:#0064b5;
background: linear-gradient(to right,  #0064b5 0%,#1c2c6f 100%);
padding: 20px;
box-sizing: border-box;
}
.main_nav .item  {

}
	
.main_nav .item a::after {
display: block;
content: '';
  width: 40px;
  height: 40px;
  background-image: url("../img/icon_arrow.png");
  background-size: contain;
  vertical-align: middle;
  position: absolute;
  bottom: -40px;
  left: 50%;
  transform: translate(-50%, -50%);
}
	.main_nav .item a.link_page:hover{
		opacity: 0.6;
  background-color: #fff;
	}
.main_nav .item a.link_page::after:hover {
opacity: 0.6;
}



.main_nav .btn_cont {
width: 98%;
display: flex;
align-items: center;
margin:10px auto;
}
.main_nav .btn_cont .name_course {
font-size: 53px;
font-family: "Oswald", sans-serif;
font-weight: 500;
color: #e3f854;
line-height: 25px;
text-align: center;
padding-right: 20px;
}
.main_nav .btn_cont .name_course span {
font-size: 18px;
}
.main_nav .btn_cont .course_cont {
}
.main_nav .btn_cont .course_cont .course_date {
font-size: 26px;
font-family: "Oswald", sans-serif;
font-weight: 500;
padding: 5px;
border:solid #fff;
border-width: 1px 1px 1px 0;
color:#fff;
line-height: 1;
display: inline-block;
}
.main_nav .btn_cont .course_cont .course_name {
font-size: 28px;
color:#fff;
line-height: 1.4;
font-weight: 700;
}
.main_nav .btn_cont .course_cont .course_name span {
font-size: 21px;
}
.cont_block {
width: 1100px;
margin: 0 auto 50px;
background-color: #fff;
}
.cont_block  .cont_inner {
padding: 30px;
}
.cont_ttl {
width: 100%;
margin: 0 auto 50px;
background-color: #e3f854;
padding: 20px;
box-sizing: border-box;
display: flex;
align-items: center;
}
.cont_ttl .name_c {
color: #001E55;
font-family: "Oswald", sans-serif;
font-weight: 500;
font-size: 53px;
margin-right: 20px;
}
.cont_ttl .name_c span {
font-size: 18px;
padding-left: 10px;
}
.cont_ttl .date_box {
background-color: #001E55;
color: #fff;
padding: 10px;
font-family: "Oswald", sans-serif;
font-weight: 500;
font-size: 26px;
line-height: 1;
margin-right: 20px;
}
.cont_ttl .ttl_name {
color: #001E55;
font-weight: 700;
font-size: 28px;
line-height: 1.2;
}
.course_outline {
width: 100%;
margin: 0 auto 50px;
display: flex;
justify-content: space-between;
}
.course_outline .phbox {
width: 450px;
}
.course_outline .txtbox {
width: calc(100% - 460px);
}
.course_outline .date_time {
font-size: 38px;
color: #001E55;
font-family: "Oswald", sans-serif;
font-weight: 700;
}
.course_outline .date_time span {
margin-left: 20px;
color: #000;
font-size: 24px;
font-weight: 700;
}
.course_outline .loca {
font-size: 24px;
color: #000;
font-weight: 700;
}
.course_outline .vsbox {
margin-top: 20px;
display: flex;
align-items: center;
}
.course_outline .vsbox .samurai {
background-color: #001E55;
color: #fff;
padding: 10px 20px;
text-align: center;
line-height: 1;
font-size: 24px;
font-weight: 700;
}
.course_outline .vsbox .samurai span {
font-size: 16px;
}
.course_outline .versus {
font-size: 38px;
color: #D2000F;
font-family: "Oswald", sans-serif;
font-weight: 700;
margin: 0 20px;
}
.course_outline .vsbox .taisen {
color: #001E55;
padding: 20px 80px;
box-sizing: border-box;
text-align: center;
line-height: 1;
font-size: 24px;
font-weight: 700;
border: 1px solid #001E55;
}
.kids_kakomi {
background-color: #ebe9db;
padding: 20px 25px;
margin: 63px auto 0;
clip-path: polygon(0 0, 100% 0%, 96% 100%, 0% 100%);
}
.kakomi_honbun {
font-size: 16px;
line-height: 1.8;
color: #000;
font-weight: 400;
}


.about_kids {
font-size: 20px;
font-weight: 700;
text-align: left;
position: relative;
display: flex;
align-items: center;
}
.about_kids::after {
content: "";
    height: 1px; /* 線の高さ */
    flex-grow: 1; /* 横幅いっぱい */
    background-color:#000;
    margin-left: 20px;
}
.oubo_ttl {
background-image: url("../img/ttl-bar.png");
background-position: top center;
background-repeat: no-repeat;
background-size: 100% auto;
margin-bottom: 30px;
}
.oubo_ttl div {
font-size: 26px;
color: #fff;
line-height: 1.2;
text-align: center;
padding: 10px;
}
ul.oubo_list {
margin: 0 auto;
padding: 0;
list-style-type: none;
}
ul.oubo_list li {
display: flex;
align-items: stretch;
font-size: 18px;
border-bottom: 1px solid #001E55;
line-height: 1.5;
}
ul.oubo_list li .oubo_item {
width: 160px;
background-color: #eaeaea;
display: flex;
flex-direction: column;
justify-content: center;
color: #000;
text-align: center;
padding: 10px 0;
}

ul.oubo_list li .oubo_detail {
padding:10px 0 10px 20px;
max-width: calc(100% - 200px);
}
.oubo_scroll {
width: 100%;
overflow-y: auto;
height: 300px;
box-sizing: border-box;
}
.oubo_scroll ul {
margin: 0;
padding: 0;
}
.oubo_scroll ul li {
border: none;
text-indent: -1em;
padding-left: 1em;
}
.qand_q {
color: #001E55;
font-weight: 700;
}
.qand_q::before {
content: "Q.";
  color: #001E55;
  padding-right: 5px;
}
.qand_a:not(:last-child) {
color: #444;
margin-bottom: 10px;
}
.qand_a {
text-indent: -1em;
padding-left: 1em;
}
.qand_a::before {
content: "A.";
  color: #444;
  padding-right: 5px;
}
.howto_ttl {
color: #001E55;
font-size: 36px;
padding: 50px 0 80px;
text-align: center;
font-weight: 700;
}
.how_flow {
width: 100%;
margin: 0 auto 20px;
display: flex;
justify-content: space-between;
}
.flow_item {
width: 31%;
box-sizing: border-box;
border:1px solid #001E55;
background-color: #F0F1F5;
padding: 50px 0 20px;
position: relative;
}
.flow_arrow {
font-size: 24px;
font-weight: bold;
display: flex;
flex-direction: column;
justify-content: center;
}

.flow_item .flow_num {
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #001E55;
  width: 75px;
  height: 75px;
  border-radius: 75px;
  border: 1px solid #fff;
}
.flow_item .flow_num div {
  color: #fff;
  font-family: "Oswald", sans-serif;
font-weight: 700;
font-size: 18px;
text-align: center;
line-height: 1;
padding-top: 12px;
}
.flow_item .flow_num div span {
font-size: 36px;
}


.flow_icon {
width: 150px;
margin: 10px auto;
}
.flow_txt {
font-size: 16px;
text-align: center;
line-height: 1.8;
}
.contact_ttl {
font-size: 48px;
padding-bottom: 30px;
text-align: center;
  font-family: "Oswald", sans-serif;
font-weight: 700;
color: #001E55;
}
.contact_name {
font-size: 24px;
text-align: center;
font-weight: 500;
color: #001E55;
}
.btn_jimu {
margin: 20px auto 0;
font-size: 20px;
width: 520px;
text-align: center;
}
.btn_jimu a {
color: #fff;
text-decoration: none;
background-color: #001E55;
display: block;
padding: 10px 30px;
border-radius: 8px;
transition: .3s;
}
.btn_jimu a:hover {
opacity: 0.7;
}
.contact_time {
font-size: 20px;
color: #001E55;
text-align: center;
padding: 10px 0;
}
.contact_anno {
color: #001E55;
font-size: 14px;
text-align: center;
line-height: 1.8;
}
.logo_dream {
width: 292px;
margin: 50px auto 0;
}
.logo_dream a {
transition: .3s;
}
.logo_dream a:hover {
opacity: 0.7;
}
.ft_caption {
position: absolute;
bottom: 10px;
right: 10px;
color: #fff;
font-size: 11px;
}

.kiyaku_check {
padding: 20px;
margin: 10px auto;
background-color: #DDE1FF;
}
.kiyaku_checkbox {
display: flex;
margin: 0 auto;
align-items: center;
width: 600px;
}
.kiyaku_checkbox label{
 display: flex;
	align-items: center;
}

.kiyaku_checkbox #oubocheck {
  margin-right: 15px;
	width: 36px;
	height: 36px;
	accent-color: #000;
}
.kiyaku_checkbox .item_txt {
font-size: 16px;
line-height: 1.5;
	flex-grow: 1; 
}
	


	
.btn_oubo {
margin: 20px auto 0;
font-size: 36px;
width: 520px;
text-align: center;	
}
.btn_oubo a {
color: #fff;
text-decoration: none;
	background-color: #999;
display: block;
padding: 10px 30px;
border-radius: 8px;
transition: .3s;
pointer-events: none;
}
	.btn_oubo.is-active a{
		background-color: #D2000F;
		pointer-events: auto;
	} 
.btn_oubo.is-active a:hover {
opacity: 0.7;
}



}
