@charset "utf-8";
/*------------------------------------------------------------------------------------------------------

Aautodesk Fusion 学生デザインコンテスト 2024

------------------------------------------------------------------------------------------------------*/
@media screen and (min-width:767px) {

.sp-only{
  display: none;
  }
.pc-only{
  display: block;
  }

/*Header
------------------------------------*/
header .wrap{
  width: 1200px;
  margin: 0 auto;
  padding: 15px 0;
  }
header .logobox{
  width: 140px;
  height: auto;
  padding-top: 0;
  }
header h1.box-title{
  width: 550px;
  padding-top: 8px;
  }
header #pc-navi{
  width: 100%;
  background: #FFF;
  border-bottom: #DDD solid 1px;
  }
header #pc-navi ul{
  display: flex;
  width: 1200px;
  margin: 0 auto;
  padding: 8px 0;
  }
header #pc-navi ul li{
  font-size: 0.87rem;
  padding-right: 2rem;
  }
header #pc-navi ul li a:hover{
  border-bottom: #5F60FF solid 1px;
  color: #5F60FF;
  }


/*メインタイトルエリア
------------------------------------*/
#main-title{ 
  }
#main-title .wrap{
  width: 1200px;
  margin: 0 auto;
  }
#main-title .block-txt{
  width: 1200px;
  height: 400px;
  position: relative;
  }
#main-title .box-grade{
  width: 1200px;
  height: 400px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  background: linear-gradient(to right,  rgba(246,246,246,1) 0%,rgba(246,246,246,1) 40%,rgba(246,246,246,0) 54%,rgba(246,246,246,0) 86%,rgba(246,246,246,1) 99%);
  }
#main-title .box-hero{
  width: 1200px;
  height: 400px;
  text-align: right;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  }
#main-title .box-hero img{
  width: auto;
  height: 400px;
  }
#main-title .box-txt{
  position: absolute;
  top: 50px;
  left: 0;
  padding: 0;
  z-index: 100;
  }
#main-title .box-txt h2 span{
  font-size: 1.3rem;
  margin-bottom: 4px;
  }
#main-title .box-txt h2{
  font-size: 3rem;
  font-weight: 700;
  }
#main-title .box-txt p.txt-date{
  font-size: 1.2rem;
  padding: 8px 0;
  margin: 10px 0 20px 0;
  display: inline-block;
  }
#main-title .box-txt p.txt-lead{
  font-size: 0.97;
  line-height: 1.6;
  }
#main-title .box-txt a{
  width: 280px;
  font-weight: 700;
  } 
#main-title ul.block-btn{
  padding: 0;
  display: flex;
  }
#main-title ul.block-btn li{
  width: 380px;
  padding-top: 10px;
  background: #000;
  border-radius: 8px;
  border: #000 solid 3px;
	margin-right: 20px;
  }
#main-title ul.block-btn li a{

  }
#main-title ul.block-btn li a img{
  width: 80%;
  padding: 0;
  margin-right: 12px;
  }
#main-title ul.block-btn li:hover{
  border: #5F60FF solid 3px;
  }

/*前回のコンテスト結果
------------------------------------*/
#previous-result{
	padding: 30px 0;
	}
#previous-result p span{
	font-size: 1.1rem;
	font-weight: bold;
	color: #F00;
	display: inline;
	margin-bottom: 0;
	}
#previous-result p a{
	font-size: 2rem;
	padding-left: 1rem;
	}
/*リード
------------------------------------*/
#lead{
  padding: 2rem 0 2rem 0;
  text-align: center;
  }
#lead h2{
	margin-bottom: 16px;
	}
#lead p.txt-lead{
	line-height: 2;
	}

/*コンテンツエリア共通
------------------------------------*/
section > .container{
  padding: 3rem 0;
  width: 1200px;
  display: flex;
  margin: 0 auto;
  }
section > .container h3{
  font-size: 1.3rem;
  color: #000;
  background: none;
  padding: 0.5rem 0 0 0;
  width: 290px;
  }
section > .container .block{
  width: 880px;
  margin-left: 30px;
  }
p.txt-honbun{
  font-size: 1rem;
  line-height: 1.8;
  margin-bottom: 1.2rem;
  }
a.btn-black{
  width: 550px;
  margin-bottom: 10px;
  font-weight: 700;
  border: #000 solid 3px;
  }
a.btn-white{
  width: 550px;
  margin-bottom: 10px;
  font-weight: 700;
  border: #FFF solid 3px;
  }
a.btn-black:hover,
a.btn-white:hover{
  border: #5F60FF solid 3px;
  }

p.txt-disclaimer{
  font-size: 0.75rem;
  line-height: 1.2;
  color: #D00;
  background: #FFF;
  border: #D00 solid 1px;
  padding: 0.8rem;
  margin-top: 1rem;
  }

/*今月のテーマ
------------------------------------*/
#theme p.txt-1{
  font-size: 2.5rem;
  margin-bottom: 1.5rem;
  }
#theme .container .box-video {
  position: relative;
  width:560px;
  height:315px;
  padding-top: 0; 
}

/*コンテスト概要
------------------------------------*/
#outline table th{
  width: 180px;
  padding: 1rem 0;
  }
#outline table td{
  padding: 1rem 0;
  }
#outline table td.day{
	line-height: 2;
	}

/*チャンピオンリーグ
------------------------------------*/
#champion h3{
  border: none;
  color: #FFF;
  }
#champion h3 span{
  display: block;
  padding: 15px;
  margin-top: 40px;
  }
#champion ul{
  margin-bottom: 30px;
  }
#champion ul li{
  margin-bottom: 0.8rem;
  }

/*応募方法
------------------------------------*/
#application a.btn-black{
  margin-bottom: 2.5rem;
  }
#application ul li{
  margin-bottom: 0.8rem;
  }

/*Fusion
------------------------------------*/
#fusion .container{
  padding: 60px 0 40px 0;
  display: flex;
  width: 1200px;
  margin: 0 auto;
  }
#fusion .container h3{
  font-size: 1.6rem;
  color: #FFF;
  background: none;
  padding: 0.5rem 0 0 0;
  width: 290px;
  border: none;
  }
#fusion .container .block{
  width: 880px;
  margin-left: 30px;
  }
#fusion p.txt-title{
  font-size: 2.5rem;
  margin-bottom: 0.8rem;
  }
#fusion p.txt-title span{
  font-size: 1.3rem;
  }
#fusion p.txt-catch{
  font-size: 1.6rem;
  margin-bottom: 1.2rem;
  }
#fusion h4{
  margin: 40px 0 12px 0;
  }
#fusion ul.block-btn{
  display: flex;
  }
#fusion ul.block-btn li{
  width: 350px;
  font-weight: 700;
  margin-right: 30px;
  background: #FFF;
  border: #FFF solid 3px;
  border-radius: 6px;
  }
#fusion ul.block-btn li a{
  padding: 25px 0 0 15px;
  }  
#fusion ul.block-btn li:hover{
  border: #5F60FF solid 3px;
  }
#fusion ul.block-youtube{
  display: flex;
  justify-content: space-between;
  }
#fusion ul.block-youtube li{
  width: 280px;
  margin-bottom: 0;
  }
#fusion ul.block-youtube li img{
  margin-bottom: 6px;
  }
#fusion ul.block-youtube li p{
  font-size: 0.9rem;
  line-height: 1.4;
  }

/*コンテスト結果
------------------------------------*/
#lastresult{}
#lastresult ul.block-1{
  display: flex;
  flex-wrap: wrap;
  }
#lastresult ul.block-1 li{
  width: 420px;
  font-size: 1rem;
  margin: 0.5rem;
  }
#lastresult ul.block-2 li{
  margin-bottom: 1rem;
  }
#lastresult ul.block-2 li:hover{
  color: #5F60FF;
  } 

/*スポンサー
------------------------------------*/
#sponsor .box h4{
  font-size: 1.15rem;
  background: #DDD;
  text-align: center;
  padding: 0.2rem 0;
  }
#sponsor .box.gold ul{
  margin-bottom: 30px;
  }
#sponsor .box.gold ul li{
  width: 290px;
  }
#sponsor .box.silver ul{
  display: flex;
  flex-wrap: wrap;
  }
#sponsor .box.silver ul li{
  width: 220px;
  }
#sponsor .box.gold ul li:hover,
#sponsor .box.silver ul li:hover{
  opacity: 0.5;
  }

/*主催
------------------------------------*/
#organizer .container{
  padding: 80px 0;
  }
#organizer .box{
  width: 800px;
  margin: 0;
  display: flex;
  align-items: flex-start;
  text-align: left;
  }
#organizer .box p{
  font-size: 1.1rem;
  margin-left: 3rem;
  padding-top: 1rem;
  }
#organizer .box img{
  width: 250px;
  margin-bottom: 0;
  float: left;
  }

/*お問い合わせ
------------------------------------*/
#contact .container{
  padding: 70px 0;
  }

	
/*-------------------------------------------------------------------------------------------------------------
  コンテスト結果ページ  #contest-result
-------------------------------------------------------------------------------------------------------------*/
/*メインビジュアル
------------------------------------*/
#contest-result #main-title{
	padding: 0;
	}
	
#contest-result #main-title .wrap{
  width: 100%;
  height: 400px;
	padding: 0;
  }
#contest-result #main-title .wrap img {
  width: 100%;
  height: 400px;
  object-fit: cover;
  }	
/*リード
------------------------------------*/
#contest-result #lead{
	padding: 30px 0 20px 0;
	}
#contest-result #lead span{
	font-size: 2rem;
	}


/*受賞作品
------------------------------------*/
#contest-result .area-work{
	padding: 0px;
	margin-bottom: 30px;
	}
#contest-result .wrap-gold{
	border-top: none;
	padding: 20px 0;
	margin-bottom: 0;
	background: #D5BD7B;
	}
#contest-result .wrap-silver{
	border-top: none;
	padding: 20px 0;
	margin-bottom: 0;
	background: #C7C9C9;
	}
#contest-result .wrap-white{
	width: 1200px;
	background: #FFF;
	margin: 0 auto;
	padding: 20px;
	box-sizing: border-box;
	}
#contest-result .wrap-title{
	display: flex;
	align-items: flex-end;
	margin-bottom: 1.5rem;
	}
#contest-result .box-cup{
	width: 260px;
	margin: 0;
	}	
#contest-result .block-title{
	margin-bottom: 0;
	padding-left: 30px;
	}
#contest-result p.txt-title{
	font-size: 2rem;
	margin-bottom: 0.5rem;
	text-align: left;
	}
#contest-result p.txt-name{
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.4;
	text-align: left;
	}
#contest-result p.txt-name span.san{
	font-size: 1rem;
	padding-left: 0.5rem;
	}
#contest-result p.txt-name span.school{
	font-size: 0.9rem;
	}
#contest-result .wrap-comment{
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	}
#contest-result .block-comment{
	width: 400px;
	}
#contest-result dl.box-gold,
#contest-result dl.box-silver{
	margin-top: 1rem;
	}

#contest-result ul.box-pic li img{
  width: 100%;
  height: auto;
  }
#contest-result ul.box-pic{
  width: 740px;
	display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  }
#contest-result ul.box-pic li{
  margin-bottom: 10px;
  }
#contest-result ul.box-pic li:nth-child(1){
  width: 100%;
  height: 400px;
	overflow: hidden;
  }
#contest-result ul.box-pic li:nth-child(1) img{
	width: 740px;
	height: 400px;
	object-fit: cover;
	}
#contest-result ul.box-pic li:nth-child(n+2){
  width: 18%;
  margin-right: 2%;
  }
#contest-result ul.box-pic li:nth-child(5n+1){
  margin-right: 0;
  }
	
/*YouTube*/
.area-video{
  width: 640px;
  margin: 50px auto 30px auto;
  padding: 0;
  }
	
	
	

/*-------------------------------------------------------------------------------------------------------------
チャンピオンリーグページ  #Champ
-------------------------------------------------------------------------------------------------------------*/
#Champ #main-title{
  height: auto;
  }
#Champ #main-title .wrap{
  padding: 60px 0 40px 0;
  }
#Champ #main-title .wrap h2{
  text-align: center;
  }
#Champ #main-title .wrap h2 img{
  width: 700px;
  height: auto;
  }
#Champ p.txt-lead{
  line-height: 2;
	margin-bottom: 2rem;
  }
#Champ #lead a{
	font-size: 1.15rem;
	font-weight: 700;
	border: #000 solid 3px;
	width: 600px;
	margin: 0 auto;
	}
#Champ #lead a:hover{
	border: #5F60FF solid 3px;
	}


/*Champions List
------------------------------------*/
#Champ .area-champions-list h2{
  font-size: 30px;
  padding: 30px 0 50px 0;
  }
#Champ .area-champions-list .container{
  padding: 0 0 25px 0;
  width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  }
#Champ .area-champions-list .block-champion{
  width: 200px;
  height: 210px;
  border-radius: 8px;
  margin-bottom: 15px;
  display: block;
  padding: 0;
  text-align: center;
  margin: 0 10px 40px 10px;
  position: relative;
  }
#Champ .area-champions-list .box-icon{
  margin-right: 0;
  margin-top: -15px;
  }
#Champ .area-champions-list .box-icon img{
  width: 110px;
  height: 110px;
  border-radius: 55px;
  object-fit: cover;
  }
#Champ .area-champions-list p.name{
  font-size: 20px;
  font-weight: 700;
  padding: 20px 0 0 0;
  height: 70px;
  }
#Champ .area-champions-list p.name span{
  font-size: 12px;
  display: block;
  padding-top: 2px;
  }
#Champ .area-champions-list p.point,.area-champions-list p.point-2{
  font-size: 32px;
  width: 100%;
  text-align: center;
  margin-left: 0;
  padding: 6px 0;
  position: relative;
  background: #FFFAB7;
  border-radius: 0 0 8px 8px;
  }
#Champ .area-champions-list p.point::after{
  content: "Point";
  font-size: 13px;
  position: absolute;
  right: 40px;
  bottom: 14px;
  }
#Champ .area-champions-list p.point-2::after{
  content: "Point";
  font-size: 13px;
  position: absolute;
  right: 30px;
  bottom: 14px;
  }

/*チャンピオンリーグ 概要
------------------------------------*/
#Champ #outline p{
  line-height: 1.6;
  margin-bottom: 1.5rem;
  }
#Champ #outline ul{
  list-style: disc;
  margin-left: 1.5rem;
  }
#Champ #outline ul li{
  font-size: 1rem;
  line-height: 1.3;
  margin-bottom: 0.5rem;
  }
#Champ #outline ul li:last-child{
  margin-bottom: 0;
  }

/*作品提出について
------------------------------------*/
#Champ #submission .container p.txt-1{
  font-size: 1.2rem;
  }

/*採点について
------------------------------------*/
#Champ #scoring p.txt-1{
  font-size: 1.2rem;
  line-height: 1.5;
  }

/*応募方法
------------------------------------*/
#Champ #application .container p.txt-1{
  font-size: 1.2rem;
  margin-bottom: 1rem;
  }

/*賞品
------------------------------------*/
#Champ #prize .container .block{
  width: 880px
  }

/*コンテスト結果*/
#Champ #lastresult .container{
  overflow-x: hidden;
  }
#Champ #lastresult table{
  width: 880px;
  font-size: 14px;
  }
#Champ #lastresult table th{
  font-size: 13px;
  background: #EEE;
  text-align: center;
  padding: 3px 0;
  border-top: #DDD solid 1px;
  border-right: #DDD solid 1px;
  border-left: #DDD solid 1px;
  }
#Champ #lastresult table td{
  padding: 8px;
  border: #DDD solid 1px;
  }
#Champ #lastresult table th.cel-1{
  width: 200px;
  }
#Champ #lastresult table th.cel-2,
#Champ #lastresult table th.cel-3,
#Champ #lastresult table th.cel-4,
#Champ #lastresult table th.cel-5,
#Champ #lastresult table th.cel-6,
#Champ #lastresult table th.cel-7,
#Champ #lastresult table th.cel-8,
#Champ #lastresult table th.cel-9,
#Champ #lastresult table th.cel-10{
  width: 80px;
  }
  
/*過去の Champions League*/
#Champ #past-league .container ul li{
  font-size: 16px;
  width: 24%;
  margin-bottom: 14px;
  }
#Champ #past-league .container ul li a{
  display: block;
  color: #FFF;
  background: #000;
  padding: 10px 0 10px 50px;
  border: #000 solid 3px;
  border-radius: 6px;
  }
#Champ #past-league .container ul li span{
  background: #DDD;
  padding: 10px 0 10px 50px;
  }
#Champ #past-league .container ul li a:hover,
  #past-league .container p a:hover{
  border: #5F60FF solid 3px;
  } 
#Champ #past-league .container p a{
  width: 50%;
  padding: 14px 0;
  border: #000 solid 3px;
  border-radius: 6px;
  }
#Champ #past-league .container p a:hover{
  border: #5F60FF solid 3px;
  } 


/*-------------------------------------------------------------------------------------------------------------
チャンピオンリーグ  バトルページ  #Champ-battle
-------------------------------------------------------------------------------------------------------------*/
#Champ-battle #main-title{
  height: 330px;
  }
#Champ-battle #main-title .wrap{
  width: 780px;
  margin: 0 auto;
  padding-top: 50px;
  }
#Champ-battle #main-title .wrap img.mark{
  width: 269px;
  height: auto;
  }
#Champ-battle #main-title .block{
  padding-top: 30px;
  }
#Champ-battle #main-title .block img.title{
  width: 496px;
  }
#Champ-battle #main-title .block h2{
  font-size: 3.8rem;
  padding-top: 4px;
  }

/*champion-work*/
.champion-work{
  padding: 0 15px;
  margin-bottom: 30px;
  }
.champion-work p.txt-kome{
  font-size: 0.92rem;
  color: #C00;
  }
.champion-work .container{
  }
.champion-work .block-champion{
  padding-top: 1.5rem;  
  width: 1200px;
  margin: 0 auto 1rem auto;
  display: flex;
  justify-content: space-between;
  box-sizing: border-box;
  }
.champion-work .block-champion .block-text{
  width: 550px;
  }
.champion-work .block-champion .box-pic{
  width: 630px;
  }
.champion-work .block-champion .box-header{
  margin-bottom: 20px;
  }
.champion-work .box-icon{
  margin-right: 10px;
  }
.champion-work .box-icon img{
  width: 120px;
  height: 120px;
  border-radius: 60px;
  object-fit: cover;
  }
.champion-work p.name{
  font-size: 20px;
  font-weight: bold;
  }
.champion-work p.name span{
  font-size: 14px;
  display: block;
  padding-top: 2px;
  }
.champion-work .block-champion .box-header a.twitter{
  text-align: center;
  padding-top: 10px;
  }
.champion-work .block-champion .box-header a.twitter:hover{
  opacity: 0.7;
  }
.champion-work .block-champion .box-header a.twitter img{
  width: 60px;
  height: 60px;
  border-radius: 5px;
  object-fit: cover;
  margin-bottom: 6px;
  }
.champion-work .block-champion .box-header a.twitter p{
  display: block;
  font-size: 14px;
  font-weight: bold;
  color: #000;
  }
.champion-work .block-champion ul.box-pic li img{
  width: 100%;
  height: auto;
  }
.champion-work .block-champion ul.box-pic{
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  }
.champion-work .block-champion ul.box-pic li{
  }
.champion-work .block-champion ul.box-pic li:nth-child(1){
  width: 100%;
  height: 340px;
  }
.champion-work .block-champion ul.box-pic li:nth-child(1) img{
  width: 100%;
  height: 340px;
  object-fit: cover;
  }
  .champion-work .block-champion ul.box-pic li:nth-child(n+2){
  width: 19%;
  margin-right: 1.2%;
  }
.champion-work .block-champion ul.box-pic li:nth-child(6n){
  margin-right: 0;
  }

/*続きを読む 開閉
-------------------------------------*/
.grad-wrap{
  margin-bottom: 0;
  }
.grad-wrap p{
  font-size: 0.96rem;
  line-height: 1.8;
  margin-bottom: 0.8em;
  }
.grad-wrap p.txt-title{
  font-size: 140%;
  font-weight: bold;
  line-height: 1.3;
  margin-bottom: 0.4em;
  }
.grad-wrap ul{
  margin-left: 1.5rem;
  list-style: disc;
  }
.grad-wrap ul li{
  font-size: 0.96rem;
  line-height: 1.3;
  margin-bottom: 0.5rem;
  }
label.grad-btn {
  width: 100%;
  display: block;
  text-align: right;
  }
.grad-btn::before {
  content: "……続きを読む";
  font-size: 0.82rem;
  color: #000;
  }
.grad-item {
  position: relative;
  overflow: hidden;
  height: 170px; /*隠した状態の高さ*/
  }

/*コンテスト結果ページ用*/
.grad-item-2 {
  position: relative;
  overflow: hidden;
  height: 300px; /*隠した状態の高さ*/
  }
.grad-item-2::before {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 50px; /*グラデーションで隠す高さ*/
  background: -webkit-linear-gradient(top, rgba(255,255,255,0.5) 0%, #FFF 90%);
  background: linear-gradient(top, rgba(255,255,255,0.5) 0%, #FFF 90%);
  content: "";
  }

}
