@charset "utf-8";
/*------------------------------------------------------------------------------------------------------

APAC 学生デザインコンテスト 2026

------------------------------------------------------------------------------------------------------*/
@media screen and (min-width:767px) {
.for-sp{
  display: none;
  }
.for-pc{
  display: block;
  }

/*header nav ul{
  width: 100%;
  display: flex;
  box-sizing: border-box;
  padding: 0 0 0 20px;
  }*/
  
  .wrap-content{
    box-sizing: border-box;
    padding: 0 20px;
  }
  
/*メインタイトル*/
#main-title .wrap{
  position: relative;
  width: 100%;
  height: calc(100vh - 63px);
  overflow: hidden;
}
#main-title .wrap img.img-main{
  position: absolute;
  display: block;
  width: 100%;
  height: auto;
  min-height: calc(100vh - 62px);/*100vh - 63px - 82px*/
  top: -63px;
  left: 50%;
  /*transform: translatex(-50%);*/
  object-fit: cover;
}
  
  #main-title .wrap .box-title{
  min-width: 760px;
  width: 50%;
  box-sizing: border-box;
  padding: 20px;
  background-color: rgba(0,0,0,0.80);
  border-radius: 15px;
  position: absolute;
  z-index: 11;
  max-width: none;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}
#main-title .wrap .box-title .title-en{
  text-align: center;
  font-size: 28px;
}
#main-title .wrap .box-title h1{
  text-align: center;
  font-size: 40px;
}
#main-title .wrap .box-title .title-date{
  text-align: center;
  font-size: 28px;
}
  
  
/*#main-title .wrap img.img-title{
  position: absolute;
  z-index: 11;
  min-width: 760px;
  width: 50%;
  max-width: none;*/
  /*max-width: 860px;*/
  /*height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  padding: 0 10px;
}*/
#main-title .wrap p.title-txt-1{
  position: absolute;
  z-index: 12;
  bottom: 0;
  left: 0;
  background: #000;
  font-size: 37px;
  color: #FFFF00;
  font-weight: 500;
  text-align: center;
  width: 100%;
  box-sizing: border-box;
  padding: 20px 0;
}

/*リード*/
p.txt-lead{
  font-size: 16px;
  line-height: 1.8;
  padding: 70px 0;
  text-align: center;
  }
.box-contest-theme{
  box-sizing: border-box;
  padding: 30px;
  max-width: 820px;
  margin: 0 auto 100px auto;
	}
.box-contest-theme p.txt-1 span.for-pc{
    display: inline;
  }

/*共通構造指定*/
.area-typeA{
  padding: 0;
  margin-bottom: 30px;
  display: flex;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  }
.area-typeA h3{
  font-size: 22px;
  color: #000;
  background: none;
  padding: 70px 0 0 0;
  margin-bottom: 0;
  width: 31%;
  min-width: 290px;
  text-align: center;
  border-top: #000 solid 5px;
  }
.area-typeA .container{
  width: 69%;
  max-width: 830px;
  box-sizing: border-box;
  padding: 70px 0 100px 24px;
  border-top: #333 solid 1px;
  }

/*コンテスト概要*/
#outline .container p{
  line-height: 1.8;
  margin-bottom: 24px;
  }
#outline .container table{
  width: 100%;    
  max-width: 770px;
  }
#outline .container table th{
  max-width: 150px;
  width: 20%;
  text-align: center;
  vertical-align: middle;
  }
#outline .container table td{
  width: 80%;
  max-width: 620px;
  padding: 20px 0;
  }

/*入賞*/
#prize .container .wrap-flex {
  display: flex;
  justify-content: space-between;
  }
#prize .container .block{
  max-width: 48%;/*367px*/
  /*width: 100%;*/
  }

#prize .container .block .box-award{
  border-left: solid #FFD500 5px;
  box-sizing: border-box;
  padding: 5px 5px 0 15px;
  margin-bottom: 30px;
}
#prize .container .block .box-award h4{
  font-size: 18px;
  font-weight: bold;
  }
#prize .container .block .box-award p{
  font-size: 24px;
  font-weight: bold;
}
#prize .container .txt-annotation{
  font-size: 12px;
  margin-top: 15px;
}
  
#prize .container .block:nth-child(1){
  margin-bottom: 0;
  }

/*応募方法*/
#application .container p.txt-1{
  font-size: 15px;
  line-height: 1.8;
  margin-bottom: 30px;
  }
#application .container p.txt-2{
  font-size: 15px;
  line-height: 1.5;
  font-weight: bold;
  margin-bottom: 8px;
  }
  #application .container p.txt-annotation{
  font-size: 15px;
  margin-bottom: 40px;
}
#application .container a.btn{
  font-size: 18px;
  text-align: left;
  border-radius: 5px;
  width: 370px;
  padding: 15px;
  /*margin-bottom: 30px;*/
  position: relative;
  }
#application .container a.btn::before,#application .container a.btn::after{
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  right: 15px;
  width: 8px;
  height: 2px;
  border-radius: 9999px;
  background-color: #ffffff;
  transform-origin: calc(100% - 0.5px) 50%;
  }
  #application .container a.btn::before{
    transform: rotate(45deg);
  }
  #application .container a.btn::after{
    transform: rotate(-45deg);
  }

#application .container a.btn:hover{
  background: #d74e26;
  }
#application .container ul{
  list-style: disc;
  margin-left: 1em;
  margin-bottom: 12px;
  }
#application .container ul li{
  font-size: 15px;
  line-height: 1.5;
  margin-bottom: 8px;
  }
#application .container ul li:nth-last-child(1){
  margin-bottom: 0;
  }

/*主催*/
/*#organizer .container{
  padding-bottom: 60px;
}*/
#organizer .container .box{
  width: 100%;
  text-align: left;
  margin: 0 auto;
  padding-top: 0;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  }
#organizer .container .box img{
  width: 240px;
  margin: 0 50px 0 0;
  }
  #organizer .container .box p{
    padding: 20px 0;
  }

/*お問い合わせ*/
/*#contact .container{
  padding-bottom: 80px;
  }*/
#contact .container p.txt-1{
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 30px;
}
#contact .container p.txt-2{
  font-size: 18px;
  font-weight: bold;
  line-height: 1.5;
  margin-bottom: 30px;
}
#contact .container a.btn{
  font-size: 18px;
  text-align: left;
  border-radius: 5px;
  width: 280px;
  padding: 10px 15px;
  position: relative;
  }
#contact .container a.btn::before,#contact .container a.btn::after{
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  right: 15px;
  width: 8px;
  height: 2px;
  border-radius: 9999px;
  background-color: #ffffff;
  transform-origin: calc(100% - 0.5px) 50%;
  }
#contact .container a.btn::before{
    transform: rotate(45deg);
  }
#contact .container a.btn::after{
    transform: rotate(-45deg);
  }
#contact .container a.btn:hover{
  background: #d74e26;
  }


  

}