/*  ---------------------------
			Layout
---------------------------  */
/* Scss Document */
/* Scss Document */
h4 {
  width: 170px;
  margin: 0 auto 20px auto;
}
@media screen and (max-width: 960px) {
  h4 {
    width: 50%;
    margin-bottom: 20px;
  }
}

#kv {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  #kv {
    margin-top: 60px;
  }
}

#cnt {
  width: 980px;
  margin: 0 auto;
  padding-bottom: 50px;
}
@media screen and (max-width: 960px) {
  #cnt {
    width: 90%;
    padding-top: 5%;
    padding-bottom: 5%;
  }
}
#cnt .box {
  width: 100%;
  background: #fff;
  border-radius: 10px;
  position: relative;
  margin-bottom: 50px;
  -webkit-filter: drop-shadow(1px 3px 5px rgba(0, 0, 0, 0.2));
  -moz-filter: drop-shadow(1px 3px 5px rgba(0, 0, 0, 0.2));
  -ms-filter: drop-shadow(1px 3px 5px rgba(0, 0, 0, 0.2));
  filter: drop-shadow(1px 3px 5px rgba(0, 0, 0, 0.2));
}
@media screen and (max-width: 960px) {
  #cnt .box {
    margin-bottom: 30px;
  }
}
#cnt .box .ttl {
  width: 830px;
  position: absolute;
  top: -20px;
  left: 60px;
}
@media screen and (max-width: 960px) {
  #cnt .box .ttl {
    width: 90%;
    top: -10px;
    left: 5%;
  }
}
#cnt .box .box_inner {
  padding: 50px 40px;
}
@media screen and (max-width: 960px) {
  #cnt .box .box_inner {
    padding: 8vw 5% 8vw 5%;
  }
}

#sousuu {
  width: 100%;
  margin-bottom: 50px;
}
#sousuu h2 {
  margin-bottom: 20px;
}
#sousuu .ad {
  width: 90%;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  #sousuu .ad {
    width: 100%;
  }
}

#dantai .prize_1 {
  width: 729px;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  #dantai .prize_1 {
    width: 100%;
  }
}
#dantai .prize_btn {
  width: 470px;
  margin: -20px auto 40px auto;
}
@media screen and (max-width: 960px) {
  #dantai .prize_btn {
    width: 80%;
    margin-top: 20px;
    margin-bottom: 20px;
  }
}
#dantai ul.photo {
  margin-bottom: 40px;
}
@media screen and (max-width: 960px) {
  #dantai ul.photo {
    justify-content: center;
    margin-bottom: 0;
  }
}
#dantai ul.photo li {
  width: 49%;
}
@media screen and (max-width: 960px) {
  #dantai ul.photo li {
    width: 80%;
    margin-bottom: 20px;
  }
}
#dantai ul.photo.center {
  justify-content: center;
  margin-bottom: 20px;
}
@media screen and (max-width: 960px) {
  #dantai ul.photo.center {
    margin-bottom: 0;
  }
}
#dantai ul.photo.center li {
  width: 100%;
}
@media screen and (max-width: 960px) {
  #dantai ul.photo.center li {
    width: 100%;
  }
}
#dantai .block {
  margin-bottom: 40px;
}
@media screen and (max-width: 960px) {
  #dantai .block {
    margin-bottom: 20px;
  }
}
#dantai .block:last-child {
  margin-bottom: 0;
}

#kojin .prize_1 {
  width: 728px;
  margin: 0 auto 40px auto;
}
@media screen and (max-width: 960px) {
  #kojin .prize_1 {
    width: 100%;
    margin-bottom: 20px;
  }
}
#kojin .top_prize {
  width: 830px;
  margin: 0 auto 40px auto;
}
@media screen and (max-width: 960px) {
  #kojin .top_prize {
    width: 80%;
    margin-bottom: 20px;
  }
}
#kojin .top_prize a p {
  display: none;
}
#kojin .block {
  margin-bottom: 40px;
}
@media screen and (max-width: 960px) {
  #kojin .block {
    margin-bottom: 20px;
  }
}
#kojin .block:last-child {
  margin-bottom: 0;
}

ul.portfolio {
  align-items: flex-start;
}
ul.portfolio li {
  width: 285px;
  margin-bottom: 30px;
}
@media screen and (max-width: 960px) {
  ul.portfolio li {
    width: 80%;
    margin: 0 auto 30px auto;
  }
}
ul.portfolio li a {
  font-size: 16px;
}
@media screen and (max-width: 960px) {
  ul.portfolio li a {
    font-size: 15px;
  }
}
ul.portfolio li a p {
  padding-bottom: 10px;
  letter-spacing: 0;
  display: block;
}
ul.portfolio li a p.name {
  font-weight: bold;
  padding-bottom: 5px;
}
ul.portfolio li a p.school {
  font-size: 12px;
}
@media screen and (max-width: 960px) {
  ul.portfolio li a p.school {
    font-size: 10px;
  }
}
ul.portfolio li a p.title {
  font-weight: bold;
}
ul.portfolio li a p.title.small {
  font-size: 13px;
  padding-top: 4px;
}
@media screen and (max-width: 960px) {
  ul.portfolio li a p.title.small {
    padding-top: 0;
  }
}
ul.portfolio li a .img {
  border: 1px solid #ccc;
  margin-bottom: 10px;
}
ul.portfolio li .txt {
  padding-top: 5px;
  width: 284px;
}
@media screen and (max-width: 960px) {
  ul.portfolio li .txt {
    width: 100%;
  }
}
ul.portfolio li:last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 960px) {
  ul.portfolio.tokubetsu li {
    width: 47%;
  }
}
@media screen and (max-width: 960px) {
  ul.portfolio.tokubetsu li a {
    font-size: 14px;
  }
}
ul.portfolio.tokubetsu li a p {
  line-height: 1.2;
}

#awards {
  padding-top: 10px;
}
@media screen and (max-width: 960px) {
  #awards {
    padding-top: 70px;
  }
}
#awards .awardprize {
  width: 713px;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  #awards .awardprize {
    width: 100%;
  }
}

ul.portfolio.awards {
  margin-top: 40px;
}
@media screen and (max-width: 960px) {
  ul.portfolio.awards {
    margin-top: 20px;
  }
}
ul.portfolio.awards li {
  width: 18%;
}
@media screen and (max-width: 960px) {
  ul.portfolio.awards li {
    width: 48%;
    margin-bottom: 15px;
  }
}
ul.portfolio.awards li p {
  font-size: 12px;
  line-height: 1.4;
}

ul.portfolio.awards:after {
  content: "";
  width: 59%;
}
@media screen and (max-width: 960px) {
  ul.portfolio.awards:after {
    display: none;
  }
}

p.award_cap {
  text-align: left;
}
@media screen and (max-width: 960px) {
  p.award_cap {
    font-size: 12px;
  }
}

.back_top {
  width: 835px;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  .back_top {
    width: 100%;
  }
}

#modal {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 10000;
  display: none;
}
#modal .modal_bg {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
}
#modal .modal_inner {
  position: absolute;
  width: 500px;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 960px) {
  #modal .modal_inner {
    width: 90%;
  }
}
#modal .modal_inner .txt_area {
  background: #000;
  border-radius: 10px;
  padding: 10px 10px;
  margin-top: 10px;
}
#modal .modal_inner p {
  font-size: 14px;
  color: #fff;
}
#modal .modal_inner p.name {
  padding-top: 5px;
  font-size: 12px;
  line-height: 1.2;
}
#modal .modal_inner .modal_close {
  position: absolute;
  top: -30px;
  right: 0;
  width: 20px;
}