@charset "UTF-8";
@font-face {
  font-family: Popstarpop;
  src: url(../font/popstarpop.ttf) format("truetype"); }
html {
  font-size: 1px; }

body {
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", Arial, Osaka, Sans-Serif;
  color: #4E422B;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
  border: 0;
  line-height: 1.4;
  font-weight: 500;
  font-size: 16px;
  background: #fff; }

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

h1, h2, h3, h4 {
  margin: 0; }

.d-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }

.flex-reserve {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse; }

ul {
  padding: 0;
  margin: 0;
  list-style: none; }

p {
  margin-top: 0;
  margin-bottom: 0;
  padding: 0; }

a {
  text-decoration: none; }

.align-items-center {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }

.pc {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important; }

.pc-block {
  display: block !important; }

.font-mincho {
  font-family: 'Hina Mincho', serif; }

.sp {
  display: none !important; }

.sp-block {
  display: none !important; }

.justify-content-center {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center; }

.justify-content-between {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }

.justify-content-around {
  -ms-flex-pack: distribute;
  justify-content: space-around; }

.justify-content-end {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end; }

.align-items-baseline {
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline; }

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

.center {
  margin-left: auto;
  margin-right: auto; }

img {
  width: 100%;
  height: 100%;
  object-fit: cover; }

.jusify-content-left {
  justify-content: left !important; }

@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(50px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
@keyframes fadeInLeft {
  0% {
    opacity: 0;
    transform: translateX(-100px); }
  100% {
    opacity: 1;
    transform: translateX(0); } }
@keyframes fadeInRight {
  0% {
    opacity: 0;
    transform: translateX(100px); }
  100% {
    opacity: 1;
    transform: translateX(0); } }
@keyframes scaled_x {
  0% {
    opacity: 1;
    clip-path: inset(0 100% 0 0); }
  100% {
    opacity: 1;
    clip-path: inset(0 0 0 0); } }
.anim {
  opacity: 0; }
  .anim.fadeInUp.is-animated {
    animation: fadeInUp 1s  ease-in-out forwards; }
  .anim.fadeIn.is-animated {
    animation: fadeIn 1s  ease-in-out forwards; }
  .anim.fadeInLeft.is-animated {
    animation: fadeInLeft 1s  ease-in-out forwards; }
  .anim.fadeInRight.is-animated {
    animation: fadeInRight 1s  ease-in-out forwards; }
  .anim.scaled_x.is-animated {
    animation: scaled_x 1s  ease-in-out forwards; }
  .anim.scaled_y.is-animated {
    transform-origin: right;
    animation: scaled_x 1s  ease-in-out forwards; }

@keyframes frontview_fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(100px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
header {
  width: 100%;
  height: 100px;
  background: #fff;
  padding: 0 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5; }
  header.fixed {
    position: fixed;
    animation: fadeIn 0.5s  ease-in-out;
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.3); }
  header .logo {
    width: 136px;
    display: block; }
  header ul {
    display: flex; }
    header ul li {
      margin: 0 20px; }
      header ul li.open a:after {
        width: 100%; }
      header ul li:hover a:after {
        width: 100%; }
      header ul li a {
        font-weight: bold;
        font-size: 18px;
        line-height: 31.5px;
        text-align: right;
        color: #000;
        position: relative; }
        header ul li a:after {
          content: "";
          width: 0;
          height: 0;
          border-bottom: 2px solid #b91840;
          position: absolute;
          left: 0;
          bottom: -5px;
          transition: all 0.2s ease-in-out; }

.frontview {
  width: 100%;
  height: 800px;
  margin-top: 100px; }
  .frontview .swiper-button-next, .frontview .swiper-button-prev {
    color: white; }
  .frontview .swiper-slide.swiper-slide-active .text__wrapper {
    animation: frontview_fadeInUp 1s  ease-in-out forwards; }
  .frontview .swiper-slide .slider__back {
    width: 100%;
    height: 500px;
    background: linear-gradient(rgba(185, 24, 64, 0) 0%, #b91840 100%);
    position: absolute;
    bottom: 0;
    left: 0; }
  .frontview .swiper-slide .text__wrapper {
    position: absolute;
    left: 120px;
    bottom: 40px;
    z-index: 2;
    opacity: 0; }
    .frontview .swiper-slide .text__wrapper .txt {
      font-weight: bold;
      font-size: 72px;
      line-height: 90px;
      text-align: left;
      color: #fff; }
    .frontview .swiper-slide .text__wrapper .more__btn {
      width: 160px;
      height: 48px;
      margin-top: 14px;
      background: transparent;
      border: 2px solid #fff;
      display: flex;
      justify-content: center;
      align-items: center; }
      .frontview .swiper-slide .text__wrapper .more__btn .lbl__txt {
        font-weight: bold;
        font-size: 24px;
        line-height: 42px;
        text-align: left;
        color: #fff; }
      .frontview .swiper-slide .text__wrapper .more__btn .sign__icon {
        width: 8px;
        height: 16px;
        margin-left: 20px; }

.section__title {
  font-weight: 700;
  font-size: 24px;
  line-height: 1.5;
  text-align: center;
  color: #000;
  position: relative; }
  .section__title:after {
    content: "";
    width: 160px;
    height: 0;
    border-bottom: 4px solid #b91840;
    position: absolute;
    left: 50%;
    bottom: -12px;
    transform: translate(-50%); }

section {
  margin-top: 150px; }

.clubs-logan .football__logo {
  width: 160px;
  margin: auto;
  margin-top: 60px; }
.clubs-logan .club-content__wrapper {
  width: 670px;
  margin: auto;
  margin-top: 40px; }
  .clubs-logan .club-content__wrapper .item {
    display: flex;
    align-items: center;
    margin-bottom: 24px; }
    .clubs-logan .club-content__wrapper .item .num__wrapper {
      width: 40px;
      height: 40px;
      margin-right: 16px;
      background: #b91840;
      border-radius: 50%;
      display: flex;
      justify-content: center;
      align-items: center; }
      .clubs-logan .club-content__wrapper .item .num__wrapper span {
        font-weight: 700;
        font-size: 24px;
        line-height: 1;
        text-align: center;
        color: #fff; }
    .clubs-logan .club-content__wrapper .item .c__txt {
      font-weight: bold;
      font-size: 24px;
      line-height: 42px;
      text-align: left;
      color: #000; }

.offical-partner .partner__image {
  width: 824px;
  margin: auto;
  margin-top: 60px;
  position: relative;
  display: flex;
  flex-wrap: wrap; }
  .offical-partner .partner__image .item {
    width: 25%;
    padding: 0 4px;
    margin-bottom: 8px;
    display: flex; }

.watermark {
  width: 320px;
  position: fixed;
  top: 180px;
  right: 80px;
  z-index: -1; }

.top-schedule .calender__wrapper {
  width: 640px;
  height: 578px;
  margin: auto;
  margin-top: 60px; }
  .top-schedule .calender__wrapper iframe {
    width: 100%;
    height: 100%; }

.page-contact__btn {
  width: 240px;
  height: 48px;
  margin: auto;
  margin-top: 80px;
  background: #b91840;
  display: flex;
  justify-content: center;
  align-items: center; }
  .page-contact__btn span {
    font-weight: 700;
    font-size: 18px;
    line-height: 31.5px;
    text-align: center;
    color: #fff; }

footer {
  padding: 80px 0;
  background: #f2f2f2;
  margin-top: 80px; }
  footer.mgTNone {
    margin-top: 0; }
  footer .sns__link {
    display: flex;
    justify-content: center;
    align-items: center; }
    footer .sns__link .lbl__txt {
      font-weight: bold;
      font-size: 18px;
      line-height: 31.5px;
      text-align: left;
      color: #000; }
    footer .sns__link .instagram__icon {
      width: 24px;
      margin: 0 16px; }
    footer .sns__link .youtude__icon {
      width: 34px; }
  footer .address__txt {
    font-weight: 500;
    font-size: 18px;
    line-height: 31.5px;
    margin-top: 65px;
    text-align: center;
    color: #000; }

.copyright {
  font-weight: 500;
  font-size: 14px;
  line-height: 24.5px;
  padding: 20px 0;
  background: #b91840;
  text-align: center;
  color: #fff; }

.toppage {
  width: 56px;
  position: fixed;
  right: 50px;
  bottom: 50px;
  display: none;
  z-index: 50; }

.subpage__top {
  padding-top: 50px; }

.section-sports-content {
  width: 840px;
  margin: auto;
  margin-top: 150px; }
  .section-sports-content .sports__text {
    font-weight: 500;
    font-size: 18px;
    line-height: 31.5px;
    margin-top: 50px;
    text-align: justify;
    color: #000; }
    .section-sports-content .sports__text span.parph {
      margin-bottom: 30px;
      display: block; }
    .section-sports-content .sports__text span.red {
      color: #b91840; }
    .section-sports-content .sports__text span.parph__center {
      text-align: center;
      margin-bottom: 50px;
      position: relative;
      display: block; }
      .section-sports-content .sports__text span.parph__center:after {
        content: "";
        width: 40px;
        height: 20px;
        background-image: url(../img/down_arrow.png);
        background-repeat: no-repeat;
        background-size: contain;
        position: absolute;
        left: 50%;
        bottom: -35px;
        transform: translate(-50%); }
      .section-sports-content .sports__text span.parph__center:last-child:after {
        content: unset; }
  .section-sports-content .sprots__image {
    margin: 0;
    margin-top: 65px; }
  .section-sports-content .sports__graph {
    width: 728px;
    margin: auto;
    margin-top: 70px; }
  .section-sports-content .sponsor__contact {
    margin-top: 64px;
    display: flex;
    flex-direction: column;
    align-items: center; }
    .section-sports-content .sponsor__contact .apply__btn {
      width: 320px;
      height: 48px;
      background: #b91840;
      display: flex;
      justify-content: center;
      align-items: center; }
      .section-sports-content .sponsor__contact .apply__btn span {
        font-weight: 700;
        font-size: 18px;
        line-height: 31.5px;
        text-align: center;
        color: #fff; }
    .section-sports-content .sponsor__contact .sponsor-faq__link {
      font-weight: 500;
      text-decoration: underline;
      font-size: 18px;
      line-height: 31.5px;
      text-underline-offset: 3px;
      margin-top: 20px;
      text-decoration: underline;
      text-align: center;
      color: #b91840; }

.reve-team__wrapper {
  margin-top: 105px; }
  .reve-team__wrapper .team__mark {
    width: 480px;
    margin: auto; }
  .reve-team__wrapper .company__mans {
    width: 900px;
    margin: auto;
    margin-top: 50px;
    display: flex;
    justify-content: center; }
    .reve-team__wrapper .company__mans .item {
      width: 50%;
      padding: 0 60px; }
      .reve-team__wrapper .company__mans .item:last-child {
        border-left: 2px solid #b91840; }
      .reve-team__wrapper .company__mans .item .inner .lbl__txt {
        font-weight: 700;
        font-size: 24px;
        line-height: 42px;
        text-align: center;
        color: #000; }
      .reve-team__wrapper .company__mans .item .inner .company {
        width: 100%;
        margin-top: 46px; }
        .reve-team__wrapper .company__mans .item .inner .company.mans {
          width: 95%;
          margin-left: auto; }

.container {
  color: #000; }
  .container img {
    height: auto;
    vertical-align: bottom; }
  .container figure {
    margin: 0; }
  .container p {
    line-height: 2; }
  .container dl, .container dt, .container dd {
    margin: 0; }

.redBtn,
.blueBtn {
  width: 100%;
  max-width: 380px;
  display: block;
  padding: 25px 0;
  text-align: center;
  background: #DE0615;
  border-radius: 14px;
  font-size: 20px;
  font-weight: 700;
  color: #fff; }

.blueBtn {
  background-color: #0340C9; }

.contentsInner {
  max-width: 840px;
  margin: 0 auto;
  padding: 0 5vw;
  box-sizing: content-box; }

.heading1 {
  margin: 0 0 40px;
  text-align: center;
  font-size: 30px;
  font-weight: 700; }
  .heading1 span {
    display: block;
    margin: 0 0 10px;
    font-size: 40px;
    color: #DE0615; }

.heading1 span,
.num {
  font-family: "Antonio", sans-serif;
  font-weight: 700; }

.topKv {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 100px 0 0;
  aspect-ratio: 12 / 5;
  background: url("../img/top_kv.jpg") no-repeat center 0/100% auto; }
  .topKv .topKvCon {
    width: 43%;
    max-width: 419px;
    padding: 0 0 0 30%;
    box-sizing: content-box;
    /*.redBtn{
        max-width:420px;
        margin:7% 0 0;
        font-size:26px;
    }*/ }
    .topKv .topKvCon .btnArea {
      margin: 40px 0 0; }
      .topKv .topKvCon .btnArea .tit {
        text-align: center;
        font-size: 20px;
        font-weight: 600;
        color: #fff; }
      .topKv .topKvCon .btnArea ul {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        margin: 15px 0 0;
        border-radius: 14px;
        overflow: hidden; }
        .topKv .topKvCon .btnArea ul li {
          width: 50%; }
          .topKv .topKvCon .btnArea ul li a {
            display: block;
            padding: 20px 0;
            text-align: center;
            background: #03C755;
            color: #fff; }
            .topKv .topKvCon .btnArea ul li a span {
              display: inline-block;
              padding: 5px 0 5px 40px;
              background: url("../img/ico_line.svg") no-repeat 0 center/30px auto;
              font-size: 22px;
              font-weight: 600; }
          .topKv .topKvCon .btnArea ul li:nth-child(2) a {
            background: #DE0615; }
            .topKv .topKvCon .btnArea ul li:nth-child(2) a span {
              background-image: url("../img/ico_mail.svg"); }

.topConcept {
  margin: 0;
  padding: 80px 0;
  background: #f5f5f5; }
  .topConcept .contentsInner {
    display: flex;
    flex-direction: row-reverse; }
    .topConcept .contentsInner .txtArea {
      width: 50%;
      padding: 50px 0 0;
      background: url("../img/top_concept_tit.svg") no-repeat 0 0/70% auto; }
      .topConcept .contentsInner .txtArea .tit {
        font-size: 32px;
        font-weight: 700;
        color: #DE0615; }
      .topConcept .contentsInner .txtArea .txt {
        margin: 20px 0 0;
        font-size: 18px;
        font-weight: 600; }
    .topConcept .contentsInner figure {
      width: 45%;
      margin: 0 5% 0 0; }
      .topConcept .contentsInner figure img {
        width: 100%;
        height: auto; }

.topFeature {
  margin: 0;
  padding: 80px 0 60px; }
  .topFeature .lead {
    font-size: 18px; }
  .topFeature .boxFrame {
    margin: 40px 0 0;
    background: url("../img/top_class_bg.jpg") no-repeat center 0/1200px auto; }
    .topFeature .boxFrame .boxFrameBg {
      background: linear-gradient(90deg, rgba(3, 64, 201, 0.7) 0%, rgba(3, 64, 201, 0.7) 50%, rgba(222, 6, 21, 0.7) 50%, rgba(222, 6, 21, 0.7) 100%); }
      .topFeature .boxFrame .boxFrameBg .contentsInner {
        display: flex;
        flex-wrap: wrap; }
    .topFeature .boxFrame .box {
      width: 50%;
      padding: 50px 50px 30px 0; }
      .topFeature .boxFrame .box .tit {
        margin: 0 0 20px;
        text-align: center;
        font-size: 22px;
        color: #fff; }
      .topFeature .boxFrame .box .txtArea {
        min-height: 227px;
        padding: 55px 20px 30px 30px;
        background: #fff;
        border-radius: 14px; }
        .topFeature .boxFrame .box .txtArea dl {
          display: flex;
          flex-wrap: wrap;
          gap: 10px 0; }
          .topFeature .boxFrame .box .txtArea dl dt {
            width: 28%;
            font-size: 15px;
            font-weight: 600;
            color: #0340C9; }
          .topFeature .boxFrame .box .txtArea dl dd {
            width: 72%;
            font-size: 16px; }
        .topFeature .boxFrame .box .txtArea .note {
          margin: 20px 0 0;
          font-size: 13px;
          line-height: 1.4; }
      .topFeature .boxFrame .box:nth-child(2) {
        padding-left: 50px;
        padding-right: 0; }
        .topFeature .boxFrame .box:nth-child(2) .txtArea {
          padding-top: 30px; }
          .topFeature .boxFrame .box:nth-child(2) .txtArea dl dt {
            color: #DE0615; }
      .topFeature .boxFrame .box .link {
        margin: 20px 0 0;
        text-align: center; }
        .topFeature .boxFrame .box .link a {
          padding: 0 23px 0 10px;
          background: url("../img/arrow_white_right.svg") no-repeat right center/20px auto;
          font-size: 17px;
          font-weight: 700;
          color: #fff; }
  .topFeature .sumList {
    text-align: center;
    padding: 50px 0 0; }
    .topFeature .sumList ul {
      display: inline-block;
      text-align: left; }
      .topFeature .sumList ul li {
        margin: 0 0 20px;
        padding: 5px 0 5px 50px;
        text-align: left;
        background: url("../img/ico_ball.svg") no-repeat 0 1px/30px auto;
        font-size: 20px;
        font-weight: 600; }
        .topFeature .sumList ul li:last-child {
          margin-bottom: 0; }

.policyArea {
  margin: 0;
  padding: 80px 0;
  text-align: center;
  background: #F5F5F5; }
  .policyArea .title {
    margin: 0 0 20px;
    font-size: 24px;
    font-weight: 700; }
  .policyArea .title2 {
    padding: 100px 0 0;
    background: url("../img/logo_fcrave.svg") no-repeat center 0/65px auto;
    font-size: 30px;
    font-weight: 700;
    color: #DE0615;
    line-height: 1.4; }

ul.policyList {
  display: flex;
  flex-wrap: wrap;
  gap: 40px 80px;
  margin: 20px 0 0; }
  ul.policyList > li {
    width: calc(50% - 40px);
    /*&:nth-child(3){
        .tit{
            min-height:3em;
            padding:13px 0 0;
        }
    }*/ }
    ul.policyList > li .num {
      font-size: 40px; }
    ul.policyList > li .tit {
      min-height: 3em;
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      align-items: center;
      font-size: 22px; }
    ul.policyList > li figure {
      margin: 25px 0 0; }
    ul.policyList > li .txt {
      margin: 20px 0 0;
      text-align: left;
      font-size: 17px;
      line-height: 1.6; }
    ul.policyList > li ul {
      margin: 15px 0 0;
      text-align: left;
      font-size: 15px; }
      ul.policyList > li ul li {
        margin: 0 0 5px;
        padding: 0 0 0 18px;
        position: relative; }
        ul.policyList > li ul li::before {
          content: "・";
          position: absolute;
          top: 0;
          left: 0; }

.voiceArea {
  margin: 0;
  padding: 80px 0;
  background: #DE0615; }
  .voiceArea .heading1 {
    color: #fff; }
    .voiceArea .heading1 span {
      color: #fff; }
  .voiceArea ul {
    display: flex;
    flex-wrap: wrap;
    gap: 30px 0;
    margin: 40px 0 0; }
    .voiceArea ul > li {
      width: 100%;
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 0 20px;
      padding: 30px;
      background: #fff;
      border-radius: 14px; }
      .voiceArea ul > li figure {
        width: 22%;
        text-align: center; }
        .voiceArea ul > li figure img {
          max-width: 100px;
          display: block;
          margin: 0 auto;
          border-radius: 50%; }
        .voiceArea ul > li figure figcaption {
          margin: 10px 0 0;
          font-size: 13px; }
      .voiceArea ul > li p {
        width: calc(78% - 20px);
        font-size: 15px;
        line-height: 1.6; }

.flowArea {
  margin: 0;
  padding: 80px 0; }
  .flowArea .heading1 {
    margin-bottom: 20px; }
  .flowArea .lead {
    text-align: center;
    font-size: 18px; }
  .flowArea .flowList {
    margin: 40px 0 0;
    text-align: center; }
    .flowArea .flowList ul {
      display: inline-block; }
      .flowArea .flowList ul li {
        padding: 7px 0 40px 80px;
        text-align: left;
        position: relative; }
        .flowArea .flowList ul li::after {
          width: 2px;
          height: 100%;
          content: "";
          display: block;
          background: #DE0615;
          position: absolute;
          top: 45px;
          left: 22.5px; }
        .flowArea .flowList ul li:last-child::after {
          display: none; }
        .flowArea .flowList ul li .num {
          width: 45px;
          aspect-ratio: 1 / 1;
          padding: 11px 0 0;
          text-align: center;
          background: #DE0615;
          border-radius: 50%;
          font-size: 20px;
          color: #fff;
          line-height: 1;
          position: absolute;
          top: 0;
          left: 0; }
        .flowArea .flowList ul li .tit {
          font-size: 20px;
          font-weight: 600;
          line-height: 1.6; }
        .flowArea .flowList ul li .txt {
          margin: 7px 0 0;
          line-height: 1.6; }
          .flowArea .flowList ul li .txt a {
            text-decoration: underline;
            color: #000; }
  .flowArea .redBtn,
  .flowArea .blueBtn {
    margin: 10px auto 0; }

.joseiBanner {
  margin: 0;
  padding: 0 0 80px; }

.faqArea {
  margin: 0;
  padding: 80px 0;
  background: #F5F5F5; }
  .faqArea ul.faqList li {
    margin: 0 0 20px;
    padding: 30px 50px;
    background: #fff;
    border-radius: 14px; }
    .faqArea ul.faqList li:last-child {
      margin-bottom: 0; }
    .faqArea ul.faqList li .qTxt {
      padding: 1px 0 0 30px;
      font-size: 20px;
      font-weight: 600;
      color: #DE0615;
      line-height: 1.6;
      position: relative; }
      .faqArea ul.faqList li .qTxt::before {
        content: "Q.";
        position: absolute;
        top: 0;
        left: 0; }
    .faqArea ul.faqList li .aTxt {
      margin: 10px 0 0;
      padding: 0 0 0 30px;
      font-size: 17px;
      line-height: 1.6; }
      .faqArea ul.faqList li .aTxt .note {
        display: block;
        margin: 5px 0 0;
        font-size: 15px; }

.contactArea {
  margin: 0;
  padding: 60px 0 80px;
  background: #DE0615;
  color: #fff; }
  .contactArea .heading1 span {
    color: #fff; }
  .contactArea .box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
    .contactArea .box figure {
      width: 48%; }
      .contactArea .box figure img {
        height: 100%;
        object-fit: cover; }
    .contactArea .box .txtArea {
      width: 48%;
      font-weight: 600; }
      .contactArea .box .txtArea .redBtn {
        max-width: 100%;
        margin: 20px 0 0;
        background: #fff;
        color: #DE0615; }

.classKv {
  margin: 100px 0 0;
  padding: 60px 0 80px;
  background: #F5F5F5; }
  .classKv .heading1 {
    margin: 0 0 20px;
    font-size: 34px;
    color: #DE0615; }
    .classKv .heading1 span {
      font-size: 30px; }
  .classKv .catch {
    margin: 0 0 30px;
    text-align: center;
    font-size: 26px;
    font-weight: 700; }
  .classKv .txtArea {
    margin: 30px 0 0;
    text-align: center; }
    .classKv .txtArea p {
      max-width: 700px;
      display: inline-block;
      text-align: left;
      font-size: 18px; }

.pointArea {
  margin: 0;
  padding: 60px 0 80px; }
  .pointArea .lead {
    margin: 0 auto;
    font-size: 18px; }
  .pointArea ul {
    display: flex;
    flex-wrap: wrap;
    gap: 0 40px;
    margin: 40px auto 0; }
    .pointArea ul li {
      width: calc((100% - 80px) / 3);
      text-align: center;
      /*.num{
          font-size:36px;
          color:#DE0615;
          line-height:1;
      }
      figure{
          margin:20px 0 0;
      }*/ }
      .pointArea ul li .txt {
        margin: 20px 0 0;
        text-align: left;
        font-size: 18px;
        font-weight: 600;
        line-height: 1.6; }

.classInfoArea {
  margin: 0;
  padding: 60px 0 80px;
  background: #F5F5F5; }
  .classInfoArea .title {
    padding: 0 0 15px;
    text-align: center;
    position: relative; }
    .classInfoArea .title::after {
      width: 100px;
      height: 3px;
      content: "";
      margin: 0 auto;
      background: #DE0615;
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0; }
  .classInfoArea .box {
    margin: 30px 0 40px;
    padding: 40px 100px;
    background: #fff;
    border-radius: 14px; }
    .classInfoArea .box:last-child {
      margin-bottom: 0; }
    .classInfoArea .box dl {
      display: flex;
      flex-wrap: wrap;
      gap: 15px 0; }
      .classInfoArea .box dl dt {
        width: 25%; }
      .classInfoArea .box dl dd {
        width: 75%; }
      .classInfoArea .box dl .fontRed {
        font-weight: 600;
        color: #DE0615; }
      .classInfoArea .box dl .fontBlue {
        font-weight: 600;
        color: #0340C9; }
    .classInfoArea .box dl.threeColumn dt {
      width: 170px; }
    .classInfoArea .box dl.threeColumn dd:nth-of-type(2n+1) {
      width: 120px; }
    .classInfoArea .box dl.threeColumn dd:nth-of-type(2n) {
      width: calc(100% - 290px); }
    .classInfoArea .box .note {
      margin: 20px 0 0;
      font-size: 15px;
      line-height: 1.6; }
    .classInfoArea .box iframe {
      width: 100%;
      height: 400px; }
    .classInfoArea .box .tit {
      margin: 0 0 20px;
      font-weight: 600; }
    .classInfoArea .box .link {
      margin: 15px 0 0;
      text-align: center; }
      .classInfoArea .box .link a {
        text-decoration: underline;
        color: #000; }
    .classInfoArea .box .costArea {
      max-width: 300px;
      margin: 30px auto 0; }
      .classInfoArea .box .costArea dl {
        gap: 10px 0;
        padding: 0 20px; }
        .classInfoArea .box .costArea dl dt {
          width: 60%; }
        .classInfoArea .box .costArea dl dd {
          width: 40%;
          text-align: right; }
      .classInfoArea .box .costArea dl.sum {
        margin: 10px 0 0;
        padding-top: 10px;
        border-top: #ccc 1px solid;
        font-size: 18px;
        font-weight: 600; }
    .classInfoArea .box .txt1 {
      margin: 30px 0 0; }
    .classInfoArea .box .campTxt {
      margin: 40px 0 0;
      text-align: center;
      font-size: 24px;
      font-weight: 600;
      color: #DE0615;
      line-height: 1.4; }
      .classInfoArea .box .campTxt span {
        display: block;
        font-size: 30px; }

.classPointArea {
  margin: 0;
  padding: 60px 0 80px; }
  .classPointArea .title {
    text-align: center;
    font-size: 30px;
    color: #DE0615; }
  .classPointArea ul.policyList {
    margin: 40px 0 0;
    gap: 30px 30px; }
    .classPointArea ul.policyList .txt {
      font-weight: 600; }
    .classPointArea ul.policyList > li {
      width: 100%;
      display: flex;
      flex-wrap: wrap;
      justify-content: flex-start;
      align-items: center;
      padding: 30px 50px;
      border: #DE0615 3px solid;
      border-radius: 14px;
      /*figure{
          width:200px;
          
          img{
              aspect-ratio:1 / 1;
              object-fit:cover;
          }
      }*/ }
      .classPointArea ul.policyList > li .num {
        width: 70px;
        text-align: left;
        color: #DE0615; }
      .classPointArea ul.policyList > li .tit {
        width: 250px;
        min-height: auto;
        display: block;
        margin: 0;
        text-align: left;
        font-size: 22px; }
      .classPointArea ul.policyList > li .txtArea {
        width: calc(100% - 320px); }
        .classPointArea ul.policyList > li .txtArea .txt {
          margin: 0; }
        .classPointArea ul.policyList > li .txtArea ul li {
          padding-left: 16px;
          font-size: 14px; }

.coachArea {
  margin: 0;
  padding: 60px 0 80px;
  background: #DE0615; }
  .coachArea .heading1 {
    color: #fff; }
    .coachArea .heading1 span {
      color: #fff; }
  .coachArea .box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding: 40px 50px;
    background: #fff;
    border-radius: 14px; }
    .coachArea .box figure {
      width: 40%; }
      .coachArea .box figure img {
        border-radius: 10px; }
      .coachArea .box figure figcaption {
        margin: 10px 0 0;
        text-align: center;
        font-size: 18px;
        font-weight: 600; }
        .coachArea .box figure figcaption span {
          display: block;
          font-size: 13px;
          font-weight: normal; }
    .coachArea .box .txtArea {
      width: 53%; }
      .coachArea .box .txtArea dl dt {
        font-size: 18px;
        font-weight: 600; }
      .coachArea .box .txtArea dl dd {
        margin: 10px 0 30px; }
  .coachArea .note {
    margin: 10px 0 0;
    text-align: center;
    font-size: 13px;
    color: #fff; }

.classPolicyArea {
  margin: 0;
  padding: 60px 0 80px;
  background: #F5F5F5; }
  .classPolicyArea .title {
    margin: 0 0 20px;
    text-align: center;
    font-size: 24px;
    font-weight: 700; }
  .classPolicyArea .title2 {
    margin: 0 0 40px;
    padding: 110px 0 0;
    text-align: center;
    background: url("../img/logo_fcrave.svg") no-repeat center 0/65px auto;
    font-size: 30px;
    font-weight: 700;
    color: #DE0615;
    line-height: 1.4; }
  .classPolicyArea .box {
    max-width: 700px;
    margin: 0 auto; }
    .classPolicyArea .box p {
      font-size: 17px; }

.schoolClass .classKv .heading1,
.schoolClass .heading1 span,
.schoolClass .pointArea ul li .num,
.schoolClass .classPointArea .title,
.schoolClass .faqArea ul.faqList li .qTxt,
.schoolClass .classInfoArea .box .campTxt,
.schoolClass .classPointArea ul.policyList > li .num {
  color: #0340C9; }
.schoolClass .pointArea ul li,
.schoolClass .classPointArea ul.policyList > li {
  border-color: #0340C9; }
.schoolClass .classInfoArea .title::after,
.schoolClass .coachArea,
.schoolClass .flowArea .flowList ul li .num,
.schoolClass .flowArea .flowList ul li::after {
  background: #0340C9; }
.schoolClass .classPolicyArea .title2 {
  color: #000; }
.schoolClass .coachArea .heading1 span,
.schoolClass .contactArea .heading1 span {
  color: #fff; }

@media screen and (min-width: 769px) {
  .redBtn,
  .topFeature .boxFrame .box .link a,
  .joseiBanner a,
  .blueBtn {
    transition: all 0.3s; }

  .redBtn:hover {
    background: #b91840; }

  .contactArea .box .txtArea .redBtn:hover {
    background: #EACFD3; }

  .topFeature .boxFrame .box .link a:hover,
  .joseiBanner a:hover,
  .blueBtn:hover {
    opacity: 0.7; }

  .footerFixBtn {
    display: none; } }
@media screen and (max-width: 1260px) {
  .frontview .swiper-slide .text__wrapper .txt {
    font-size: 54px; }

  header ul li a {
    font-weight: bold;
    font-size: 15px; }

  header {
    padding: 0 20px; }

  header ul li {
    margin: 0 10px; }

  header .logo {
    width: 90px; }

  .reve-team__wrapper .company__mans {
    width: 95%; } }
@media screen and (max-width: 850px) {
  .offical-partner .partner__image {
    width: 95%; }

  .section-sports-content {
    width: 95%; } }
@media screen and (max-width: 768px) {
  .pc {
    display: none !important; }

  .pc-block {
    display: none !important; }

  .sp {
    display: flex !important; }

  .sp-block {
    display: block !important; }

  html {
    font-size: 0.2666666vw; }

  header {
    height: 64rem; }

  header {
    padding: 0 0 0 16rem; }

  header .logo {
    width: 102rem; }

  .sp-menu {
    width: 48rem;
    height: 48rem;
    background: #b91840;
    border-radius: 11rem 0 0 11rem;
    position: relative; }
    .sp-menu.open span:nth-child(1) {
      top: 28rem;
      left: 20rem;
      transform: rotate(45deg) translate(-50%); }
    .sp-menu.open span:nth-child(2) {
      opacity: 0; }
    .sp-menu.open span:nth-child(3) {
      top: 28rem;
      left: -2rem;
      transform: rotate(135deg) translate(-50%); }
    .sp-menu span {
      width: 32rem;
      height: 4rem;
      position: absolute;
      top: 8rem;
      left: 50%;
      transform: translate(-50%);
      display: inline-flex;
      transition: all 0.3s ease-in-out;
      transform-origin: center center; }
      .sp-menu span img {
        object-fit: contain; }
    .sp-menu span + span {
      top: 16rem; }
    .sp-menu span + span + span {
      top: 24rem; }
    .sp-menu .lbl {
      width: 100%;
      font-weight: 500;
      font-size: 8rem;
      line-height: 1;
      text-align: center;
      color: #fff;
      position: absolute;
      bottom: 7rem;
      left: 50%;
      transform: translate(-50%); }

  .frontview {
    width: 100%;
    height: 240rem;
    margin-top: 64rem; }

  .frontview .swiper-slide .text__wrapper {
    left: 16rem;
    bottom: 16rem; }

  .frontview .swiper-slide .text__wrapper .txt {
    font-size: 18rem;
    line-height: 24rem; }

  .frontview .swiper-slide .text__wrapper .more__btn {
    width: 80rem;
    height: 24rem;
    margin-top: 12rem;
    border: 1rem solid #fff; }

  .frontview .swiper-slide .text__wrapper .more__btn .lbl__txt {
    font-size: 12rem;
    line-height: 1; }

  .frontview .swiper-slide .text__wrapper .more__btn .sign__icon {
    width: 4rem;
    height: auto;
    margin-left: 10rem; }

  .swiper-button-next:after, .swiper-button-prev:after {
    font-size: 0; }

  section {
    margin-top: 45rem; }

  .section__title {
    font-size: 16rem; }

  .section__title:after {
    width: 80rem;
    height: 0;
    border-bottom: 2rem solid #b91840;
    bottom: -4rem; }

  .clubs-logan .football__logo {
    width: 80rem;
    margin-top: 35rem; }

  .clubs-logan .club-content__wrapper .item .c__txt {
    font-size: 16rem;
    line-height: 28rem; }

  .clubs-logan .club-content__wrapper .item .num__wrapper {
    width: 24rem;
    height: 24rem;
    margin-right: 8rem; }

  .clubs-logan .club-content__wrapper .item .num__wrapper span {
    font-size: 14rem; }

  .clubs-logan .club-content__wrapper {
    width: 85%;
    margin-top: 30rem; }

  .clubs-logan .club-content__wrapper .item:last-child .num__wrapper {
    margin-top: -27rem; }

  .offical-partner .partner__image {
    width: 358rem;
    margin: auto;
    margin-top: 35rem; }

  .top-schedule .calender__wrapper {
    width: 100%;
    height: 338rem;
    margin: auto;
    margin-top: 35rem; }

  .page-contact__btn {
    width: 160rem;
    height: 32rem;
    margin-top: 50rem; }

  .page-contact__btn span {
    font-size: 14rem;
    line-height: 1; }

  footer {
    padding: 28rem 0;
    margin-top: 24rem; }

  footer .sns__link .lbl__txt {
    font-size: 14rem;
    line-height: 1; }

  footer .sns__link .instagram__icon {
    width: 24rem;
    height: 24rem;
    margin: 0 10rem; }

  footer .sns__link .youtude__icon {
    width: 34rem;
    height: 24rem; }

  footer .address__txt {
    font-size: 14rem;
    line-height: 25rem;
    margin-top: 30rem; }

  .toppage {
    width: 24rem;
    right: 8rem;
    bottom: 8rem; }

  .copyright {
    font-size: 12rem;
    line-height: 1.5;
    padding: 12rem 0; }

  .frontview .swiper-slide .slider__back {
    height: 144rem; }

  .clubs-logan .club-content__wrapper .item {
    margin-bottom: 15rem; }

  header ul {
    width: 100%;
    height: 100vh;
    position: fixed;
    top: 64rem;
    left: 0;
    padding-top: 60rem;
    background: white;
    display: none; }

  header ul li {
    margin: 40rem 0; }
    header ul li a {
      display: block;
      width: 100%;
      font-size: 18rem;
      line-height: 1;
      text-align: center; }

  .section-sports-content {
    margin-top: 50rem; }

  .subpage__top {
    padding-top: 56rem; }

  .section-sports-content {
    width: 100%; }

  .section-sports-content .sports__text {
    width: 343rem;
    margin: auto;
    font-size: 14rem;
    line-height: 24rem;
    margin-top: 32rem; }

  .section-sports-content .sprots__image {
    margin: 0;
    margin-top: 28rem; }

  .section-sports-content .sports__text span.parph {
    margin-bottom: 14rem; }

  .section-sports-content .sponsor__contact .apply__btn {
    width: 240rem;
    height: 32rem; }

  .section-sports-content .sponsor__contact .apply__btn span {
    font-size: 14rem;
    line-height: 1; }

  .section-sports-content .sponsor__contact {
    margin-top: 27rem; }

  .section-sports-content .sponsor__contact .sponsor-faq__link {
    font-size: 14rem;
    line-height: 1.5;
    text-underline-offset: 3rem;
    margin-top: 17rem; }

  .reve-team__wrapper .team__mark {
    width: 193rem; }

  .reve-team__wrapper .company__mans .item .inner .lbl__txt {
    font-weight: 700;
    font-size: 14rem;
    line-height: 1; }

  .reve-team__wrapper .company__mans .item {
    padding: 0 23rem; }

  .reve-team__wrapper .company__mans .item .inner .company {
    margin-top: 20rem; }

  .reve-team__wrapper .company__mans .item:last-child {
    border-left: 2rem solid #b91840; }

  .reve-team__wrapper .company__mans .item .inner .company {
    width: 116rem; }

  .reve-team__wrapper .company__mans .item .inner .company.mans {
    width: 104rem; }

  .section-sports-content .sports__text span.parph__center {
    margin-bottom: 48rem; }

  .section-sports-content .sports__text span.parph__center:after {
    width: 40rem;
    height: 20rem;
    left: 50%;
    bottom: -37rem; }

  .section-sports-content .sports__graph {
    width: 343rem;
    margin: auto;
    margin-top: 35rem; }

  .offical-partner .partner__image .item {
    width: 50%;
    padding: 0 4rem;
    margin-bottom: 8rem; }

  .contentsInner {
    max-width: 500px;
    margin: 0 auto;
    padding: 0 6vw; }

  .heading1 {
    margin: 0 0 30px;
    font-size: 24px; }

  .topKv {
    margin-top: 66px;
    aspect-ratio: 390 / 383;
    background: url("../img/top_kv_sp.jpg") no-repeat center 0/100% auto;
    position: relative; }
    .topKv .topKvCon {
      width: 77%;
      padding: 0 0 80px;
      /*.redBtn{
          width:77%;
          margin:0 auto;
          font-size:20px;
          position:absolute;
          left:0;
          right:0;
          bottom:-39px;
      }*/ }
      .topKv .topKvCon .btnArea {
        width: 90%;
        margin: 0 auto;
        position: absolute;
        left: 0;
        right: 0;
        bottom: -39px; }
        .topKv .topKvCon .btnArea ul li a span {
          font-size: 20px; }

  .topConcept {
    padding: 80px 0 60px; }
    .topConcept .contentsInner {
      display: block; }
      .topConcept .contentsInner .txtArea {
        width: 100%; }
        .topConcept .contentsInner .txtArea .tit {
          font-size: 26px; }
        .topConcept .contentsInner .txtArea .txt {
          font-size: 15px; }
      .topConcept .contentsInner figure {
        width: 100%;
        margin: 25px 0 0; }

  .topFeature {
    padding: 40px 0; }
    .topFeature .lead {
      font-size: 15px; }
    .topFeature .boxFrame {
      margin: 30px 0 0;
      background: none; }
      .topFeature .boxFrame .boxFrameBg {
        background: none; }
        .topFeature .boxFrame .boxFrameBg .contentsInner {
          max-width: 100%;
          display: block;
          padding: 0; }
          .topFeature .boxFrame .boxFrameBg .contentsInner .box {
            width: 100%;
            padding: 0;
            background: url("../img/top_class_img_01.jpg") no-repeat right top/100% auto; }
            .topFeature .boxFrame .boxFrameBg .contentsInner .box .boxBg {
              padding: 52px 6vw 30px;
              background: rgba(3, 64, 201, 0.7); }
              .topFeature .boxFrame .boxFrameBg .contentsInner .box .boxBg .txtArea {
                max-width: 500px;
                min-height: auto;
                margin: 0 auto;
                padding: 35px; }
                .topFeature .boxFrame .boxFrameBg .contentsInner .box .boxBg .txtArea .tit {
                  margin: 0 0 28px; }
                .topFeature .boxFrame .boxFrameBg .contentsInner .box .boxBg .txtArea dl dt {
                  font-size: 14px; }
                .topFeature .boxFrame .boxFrameBg .contentsInner .box .boxBg .txtArea dl dd {
                  font-size: 15px; }
            .topFeature .boxFrame .boxFrameBg .contentsInner .box:nth-child(2) {
              background-image: url("../img/top_class_img_02.jpg"); }
              .topFeature .boxFrame .boxFrameBg .contentsInner .box:nth-child(2) .boxBg {
                background: rgba(222, 6, 21, 0.7); }
            .topFeature .boxFrame .boxFrameBg .contentsInner .box .link {
              margin: 15px 0 0; }
              .topFeature .boxFrame .boxFrameBg .contentsInner .box .link a {
                font-size: 16px; }
    .topFeature .sumList {
      padding-top: 40px; }
      .topFeature .sumList ul li {
        min-height: 30px;
        padding: 0 0 0 40px;
        font-size: 15px; }

  .policyArea {
    padding: 60px 0; }
    .policyArea .title {
      font-size: 18px; }
    .policyArea .title2 {
      padding: 90px 0 0;
      background-size: 53px auto;
      font-size: 22px; }

  ul.policyList {
    margin: 10px 0 0; }
    ul.policyList li {
      width: 100%; }
      ul.policyList li .tit {
        min-height: auto;
        font-size: 20px; }
      ul.policyList li .txt {
        font-size: 16px;
        font-weight: 600; }
      ul.policyList li ul {
        font-size: 14px; }
        ul.policyList li ul li {
          padding: 0 0 0 16px; }

  .voiceArea {
    padding: 50px 0 60px; }
    .voiceArea .heading1 {
      font-size: 22px; }
      .voiceArea .heading1 span {
        margin: 0 0 5px;
        font-size: 35px; }
    .voiceArea ul {
      gap: 20px 0;
      margin: 0; }
      .voiceArea ul li {
        width: 100%;
        display: block;
        padding: 30px 15px; }
        .voiceArea ul li figure {
          width: 100%; }
        .voiceArea ul li p {
          width: 100%;
          margin: 20px 0 0;
          font-size: 14px; }

  .flowArea {
    padding: 50px 0 60px; }
    .flowArea .heading1 {
      margin: 0 0 10px;
      font-size: 22px; }
      .flowArea .heading1 span {
        margin: 0 0 5px;
        font-size: 35px; }
    .flowArea .lead {
      font-size: 16px; }
    .flowArea .flowList ul li {
      padding: 2px 0 40px 45px; }
      .flowArea .flowList ul li::after {
        top: 30px;
        left: 15px; }
      .flowArea .flowList ul li .num {
        width: 30px;
        padding: 6px 0 0;
        font-size: 16px; }
      .flowArea .flowList ul li .tit {
        font-size: 18px; }
      .flowArea .flowList ul li .txt {
        margin: 5px 0 0;
        font-size: 15px; }

  .joseiBanner {
    padding: 0 0 60px; }
    .joseiBanner a {
      max-width: 400px;
      display: block;
      margin: 0 auto; }

  .faqArea {
    padding: 40px 0 50px; }
    .faqArea .heading1 {
      font-size: 22px; }
      .faqArea .heading1 span {
        margin: 0 0 5px;
        font-size: 35px; }
    .faqArea ul.faqList li {
      padding: 20px; }
      .faqArea ul.faqList li .qTxt {
        padding-left: 25px;
        font-size: 17px; }
      .faqArea ul.faqList li .aTxt {
        margin: 8px 0 0;
        padding-left: 25px;
        font-size: 15px; }
        .faqArea ul.faqList li .aTxt .note {
          font-size: 13px; }

  .contactArea {
    padding: 40px 0 60px; }
    .contactArea .heading1 {
      font-size: 22px; }
      .contactArea .heading1 span {
        margin: 0 0 5px;
        font-size: 35px; }
    .contactArea .box figure {
      width: 100%; }
    .contactArea .box .txtArea {
      width: 100%;
      margin: 20px 0 0; }
      .contactArea .box .txtArea p {
        font-size: 15px; }

  .footerFixBtn {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    margin: 0;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s;
    position: fixed;
    left: 0;
    bottom: 0; }
    .footerFixBtn a {
      width: 50%;
      padding: 15px 0;
      text-align: center;
      background: #03C755;
      color: #fff; }
      .footerFixBtn a span {
        display: inline-block;
        padding: 5px 0 5px 40px;
        background: url("../img/ico_line.svg") no-repeat 0 center/30px auto;
        font-size: 15px;
        font-weight: 600; }
      .footerFixBtn a:nth-child(2) {
        background: #DE0615; }
        .footerFixBtn a:nth-child(2) span {
          background-image: url("../img/ico_mail.svg"); }
    .footerFixBtn.fixed {
      opacity: 1;
      visibility: visible; }

  .classKv {
    margin: 66px 0 0;
    padding: 40px 0; }
    .classKv .heading1 {
      font-size: 28px; }
      .classKv .heading1 span {
        font-size: 22px; }
    .classKv .catch {
      margin: 0 0 20px;
      font-size: 22px;
      line-height: 1.6; }
    .classKv .txtArea p {
      font-size: 16px; }

  .pointArea {
    padding: 40px 0 50px; }
    .pointArea .lead {
      font-size: 16px; }
    .pointArea ul {
      gap: 30px 0; }
      .pointArea ul li {
        width: 100%;
        /*.num{
            width:80px;
            font-size:30px;
        }*/ }
        .pointArea ul li .txt {
          width: 100%; }

  .classInfoArea {
    padding: 40px 0 50px; }
    .classInfoArea .title {
      padding: 0 0 10px;
      font-size: 20px; }
      .classInfoArea .title::after {
        width: 80px; }
    .classInfoArea .box {
      margin: 20px 0 40px;
      padding: 30px; }
      .classInfoArea .box dl dt {
        width: 30%;
        font-size: 14px; }
      .classInfoArea .box dl dd {
        width: 70%;
        font-size: 15px; }
      .classInfoArea .box dl.threeColumn dt {
        width: 100px; }
      .classInfoArea .box dl.threeColumn dd:nth-of-type(2n+1) {
        width: 70px; }
      .classInfoArea .box dl.threeColumn dd:nth-of-type(2n) {
        width: calc(100% - 170px); }
      .classInfoArea .box .note {
        font-size: 13px; }
      .classInfoArea .box p {
        font-size: 15px;
        line-height: 1.6; }
      .classInfoArea .box .campTxt {
        margin: 30px -10px 0;
        font-size: 20px; }
        .classInfoArea .box .campTxt span {
          font-size: 24px; }

  .classPointArea {
    padding: 40px 0 50px; }
    .classPointArea .title {
      font-size: 26px; }
    .classPointArea ul.policyList {
      margin: 30px 0 0; }
      .classPointArea ul.policyList > li {
        width: 100%;
        padding: 30px 20px;
        text-align: center; }
        .classPointArea ul.policyList > li .num {
          width: 100%;
          text-align: center;
          font-size: 30px;
          line-height: 1; }
        .classPointArea ul.policyList > li .tit {
          width: 100%;
          margin: 10px 0 0;
          text-align: center;
          font-size: 22px; }
        .classPointArea ul.policyList > li .txtArea {
          width: 100%;
          margin: 20px 0 0; }

  .coachArea {
    padding: 40px 0 50px; }
    .coachArea .box {
      padding: 30px; }
      .coachArea .box figure {
        width: 100%;
        text-align: center; }
        .coachArea .box figure img {
          max-width: 200px; }
      .coachArea .box .txtArea {
        width: 100%; }
        .coachArea .box .txtArea dl dt {
          margin: 30px 0 10px; }
        .coachArea .box .txtArea dl dd {
          margin: 0; }

  .classPolicyArea {
    padding: 40px 0 50px; }
    .classPolicyArea .title2 {
      padding: 90px 0 0;
      background-size: 53px auto;
      font-size: 26px; }
    .classPolicyArea .box p {
      font-size: 16px; } }




/*ユニフォームはクラブで所有しており、3,600円/年度で貸し出ししております。*/
.plauer-rental-ex {margin-top: 1em;text-align: center;}
.plauer-rental-ex span{display: inline-block;text-align: left;}