@charset "UTF-8";
html {
  -webkit-text-size-adjust: none;
  -webkit-font-smoothing: aliased;
  -webkit-font-feature-settings: "pkna";
  font-feature-settings: "pkna";
  font-size: 62.5%;
  color: #222;
  box-sizing: border-box; }
body {
  margin: 0;
  padding: 0;
  font-size: 16px;
  line-height: 1.6;
  font-family: "Noto Sans JP", sans-serif;
  min-width: 980px;
  position: relative;
  letter-spacing: 0.05em; }
@media screen and (max-width: 1024px) {
  body {
    min-width: auto;
    min-width: initial; } }
@media screen and (max-width: 768px) {
  body {
    min-width: 300px; } }
  img {
    vertical-align: bottom; }
  a[href^="tel:"] {
   display: block;
   pointer-events: none; }
@media screen and (max-width: 768px) {
  a[href^="tel:"] {
    pointer-events: auto; } }
  .clearfix::after {
    content: "";
    display: block;
    clear: both; }
  .only-pc {
    display: block; }
@media screen and (max-width: 1024px) {
  .only-pc {
    display: none !important; } }
  .only-pc-tab {
    display: block; }
@media screen and (max-width: 768px) {
  .only-pc-tab {
    display: none !important; } }
  .only-tab-sp {
    display: none !important; }
@media screen and (max-width: 1024px) {
  .only-tab-sp {
    display: block !important; } }
  .only-sp {
    display: none !important; }
@media screen and (max-width: 768px) {
  .only-sp {
    display: block !important; } }
.img-fit {
  width: 100%;
  height: auto; }
.side-margin {
  margin-right: auto;
  margin-left: auto; }
@media screen and (max-width: 768px) {
  .t-center-pc {
    text-align: justify; } }
.t-just {
  text-align: justify; }
.m-center {
  margin-right: auto;
  margin-left: auto; }
.fwb {
  font-weight: bold; }
.dbl {
  display: block; }
.fss-ss {
  font-size: 14px; }
@media screen and (max-width: 768px) {
.fss-ss {
  font-size: 12px; } }
.les01 {
  letter-spacing: 0.1em; }
.mt05em {
  margin-top: 0.5em; }
.mt1em {
  margin-top: 1em; }
.mt15em {
  margin-top: 1.5em; }
.mb05em {
  margin-bottom: 0.5em; }
.mb1em {
  margin-bottom: 1em; }
.mb15em {
  margin-bottom: 1.5em; }
.mb2em {
  margin-bottom: 2em; }
.mb3em {
  margin-bottom: 3em; }
.mb4em {
  margin-bottom: 4em; }
.mb8per {
  margin-bottom: 8%; }
.ml1em, .ml1em-pc {
  margin-left: 1em; }
.pdt20 {
  padding-top: 20px; }
.pdt30 {
  padding-top: 30px; }
.pdt40 {
  padding-top: 40px; }
.pdt60 {
  padding-top: 60px; }
.pdt70 {
  padding-top: 70px; }
.pdt80 {
  padding-top: 80px; }
.pdt150 {
  padding-top: 150px; }
.pdt155 {
  padding-top: 155px; }
.pdb30 {
  padding-bottom: 30px; }
.pdb40 {
  padding-bottom: 40px; }
.pdb60 {
  padding-bottom: 60px; }
.pdb80 {
  padding-bottom: 80px; }
.pdb90 {
  padding-bottom: 90px; }
.pdb130 {
  padding-bottom: 130px; }
.pdb150 {
  padding-bottom: 150px; }
.key {
  color: #0066cc; }
a {
  color: #0066cc; }
a:hover {
  color: #0066cc; }
a img:hover {
  opacity: 0.8; }

.section-inner {
  width: 100%;
  max-width: 980px;
  margin: 0 auto;
 }
 
@media screen and (max-width: 1024px) {
  .section-inner {
    width: auto;
    padding: 0 5%;}
}
  .section-inner img {
    max-width: 100%;
    height: auto;
    margin: auto; }
  h1, h2, h3, h4, h5, h6 {
    padding: 0;
    margin: 0;
    line-height: 1.5; }
  p {
    margin: 0 0 0.5em;
    font-size: 16px; }
@media screen and (max-width: 1024px) {
  p {
      font-size: 14px; } }
  .red {
    color: #f51e5a; }
  .underline {
    text-decoration: underline; }
  h3 {
    font-weight: bold;
    font-size: 24px;
    line-height: 1.5;
    padding: 0.5em;
    background: #e6f0fa;
    position: relative;
    margin-bottom: 40px; }
@media screen and (max-width: 1024px) {
  h3 {
    font-size: 20px; } }
@media screen and (max-width: 768px) {
  h3 {
    font-size: 18px;
    margin-bottom: 20px } }
  h3 span {
    display: block;
    border-left: solid 4px #000;
    padding-left: 0.5em; }
  h4 {
    font-weight: bold;
    color: #0066cc;
    display: block;
    border-left: solid 4px #0066cc;
    padding-left: 0.5em;
    font-size: 20px;
    margin-bottom: 10px; }
@media screen and (max-width: 1024px) {
  h4 {
    font-size: 20px; } }
@media screen and (max-width: 768px) {
  h4 {
    font-size: 18px; } }
  p {
    line-height: 2; }
@media screen and (max-width: 768px) {
  p {
    line-height: 1.8; } }
.header {
  padding: 18px 0;
  display: block; }
@media screen and (max-width: 1024px) {
  .header {
    padding: 12px 0 8px; } }
.header h1 {
  font-size: 20px;
  float: left;
  line-height: 30px; }
@media screen and (max-width: 1024px) {
  .header h1 {
    text-align: center;
    display: block;
    float: none;
    margin-bottom: 1em; } }
@media screen and (max-width: 768px) {
  .header h1 {
    font-size: 12px;
    margin-bottom: 0.8em;
    line-height: 1.4; } }
.header .h-logo {
  float: right;
  display: flex;
 align-items: center; }
@media screen and (max-width: 1024px) {
  .header .h-logo {
    float: none;
    display: flex;
    justify-content: center; } }
@media screen and (max-width: 768px) {
  .header .h-logo {
    justify-content: center; } }
  .header .h-logo span {
    margin: 0 10px; }
  .header .h-logo span img {
    height: 50px;
    width: auto; }
@media screen and (max-width: 768px) {
  .header .h-logo span img {
    height: 30px; } }
  .header .h-logo span .logo-set {
    width: 18px;
    height: 18px;
  }
@media screen and (max-width: 400px) {
  .header .h-logo span img {
    height: 34px; } }
@media screen and (max-width: 360px) {
  .header .h-logo span img {
    height: 30px; } }
.header .h-logo span.-sfawest {
  margin-right: 0; }
@media screen and (max-width: 768px) {
  .header .h-logo span.-sfawest {
    margin: 0 10px; } }


.header .section-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .header .section-inner {
    flex-direction: column;
}
}




.sec-fv img {
  width: 100%;
  max-width: 1440px; }
.sec-fv {
  background-color: #fff;
}
.sec-intro {
  padding: 50px 0 40px;
  background: linear-gradient( #1a6bdc 0%, #47A1E2 60%);
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
   .sec-intro .section-inner p {
    text-align: justify;
  }}
.sec-intro p {
  text-align: center;
  color: #fff;
  font-size: 20px;
  text-shadow: 0 0 5px rgba(0,0,0, 0.8);
  line-height: 1.8;
}
@media screen and (max-width: 678px) {
  .sec-intro p {
    font-size: 14px; 
  } 
}

.inner-text-line {
  font-size: 20px;
  line-height: 1.6;
}

@media screen and (max-width: 768px) {
  .inner-text-line {
    font-size: 16px;
   }
}

ul.-disc {
  padding: 0;
  list-style: none; }
ul.-disc li {
  margin-bottom: 0.5em;
  padding-left: 1.5em;
  text-indent: -1.5em; }
ul.-disc li::before {
  content: "・"; }

ul.-kome {
  padding: 0;
  list-style: none; }
ul.-kome li {
  margin-bottom: 0.5em;
  padding-left: 1.5em;
  text-indent: -1.5em; }
ul.-kome li::before {
  content: "※"; }


@media screen and (max-width: 768px) {
  .sec-about {
    background-size: 10px 10px; } }
@media screen and (max-width: 1024px) {
  .sec-about {
    padding-top: 30px; } }
.sec-about div.-inner {
  box-sizing: border-box;
  background: #fff;
  margin-bottom: 50px; }
@media screen and (max-width: 1024px) {
  .sec-about div.-inner {
    margin-bottom: 30px; } }
.sec-about h3.-about {
  color: #fff;
  background: linear-gradient(to right, #0a1464, #0066cc); }
.sec-about h3.-about span {
  border-color: #fff; }
.sec-about h3.-about::after {
  display: none;
  content: "";
  width: 120px;
  height: 24px;
  background-image: url("../img/coach.png");
  background-repeat: no-repeat;
  background-position: center center;
  position: absolute;
  right: 24px;
  top: 0;
  bottom: 0;
  margin: auto; }
@media screen and (max-width: 768px) {
  .sec-about h3.-about::after {
    display: none; } }
.sec-about .col-2 {
  overflow: hidden;
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
 }
.sec-about .col-2 .-right {
  width: 50%;
  }
@media screen and (max-width: 1024px) {
  .sec-about .col-2 .-right {
    width: 45%; } }
@media screen and (max-width: 768px) {
  .sec-about .col-2 {
    display: block;
   }
  .sec-about .col-2 .-left .photo-tani {
    display: block;
    margin: auto; }
  .sec-about .col-2 .-right {
    width: auto;
    margin-bottom: 20px; } }
.sec-about .col-2 .-left {
  margin: 0 0 40px auto; }
@media screen and (max-width: 1024px) {
  .sec-about .col-2 .-left {
    width: 50%; } }
@media screen and (max-width: 768px) {
  .sec-about .col-2 .-left {
    width: auto;
    margin-bottom: 30px; } }
@media screen and (max-width: 1024px) {
  .sec-about .col-2 .-left .photo-tani {
    padding: 0;
    margin: 0 auto; } }
  .message-img {
    margin: 0 auto;
    display: block;
  }
  .sec-about .about-tani {
    background: #E4EDF4;
    padding: 40px;
  }
  .sec-about .about-tani h4{
    margin-bottom: 20px;
  }
  .sec-about .about-tani h4 span{
    color: #333;
    font-size: 12px;
  }
.sec-about .performance {
  display: flex;
  justify-content: space-between; }
@media screen and (max-width: 1024px) {
  .sec-about .performance {
    padding: 20px 10px; } }
@media screen and (max-width: 768px) {
  .sec-about .about-tani {
    background: #E4EDF4;
    padding: 40px 20px 10px;
  }
  .sec-about .about-tani h4{
    margin-bottom: 0;
  }
  .sec-about .performance {
    display: block; } }
.sec-about .performance p {
  margin-bottom: 0; }
.sec-about h3.-training {
  color: #003399;
  background: linear-gradient(to right, #b4bedc, #b4d2f0); }
.sec-about h3.-training span {
  border-color: #003399; }
.sec-about h3.-training::after {
  content: "";
  width: 170px;
  height: 24px;
  background-image: url("../img/bg-h3-training.png");
  background-repeat: no-repeat;
  background-position: center center;
  position: absolute;
  right: 24px;
  top: 0;
  bottom: 0;
  margin: auto; }
@media screen and (max-width: 768px) {
  .sec-about h3.-training::after {
    display: none; } }
.sec-about .photo-training {
  width: 100%;
  max-width: 1920px;
  margin: auto;
  display: flex;
  justify-content: space-between;
  }
.sec-about .photo-training img {
  width: 100%;
  height: auto;
 }
 .sec-about .photo-training img:first-child {
  margin-right: 1.6%;
 }
@media screen and (max-width: 768px) {
  .sec-about .photo-training img {
    float: none;
    width: 100%; } }

.sec-schedule {
  background-image: url("../img/bg-stripe-bl.png");
  background-repeat: repeat;
  padding: 80px 0; }
@media screen and (max-width: 768px) {
  .sec-schedule {
    background-size: 10px 10px; } }
@media screen and (max-width: 1024px) {
  .sec-schedule {
    padding: 60px 0; } }
.sec-schedule div.-inner {
  padding: 20px 16px;
  box-sizing: border-box;
  background: #fff; }
.sec-schedule h3.-schedule {
  color: #fff;
  background: linear-gradient(to right, #0a1464, #0066cc); }
.sec-schedule h3.-schedule span {
  border-color: #fff; }
.sec-schedule h3.-schedule::after {
  display: none;
  content: "";
  width: 140px;
  height: 24px;
  background-image: url("../img/bg-h3-schedule.png");
  background-repeat: no-repeat;
  background-position: center center;
  position: absolute;
  right: 24px;
  top: 0;
  bottom: 0;
  margin: auto; }
@media screen and (max-width: 768px) {
  .sec-schedule h3.-schedule::after {
    display: none; } }
.sec-schedule .col-2 {
  overflow: hidden; }
.sec-schedule .col-2 .-right {
  width: 418px;
  float: right; }
@media screen and (max-width: 1024px) {
  .sec-schedule .col-2 .-right {
    width: 45%; } }
@media screen and (max-width: 768px) {
  .sec-schedule .col-2 .-right {
    width: auto;
    float: none;
    margin-bottom: 20px; } }
.sec-schedule .col-2 .-left {
  width: 510px;
  float: left; }
@media screen and (max-width: 1024px) {
  .sec-schedule .col-2 .-left {
    width: 50%; } }
@media screen and (max-width: 768px) {
  .sec-schedule .col-2 .-left {
    width: auto;
    float: none; } }

span.-kome {
  padding-left: 1em;
  text-indent: -1em;
  display: block;
  font-size: 14px;
  line-height: 1.8; }
@media screen and (max-width: 768px) {
  span.-kome {
    font-size: 12px; } }
span.-kome::before {
  content: "※";
  display: inline; }

.sec-outline {
  background-image: url("../img/bg-stripe-dbl.png");
  background-repeat: repeat;
  padding: 80px 0; }
@media screen and (max-width: 768px) {
  .sec-outline {
    background-size: 10px 10px; } }
@media screen and (max-width: 1024px) {
  .sec-outline {
    padding: 60px 0; } }
.sec-outline div.-inner {
  padding: 20px 16px;
  box-sizing: border-box;
  background: #fff; }
.sec-outline h3.-outline {
  color: #fff;
  background: linear-gradient(to right, #0a1464, #0066cc); }
.sec-outline h3.-outline span {
  border-color: #fff; }
.sec-outline h3.-outline::after {
  display: none;
  content: "";
  width: 114px;
  height: 24px;
  background-image: url("../img/bg-h3-outline.png");
  background-repeat: no-repeat;
  background-position: center center;
  position: absolute;
  right: 24px;
  top: 0;
  bottom: 0;
  margin: auto; }
@media screen and (max-width: 768px) {
  .sec-outline h3.-outline::after {
    display: none; } }
.sec-outline li {
  font-size: 16px; }
@media screen and (max-width: 768px) {
  .sec-outline li {
    font-size: 14px; } }

.sec-question {
  padding: 40px 0 0; }
@media screen and (max-width: 1024px) {
  .sec-question {
    padding: 30px 0 0; } }
.sec-question strong.-ttl {
  font-size: 18px;
  margin-bottom: 1em; }
@media screen and (max-width: 768px) {
  .sec-question strong.-ttl {
    font-size: 16px; } }
.sec-question div.-inner {
  padding: 20px 0;
  margin: 20px auto 0;
  border-top: solid 1px #000;
  border-bottom: solid 1px #000; }
.sec-question li {
  font-size: 16px; }
@media screen and (max-width: 1024px) {
  .sec-question li {
    font-size: 14px; } }

.footer {
  padding: 20px 0;
  display: block; }

  .text-center {
    text-align: center;
  }

  .p-line-height {
    line-height: 1.6;
  }



.img-10000 {
  display: block;
  margin: auto;
  padding: 40px 0 40px;
}

.come {
  font-size: 10px;
}

.text-10000 {
  text-align: center;
}

.text-10000-blue {
  color: #0066CC;
  font-weight: bold;
}

.text-small {
  font-size: 14px;
  margin-top: -10px;
  display: block;
}

@media screen and (max-width: 768px) {
  .text-10000 {
    text-align: left;
  }
  .text-small {
    font-size: 12px;
    line-height: 1.4;
    margin-top: 6px;
  }
}

/* 子どもたちの1day運動教室 */
.section-about {
  background-color: #DFF8FF;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.section-about h2 {
  font-size: 40px;
  color: #0066CC;
  border-bottom: 3px solid #0066CC;
  padding: 4px 10px;
  display: inline-block;
  margin-top: 100px;
}

.section-about .about-img {
  display: flex;
  gap: 50px;
  margin: 60px auto;
}

.section-about p {
  text-align: center;
}

.section-about .about-txt1 {
  font-size: 20px;
  font-weight: bold;
}

.section-about .about-txt2 {
  font-size: 16px;
  margin: 20px auto 60px;
}

.section-about .about-87 {
  margin-bottom: 100px;
}

@media screen and (max-width: 768px) {
  .section-about h2 {
    font-size: 20px;
    border-bottom: 2px solid #0066CC;
    display: inline-block;
    margin-top: 60px;
  }
  .section-about .about-img {
    flex-direction: column;
    align-items: center;
    gap: 30px;
    margin: 40px auto;
  }
  .section-about .about-img img {
    width: 90%;
    max-width: 300px;
  }
  .section-about p {
    width: 90%;
    text-align: left;
  }
  .section-about .about-txt1 {
    font-size: 14px;
  }
  .section-about .about-txt2 {
    font-size: 12px;
    margin: 10px auto 30px;
  }
  .section-about .about-87 {
    width: 90%;
    max-width: 400px;
    margin-bottom: 60px;
  }
}

/* エントリーボタン */
a.btn {
  width: 100%;
  max-width: 480px;
  display: block;
  margin: 0 auto;
  background: #f51e5a;
  font-size: 20px;
  text-align: center;
  color: #fff;
  text-decoration: none;
  line-height: 1;
  padding: 28px 0;
  font-weight: bold;
  border-radius: 10px;
  border-bottom: solid 5px #c1272d;
  position: relative;
  letter-spacing: 0.1em; }

a.btn-orange {
  background: orange;
  border-bottom: solid 5px #c1272d;
 }

a.btn:hover {
  opacity: 0.8;
}

@media screen and (max-width: 768px) {
  a.btn {
    margin: 0 auto;
    font-size: 14px;
    padding: 1em 0; 
  }
}

a.btn::after {
  content: "";
  width: 26px;
  height: 26px;
  display: block;
  background-image: url("../img/icon-btn-arrow.png");
  background-repeat: no-repeat;
  background-position: center center;
  position: absolute;
  right: 24px;
  top: 0;
  bottom: 0;
  margin: auto;
}

@media screen and (max-width: 768px) {
  a.btn::after {
    width: 16px;
    height: 16px;
    right: 10px;
    background-size: 100% 100%; 
  } 
}

.btn-wrapper {
  display: flex;
  flex-direction: column;
  gap: 40px;
  margin: 60px auto;
}

@media screen and (max-width: 768px) {
  .btn-wrapper {
    gap: 20px;
    margin: 40px auto;
  }
}

.btn-top, .btn-bottom {
  border-radius: 10px;
  padding: 30px 40px;
  width: 86%;
  margin: auto;
}

@media screen and (max-width: 768px) {
  .btn-top, .btn-bottom {
    border-radius: 6px;
    padding: 20px 16px;
  }
}

.btn-top {
  background-color: #FDD2DE;
}

.btn-top p {
  font-size: 20px;
  font-weight: 600;
  color: #f51e5a;
}

@media screen and (max-width: 768px) {
  .btn-top p {
    font-size: 18px;
    font-weight: bold;
    line-height: 1.3;
  }
}

.btn-bottom {
  background-color: #FFEDCC;
}

.btn-bottom p {
  font-size: 20px;
  font-weight: 600;
  color: orange;
}

.btn-bottom p span {
  color: #222;
  font-size: 15px ;
  font-weight: normal;
  display: block;
}

@media screen and (max-width: 768px) {
  .btn-bottom p {
    font-size: 18px;
    font-weight: bold;
    line-height: 1.3;
  }
  .btn-bottom p span {
    font-size: 14px ;
  }
}

.btn-flex {
    display: flex;
    gap: 20px;
    margin: 0 auto;
}

@media screen and (max-width: 768px) {
    .btn-flex {
    flex-direction: column;
    gap: 10px;
    margin: 0 auto;
  }
}