/*****************************
    共通
*****************************/
.jy_sec_ttl{
  margin-bottom:60px;
}
.jy_sec_ttl h2{
  font-size:40px;
  font-weight:700;
  line-height:1.4;
  padding-left:20px;
  border-left:4px solid #b40000;
}

/* =========================
KV
========================= */
.jy_kv{
  overflow:hidden;
  position:relative;
  background:
    radial-gradient(circle at top left,
      rgba(180,0,0,.95) 0%,
      rgba(90,0,0,.97) 45%,
      rgba(15,0,0,1) 100%);
}

.jy_kv::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(rgba(0,0,0,.15),rgba(0,0,0,.35));
  mix-blend-mode:overlay;
  opacity:.35;
  pointer-events:none;
}
.jy_kv_bg{
  position:relative;
  z-index:2;
}
.jy_kv_flex{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:40px;
}

/* =========================
左
========================= */
.jy_kv_left{
  width:42%;
  color:#fff;
  position:relative;
  z-index:2;
  padding: 0 0 0 40px;
}
.jy_kv_head{
  display:flex;
  align-items:center;
  gap:20px;
  margin-bottom:30px;
}
.jy_kv_logo{
  width:80px;
  flex-shrink:0;
}
.jy_kv_logo img{
  width:100%;
  display:block;
}
.jy_subttl{
  font-size:22px;
  font-weight:700;
  color:#ffe100;
  margin:0;
}
.jy_kv_left h1{
  color: #fff;
  font-size:65px;
  line-height:1.2;
  font-weight:700;
  text-shadow:
    0 0 10px rgba(0,0,0,.35),
    0 4px 20px rgba(0,0,0,.45);
}


/* =========================
右
========================= */
.jy_kv_right{
  width:58%;
  position:relative;
}
.jy_kv_right img{
  width:100%;
  display:block;
}

@media only screen and (max-width: 1445px){
  .jy_kv_left h1{
    font-size:50px;
  }
}

@media only screen and (max-width: 1180px){
  .jy_kv_left h1{
    font-size:40px;
  }
}

@media only screen and (max-width: 1024px){
  .jy_kv_bg{
    padding-bottom: 80px;
  }
  .jy_kv_flex{
    flex-wrap: wrap;
  }
  .jy_kv_left,
  .jy_kv_right{
    width:100%;
  }
  .jy_kv_left{
    text-align:center;
  }
  .jy_kv_head{
    justify-content:center;
  }
}

@media only screen and (max-width: 767px){
  .jy_kv_head{
    gap:15px;
    margin-bottom:20px;
  }
  .jy_kv_logo{
    width:55px;
  }
  .jy_subttl{
    font-size:16px;
  }
  .jy_kv_left h1{
    font-size:42px;
  }
  .jy_kv_right{
    margin-top:20px;
  }
  .jy_kv_left{
    padding:0;
    text-align:center;
  }
}

/* =========================
セレクション
========================= */
.jy_selection{
  padding:60px 0;
}
.jy_selection_banner{
  display:block;
}

/* =========================
上画像
========================= */
.jy_selection_top{
  position:relative;
}
.jy_selection_img{
  position:relative;
}
.jy_selection_img::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(255,255,255,.45);
  z-index:1;
}
.jy_selection_img img{
  width:100%;
  display:block;
}
.jy_selection_content{
  position:absolute;
  top:50%;
  left:60px;
  transform:translateY(-50%);
  z-index:2;
}
.jy_selection_sub{
  display:flex;
  align-items:center;
  gap:15px;
  font-size:28px;
  font-weight:700;
  color:#ffe600;
  margin-bottom:20px;
  text-shadow: 0 2px 6px rgba(130,0,0),    0 2px 6px rgba(130,0,0);
}
.jy_selection_sub::before{
  content:"";
  width:70px;
  height:70px;
  background:
    url(../../images/common/logo.webp)
    no-repeat center / contain;
}
.jy_selection_content h2{
  font-size:70px;
  line-height:1.1;
  font-weight:900;
  color:#fff000;
  text-shadow:
    0 0 10px rgba(0,0,0,.55),
    0 6px 20px rgba(0,0,0,.65);
}

/* =========================
赤帯
========================= */
.jy_selection_info{
  display:flex;
  align-items:center;
  background:
    linear-gradient(
      90deg,
      #430000 0%,
      #770000 45%,
      #d70000 100%
    );
}

/* 左 */
.jy_selection_fee{
  width:28%;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:20px;
  color:#fff000;
  padding:20px;
  position:relative;
  font-size:24px;
  font-weight:700;
}
.jy_selection_fee::after{
  content:"";
  position:absolute;
  top:50%;
  right:0;
  width:1px;
  height:70%;
  background:rgba(255,255,255,.5);
  transform:translateY(-50%);
}
.jy_selection_fee span{
  color: #fff000;
  font-size:100px;
  line-height:1;
  font-weight:900;
}

/* 右 */
.jy_selection_date{
  width:72%;
  color:#fff;
  text-align:center;
  font-size:28px;
  line-height:1.8;
  font-weight:500;
  padding:30px;
}

/* =========================
黄帯
========================= */
.jy_selection_btn{
  position:relative;
  background:#fff000;
  color:#000;
  font-size:30px;
  font-weight:900;
  text-align:center;
  line-height:1.4;
  padding:25px 90px 25px 30px;
}
.jy_selection_btn::after{
  content:"";
  position:absolute;
  top:50%;
  right:30px;
  width:65px;
  height:65px;
  background:
    url(../../images/page/junior-youth/hand.webp)
    no-repeat center / contain;
  transform:translateY(-50%);
}
.tabpro_wid{
  display: none;
}

/* =========================
レスポンシブ
========================= */
@media only screen and (max-width: 1180px){
  .jy_selection_content{
    padding:40px;
  }
  .jy_selection_content h2{
    font-size:72px;
  }
  .jy_selection_date{
    font-size:22px;
  }
  .jy_selection_btn{
    font-size:32px;
  }
  .tabpro_wid{
    display: block;
  }
}

@media only screen and (max-width: 930px){
  .jy_selection_content h2{
    font-size: 50px;
  }
  .jy_selection_fee span{
    font-size: 65px;
  }
  .jy_selection_fee{
    font-size: 20px;
  }
}

@media only screen and (max-width: 767px){
  .jy_selection_content{
    padding:20px;
  }
  .jy_selection_sub{
    font-size:14px;
    gap:10px;
    margin-bottom:10px;
  }
  .jy_selection_sub::before{
    width:40px;
    height:40px;
  }
  .jy_selection_content h2{
    font-size:42px;
  }
  .jy_selection_info{
    display:block;
    margin-top:20px;
  }
  .jy_selection_fee,
  .jy_selection_date{
    width:100%;
  }
  .jy_selection_fee{
    padding:20px;
  }
  .jy_selection_fee::after{
    display:none;
  }
  .jy_selection_fee{
    font-size:24px;
  }
  .jy_selection_fee span{
    font-size:64px;
  }
  .jy_selection_date{
    font-size:18px;
    padding:20px;
  }
  .jy_selection_btn{
    font-size:22px;
    padding:20px 70px 20px 20px;
  }
  .jy_selection_btn::after{
    width:45px;
    height:45px;
    right:15px;
  }
}

/* =========================
ABOUT
========================= */
.jy_about{
  padding:60px 0;
}
.jy_about_flex{
  display:flex;
  gap:40px;
  align-items:flex-start;
}
.jy_about_img{
  width:50%;
}
.jy_about_img img{
  width:100%;
  display:block;
}
.jy_about_txt{
  width:50%;
  padding: 0 60px 0 0;
}
.jy_about_txt p{
  line-height:2;
  margin-bottom:30px;
}

/* =========================
得られるもの
========================= */
.jy_strength{
  padding:60px 0;
}
.jy_strength .sec-head{
  margin-bottom:70px;
}
.jy_strength_list{
  display:grid;
  grid-template-columns:1fr 60px 1fr 60px 1fr;
  gap:30px;
  align-items:start;
}
.jy_strength_item{
  position:relative;
}
.jy_strength_head{
  background:#bfefff;
  height:60px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:38px;
}
.jy_strength_head h3{
  font-size:20px;
  font-weight:700;
  line-height:1.4;
}
.jy_strength_cross{
  font-size:46px;
  font-weight:700;
  line-height:1;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding-top:6px;
}
.jy_strength_img{
  margin-bottom:28px;
}
.jy_strength_img img{
  width:100%;
  aspect-ratio:324/246;
  object-fit:cover;
  display:block;
}
.jy_strength_txt h4{
  font-size:20px;
  font-weight:700;
  line-height:1.6;
  margin-bottom:10px;
}
.jy_strength_txt h4 span{
  font-size: 20px;
}
.jy_strength_txt p{
  font-weight:500;
}
.jy_strength_txt p + p{
  margin-top:10px;
}
.marker-yellow{
  background:linear-gradient(transparent 62%, #fff36d 62%);
  display:inline;
  font-weight:700;
}
.marker-blue{
  background:linear-gradient(transparent 62%, #b7edfb 62%);
  display:inline;
  font-weight:700;
}

@media screen and (max-width:1024px){
  .jy_strength{
    padding:90px 0;
  }
  .jy_strength_list{
    grid-template-columns:1fr;
    gap:50px;
  }
  .jy_strength_cross{
    display:none;
  }
  .jy_strength_head{
    height:56px;
    margin-bottom:24px;
  }
  .jy_strength_head h3{
    font-size:18px;
  }
  .jy_strength_img{
    margin-bottom:20px;
  }
  .jy_strength_txt h4{
    font-size:20px;
    margin-bottom:18px;
  }
}

@media screen and (max-width:767px){
  .jy_strength{
    padding:70px 0;
  }
  .jy_strength .sec-head{
    margin-bottom:50px;
  }
  .jy_strength_list{
    gap:40px;
  }
  .jy_strength_head{
    height:50px;
  }
  .jy_strength_head h3{
    font-size:17px;
  }
  .jy_strength_txt h4{
    font-size:18px;
    line-height:1.5;
  }
}

/* =========================
スタッフ
========================= */
.jy_staff{
  padding:60px 0;
}
.staff_read{
  margin: 30px 0;
}
.staff_read p{
  margin-bottom: 10px;
}
.jy_staff_list{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:40px;
}
.jy_staff_card{
  cursor:pointer;
  box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
  border-radius: 10px;
  padding: 20px;
}
.jy_staff_img{
  overflow:hidden;
}
.jy_staff_img img{
  width:100%;
  display:block;
  transition:.4s;
}
.jy_staff_card:hover img{
  transform:scale(1.05);
}
.jy_staff_role{
  margin-top:15px;
  color:#b40000;
}

/* =========================
モーダル
========================= */
.jy_modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.7);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:9999;
  padding:40px;
}
.jy_modal.active{
  display:flex;
}
.jy_modal_inner{
  background:#fff;
  width:100%;
  max-width:1200px;
  padding:60px;
  position:relative;
  border:1px solid #c60000;
  border-radius:20px;
  max-height:calc(100vh - 80px);
  overflow-y:auto;
}
.jy_modal_close{
  position:absolute;
  top:20px;
  right:20px;
  width:60px;
  height:60px;
  border:none;
  background:#b40000;
  border-radius:50%;
  cursor:pointer;
}
.jy_modal_close::before,
.jy_modal_close::after{
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:30px;
  height:4px;
  background:#fff;
}
.jy_modal_close::before{
  transform:translate(-50%,-50%) rotate(45deg);
}
.jy_modal_close::after{
  transform:translate(-50%,-50%) rotate(-45deg);
}
.jy_modal_flex{
  display:flex;
  gap:60px;
  align-items:flex-start;
}
.jy_modal_img{
  width:35%;
}
.jy_modal_img img{
  width:100%;
  display:block;
}
.jy_modal_content{
  width:65%;
}
.jy_modal_position{
  font-size:32px;
  font-weight:700;
  margin-bottom:20px;
  padding-left: 16px;
  border-left: 4px solid #b40000;
}
.jy_modal_content h3{
  /* font-size:48px; */
  line-height:1.4;
  margin-bottom:40px;
}
.jy_modal_content .jp{
  font-size:20px;
}
.jy_modal_content .en{
  /* display:block; */
  font-size:20px;
}
.jy_modal_block{
  margin-bottom:40px;
}
.jy_modal_block h4{
  font-size:32px;
  margin-bottom:20px;
  padding-left:16px;
  border-left:4px solid #b40000;
}

/* =========================
レスポンシブ
========================= */
@media only screen and (max-width: 1024px){
  .jy_about_flex,
  .jy_modal_flex{
    display:block;
  }
  .jy_kv_flex{
    display:flex;
    flex-wrap: wrap;
  }
  .jy_kv_left,
  .jy_kv_right,
  .jy_about_img,
  .jy_modal_img,
  .jy_modal_content{
    width:100%;
  }
  .jy_modal_img{
    width:100%;
    margin-bottom: 20px;
  }
  .jy_about_txt{
    width: 100%;
    padding: 30px;
  }
  .jy_kv_right{
    margin-top:0;
  }
  .jy_staff_list{
    grid-template-columns:repeat(2,1fr);
  }
  .jy_modal_position,
  .jy_modal_block h4{
    font-size: 26px;
  }
}

@media only screen and (max-width: 767px){
  .jy_kv_left h1{
    font-size:42px;
  }
  .jy_sec_ttl h2{
    font-size:30px;
  }
  /* .jy_staff_list{
    grid-template-columns:1fr;
  } */
  .jy_staff_list{
    gap: 10px;
  }
  .jy_staff_card{
    padding: 10px;
  }
  .jy_modal{
    padding:16px;
    align-items:flex-start;
  }
  .jy_modal_inner{
    padding:24px 20px;
    max-height:calc(100vh - 32px);
    border-radius:16px;
    margin:auto 0;
  }
  .jy_modal_close{
    top:12px;
    right:12px;
    width:48px;
    height:48px;
  }
  .jy_modal_close::before,
  .jy_modal_close::after{
    width:24px;
    height:3px;
  }
  .jy_modal_content .en{
    display: block;
  }
}

/*****************************
  練習の様子
*****************************/
.jy_slidesec{
  padding: 60px 0;
}
.junioryouthslide{
  margin:0 -5px;
}
.junioryouthslide .slick-slide{
  padding:0 5px;
  box-sizing:border-box;
}
.junioryouthslide img{
  width:100%;
  display:block;
}

/*****************************
  活動日・費用
*****************************/
.jy_info{
  padding:60px 0;
}
.jy_info_block + .jy_info_block{
  margin-top:80px;
}
.jy_info_head{
  background:#970404;
  padding:18px 20px;
}
.jy_info_head h2{
  color:#fff;
  font-size:24px;
  font-weight:700;
  line-height:1.2;
  text-align:center;
}
.jy_info_table{
  width:100%;
  border-collapse:collapse;
  table-layout:fixed;
}
.jy_info_table th,
.jy_info_table td{
  border:1px solid #9d9d9d;
  text-align:center;
  vertical-align:middle;
}
.jy_info_table thead th{
  background:#fff;
  font-size:18px;
  font-weight:700;
  padding:16px 10px;
}
.jy_info_table tbody td{
  background:#f8efef;
  font-size:16px;
  font-weight:700;
  line-height:1.6;
  padding:28px 20px;
}
.jy_info_table tbody tr:nth-child(even) td{
  background:#f3f3f3;
}
.jy_info_table tbody td:last-child{
  font-size:16px;
  line-height:1.8;
}

@media only screen and (max-width: 1024px){
  .jy_info_table tbody td{
    padding:22px 14px;
  }
}

@media only screen and (max-width: 767px){
  .jy_info_block + .jy_info_block{
    margin-top:50px;
  }
  .jy_info_head{
    padding:14px 15px;
  }
  .jy_info_head h2{
    font-size: 18px;
  }
  .jy_info_table{
    table-layout:auto;
  }
  .jy_info_table thead th{
    font-size: 16px;
    padding:12px 8px;
  }
  .jy_info_table tbody td{
    font-size: 14px;
    line-height:1.6;
    padding:10px 6px;
    word-break:break-word;
  }
  .jy_info_table tbody td:last-child{
    font-size:14px;
    line-height:1.7;
  }
}

/*****************************
  BACKGROUND IMAGE SEC
*****************************/
.jy_bg{
  position: relative;
  background: url(../../images/page/junior-youth/jybg.webp) no-repeat center / cover;
  background-attachment: fixed;
  height: 40dvh;
}

/*****************************
  お問合せ・お申込みフォーム
*****************************/
.jy_contact{
  padding: 60px 0;
}
/* formリセット */
input,
textarea {
  outline:none;
}
input[type="text"],
input[type="tel"],
input[type="email"],
textarea {
  border: 1px solid #ccc;
  border-radius: 0;
  box-sizing: border-box;
  padding: 1rem;
  width: 100%;
}
input[name="zip"] {
  margin-bottom: .5rem;
  width: 100px;
}
input[name="okosamanenrei"],
input[name="soccerreki"] {
  width: 100px;
}
input[name="mail"] {
  margin-bottom: .5rem;
}
textarea {
  vertical-align: bottom;
  height: 100px;
  resize: none;
}
/* .contactform-sec {
  padding: 10rem 0;
} */
.contactform-eles {
  margin: 0 auto;
  max-width: 850px;
}
.contactform-eles .eles:not(:last-child) {
  margin-bottom: 1rem;
}
.dl-contact {
  border: 1px solid #A0000C;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  overflow: hidden;
}
.dl-contact dt,
.dl-contact dd {
  padding: 1rem;
}
.dl-contact dt:not(:last-of-type),
.dl-contact dd:not(:last-of-type) {
  border-bottom: 1px solid #A0000C;
}
.dl-contact dt {
  background: #fff4f5;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 280px;
}
.dl-contact dd {
  width: calc(100% - 280px);
}
.dl-contact dd .tyuui {
  font-size: 1.4rem;
  margin-bottom: 0;
}
.hissu,
.ninni {
  background: #fff;
  border-radius: 50px;
  display: inline-block;
  font-size: 1.2rem;
  font-weight: 600;
  padding: 2px 7px;
  text-align: center;
}
.hissu {
  border: 1px solid #ff0000;
  color: #ff0000;
}
.ninni {
  border: 1px solid #555;
  color: #555;
}
.contact-submit-wrap {
  margin-top: 2rem;
}
.contactbtn {
  border: none;
  background: #A0000C;
  border-radius: 0;
  box-shadow: 0 6px #7b0009;
  color: #fff;
  cursor: pointer;
  display: block;
  margin: 0 auto;
  padding: 1rem;
  position: relative;
  top: 0;
  width: 100%;
  max-width: 200px;
  transition: .5s;
}
.contactbtn:hover {
  box-shadow: 0 0 #555;
  opacity: 1;
  top: 6px;
  transition: .5s;
}
.contactbtn:disabled {
  background: #999;
  box-shadow: 0 6px #818181;
}
.contactbtn:disabled:hover {
  opacity: 1;
  top: 0;
}
.wpcf7-spinner {
  display: none !important;
}
.wpcf7-list-item.first {
  margin: 0;
}
.wpcf7 form .wpcf7-response-output {
  width: 90%;
  max-width: 800px;
  margin: -5rem auto 5rem;
}
.wpcf7-form.sent .contactform-sec {
  padding: 0;
}
.wpcf7-form.sent .wpcf7-response-output {
  margin: 5rem auto;
}
@media screen and (max-width: 767px) {
  .contactform-sec {
    padding: 5rem 0;
  }
  .dl-contact dt {
    border-bottom: 1px solid #A0000C;
    justify-content: left;
    width: 100%;
  }
  .dl-contact dd {
    width: 100%;
  }
  .dl-contact dt .txt {
    margin-right: 1rem;
  }
  .wpcf7 form .wpcf7-response-output {
    margin: 0 2rem;
  }
}

/*****************************
    フッター上 セクション
*****************************/
.sec.top-about-sec {
  padding: 10rem 0;
  background: url(../../images/top/bg-top-about-sec.webp) no-repeat center / cover;
}
.sec.top-about-sec::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  background: rgba(0,0,0,.6);
  height: 100%;
  width: 100%;
}
.top-about-eles .txt {
  color: #fff;
  font-size: 2rem;
  margin-bottom: 3rem !important;
  position: relative;
}
@media screen and (max-width: 767px) {
  .sec.top-about-sec {
    padding: 5rem 0;
  }
  .top-about-eles .txt {
    font-size: 1.6rem;
  }
  .top-about-eles .btn1 {
    text-align: left;
  }
}