@charset "UTF-8";

/*================================================
 * 下層ページのタイトル
 ================================================*/
.underVis {
  background: url(../images/bg-class.jpg);
  background-position: center bottom 15%;
  background-size: cover;
}

/*================================================
 * lesson
 ================================================*/
#lesson table,
#lesson td,
#lesson th {
  border: 1px solid #bdbdbd;
  border-collapse: collapse;
  max-width: 980px;
}

#lesson td,
th {
  padding: 3px;
  width: 240px;
  height: 50px;
  text-align: center;
  vertical-align: middle;
}

#lesson th {
  background: rgba(120, 85, 72, 0.6);
  color: #fff;
}

#lesson td.adult {
  background-color: rgba(183, 120, 129, 0.4);
}

#lesson td.kids {
  background-color: rgba(255, 215, 93, 0.4);
}

#lesson td.junior-a {
  background-color: rgba(180, 222, 78, 0.4);
}

#lesson td.junior-b {
  background-color: rgba(133, 191, 183, 0.4);
}

#lesson td.junior-c {
  background-color: rgba(108, 129, 230, 0.4);
}

#lesson td.adagio {
  background-color: rgb(186, 97, 22, 0.4);
}

#lesson td.pointes {
  background: linear-gradient(180deg, #a99db6 0%, #a99db6 50%, transparent 50%, transparent 100%);
  font-size: 13px;
  vertical-align: top;
  line-height: 2;
}
#lesson td.pointes.pointes_junior-c {
  background: linear-gradient(180deg, rgba(108, 129, 230, 0.4) 0%, rgba(108, 129, 230, 0.4) 50%, transparent 50%, transparent 100%);
}
#lesson td.pointes.pointes_adagio {
  background: linear-gradient(180deg, rgb(186, 97, 22, 0.4) 0%, rgb(186, 97, 22, 0.4) 50%, transparent 50%, transparent 100%);
}
#lesson td.pointes.pointes_junior-a {
  background: linear-gradient(180deg, rgba(108, 129, 230, 0.4) 0%, rgba(108, 129, 230, 0.4) 50%, rgba(180, 222, 78, 0.4) 50%, rgba(180, 222, 78, 0.4) 100%);
}

#lesson .class-part {
  margin-bottom: 10px;
  text-align: center;
}

#lesson .class-part div {
  border: 1px solid #fff;
  padding: 20px 15px 5px 15px;
  box-sizing: border-box;
  border-radius: 5px;
}

#lesson .class-part .kids {
  background-color: rgba(255, 215, 93, 0.4);
}

#lesson .class-part .junior-a {
  background-color: rgba(180, 222, 78, 0.4);
}

#lesson .class-part .junior-b {
  background-color: rgba(133, 191, 183, 0.4);
}

#lesson .class-part .junior-c {
  background-color: rgba(108, 129, 230, 0.4);
}

#lesson .class-part .adult {
  background-color: rgba(183, 120, 129, 0.4);
}

#lesson .class-part .name {
  border-bottom: 1px solid #fff;
  padding-bottom: 5px;
}

#lesson .class-part sup {
  font-size: 11px;
  vertical-align: super;
  font-weight: bold;
}

@media screen and (max-width:768px) {
  #lesson th {
    height: auto;
    font-size: 12px;
  }

  #lesson td {
    font-size: 12px;
    width: calc(100% / 5);
    height: 80px;
  }

  #lesson td.pointes {
    font-size: 10px;
    line-height: 1.2;
  }

  #lesson .class-part div {
    width: 49%;
    margin-bottom: 5px;
    padding: 15px 10px 10px 10px;
  }
}


/*================================================
 * price
 ================================================*/
#price {
  padding-top: 1rem;
}

#price ul li {
  list-style: none;
  border-bottom: 1px solid rgba(120, 85, 72, 0.3);
  padding-bottom: 10px;
  margin-bottom: 15px;
  font-size: 18px;
}

#price ul li span {
  font-size: 22px;
}

#price ul li i {
  color: #b77981;
}

@media screen and (max-width:768px) {
  #price ul li {
    font-size: 16px;
  }

  #price ul li span {
    font-size: 20px;
  }
}


/*================================================
 * voice
 ================================================*/
#voice {
  padding-top: 0;
}

#voice .report .uvoice {
  display: table;
  margin-bottom: 4px;
  padding: 10px 20px;
  width: 100%;
  box-sizing: border-box;
  font-size: 14px;
}

#voice .report .uvoice dt {
  width: 130px;
  text-align: center;
  color: #b77981;
  font-size: 14px;
}

#voice .report .uvoice dt img {
  width: 28%;
}

#voice .report .uvoice dt,
#voice .report .uvoice dd {
  display: table-cell;
  vertical-align: middle;
}

#voice .report .arrow_box {
  position: relative;
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid rgba(120, 85, 72, 0.3);
  margin: 10px;
  padding: 20px;
  border-radius: 4px;
}

#voice .report .arrow_box:after,
#voice .report .arrow_box:before {
  right: 100%;
  top: 50%;
  border: solid transparent;
  content: " ";
  height: 0;
  width: 0;
  position: absolute;
  pointer-events: none;
}

#voice .report .arrow_box:before {
  border-color: rgba(216, 216, 216, 0);
  border-right-color: rgba(120, 85, 72, 0.3);
  border-width: 7px;
  margin-top: -7px;
}

#voice .report .arrow_box:after {
  border-color: rgba(255, 255, 255, 0);
  border-right-color: #ffffff;
  border-width: 6px;
  margin-top: -6px;
}

#voice .report .uvoice dd p {
  margin-left: 1em;
}

@media screen and (max-width:768px) {
  #voice .report .uvoice {
    padding: 0;
  }

  #voice .report .uvoice dt {
    width: 53px;
    font-size: 12px;
  }

  #voice .report .uvoice dt img {
    width: 55%;
  }

  #voice .report .arrow_box {
    padding: 10px 12px 10px 10px;
    font-size: 12px;
  }
}