@charset "UTF-8";


/* --------------------------------------------------
   受賞作品詳細ページ
-------------------------------------------------- */
.detail{
  padding-top:0px;
}
@media screen and (max-width:757px){
  .detail{
    padding-top:0px;
  }
}

.detail__hero{
  padding:0 0 90px;
  background:#fff;
}
@media screen and (max-width:757px){
  .detail__hero{
    padding:0 0 56px;
  }
}

.gallery.section{
  background:#fff;
}

.detail__award-tag{
  display:inline-block;
  margin:80px 0 30px;
  padding:10px 30px;
  border-radius:5px;
  background:#013D8C;
  color:#FFFFFF;
  font-size:18px;
  font-weight:500;
  line-height:1.5;
}
@media screen and (max-width:757px){
  .detail__award-tag{
    margin:28px 0 18px;
    padding:8px 14px;
    font-size:12px;
  }
}

.detail__title{
  margin:0;
  font-size:60px;
  line-height:1.3;
  font-weight:600;
  color:#4C4C4D;
}
@media screen and (max-width:757px){
  .detail__title{
    font-size:33px;
  }
}

.detail__company{
  margin:15px 0 0;
  font-size:18px;
  font-weight:700;
    line-height:1.5;
  color:#4C4C4D;
}
@media screen and (max-width:757px){
  .detail__company{
    font-size:14px;
    margin: 8px 0 0;
  }
}

.detail__copy{
  margin:25px 0 0;
  font-size:23px;
  line-height:1.8;
  color:#4C4C4D;
}
@media screen and (max-width:757px){
  .detail__copy{
    margin:16px 0 0;
    font-size:16px;
  }
}

.detail__visual{
  margin-top:42px;
}
@media screen and (max-width:757px){
  .detail__visual{
    margin-top:28px;
  }
}

.detail__main-image-wrap{
  width:100%;
  max-width: 1100px;
  object-fit:cover;
  object-position:center !important;
  margin: 0 auto;
  margin-top:50px;
  margin-bottom:40px;
}
@media screen and (max-width:757px){
  .detail__main-image-wrap{
    max-width:none;
    margin-top:10px;
    margin-bottom:30px;
  }
}

.detail__main-image{
  width:100%;
  max-height: 700px;
  object-fit:contain;
}
@media screen and (max-width:757px){
  .detail__main-image{

  }
}

.detail__thumbs{
  display:flex;
  justify-content:center;
  gap:20px;
  margin-top:26px;
}
@media screen and (max-width:757px){
  .detail__thumbs{
    gap:10px;
    margin-top:18px;
    flex-wrap:wrap;
  }
}

.detail__thumb-button{
  width: 120px;
  height:120px;
  padding:0;
  border:none;
  box-shadow:0 0px 10px rgba(0, 0, 0, 0.187);
  border-radius:5px;
  overflow:hidden;
  transition:border-color 0.3s ease, opacity 0.3s ease;
}
@media screen and (max-width:757px){
  .detail__thumb-button{
    width:56px;
    height:56px;
  }
}

.detail__thumb-button.is-active{
  outline:2px solid #013D8C;
  outline-offset:0;
}
@media screen and (max-width:757px){
  .detail__thumb-button.is-active{
    outline:2px solid #013D8C;
  }
}

.detail__thumb-image{
  width:100%;
  height:100%;
  object-fit:cover;
}

.detail__about{
  padding:0px 0 0;
}

.detail__section-title{
  position:relative;
  margin:0 0 28px;
  padding-left:54px;
  font-size:34px;
  font-weight:700;
  color:#4C4C4D;
}
@media screen and (max-width:757px){
  .detail__section-title{
    padding-left:38px;
    font-size:24px;
    margin:0 0 20px;
  }
}

.detail__section-title::before{
  content:"";
  position:absolute;
  top:20px;
  left:0;
  width:34px;
  height:2px;
  background:#E1E1E5;
}
@media screen and (max-width:757px){
  .detail__section-title::before{
    top:14px;
    width:24px;
  }
}

.detail__text{
  margin:0 0 60px;
  font-size:16px;
  line-height:2.1;
  color:#4C4C4D;
}
@media screen and (max-width:757px){
  .detail__text{
    margin:0 0 40px;
    font-size:14px;
  }
}

.detail__table{
  border-top:1px solid #D8D8DC;
    margin-bottom:100px;
}
@media screen and (max-width:757px){
  .detail__table{
    border-top:1px solid #D8D8DC;
    margin-bottom:80px;
  }
}

.detail__row{
  display:grid;
  grid-template-columns:150px 1fr;
  gap:24px;
  padding:15px 20px;
  border-bottom:1px solid #D8D8DC;
}
@media screen and (max-width:757px){
  .detail__row{
    grid-template-columns:1fr;
    gap: 3px;
    padding:10px 10px;
  }
}

.detail__label{
  font-size:16px;
  font-weight:700;
  color:#4C4C4D;
}
@media screen and (max-width:757px){
  .detail__label{
    font-size:16px;
  }
}

.detail__value{
  font-size:16px;
  color:#4C4C4D;
}
@media screen and (max-width:757px){
  .detail__value{
    font-size:15px;
    line-height: 1.6;
  }
}

.detail__company-name{
  margin:0 0 18px;
  font-size:16px;
}
@media screen and (max-width:757px){
  .detail__company-name{
    margin:0 0 12px;
    font-size:14px;
  }
}

.detail__company-logo{
  width:250px;
  max-width:100%;
}
@media screen and (max-width:757px){
  .detail__company-logo{
    width:200px;
  }
}

.detail__related{
  padding:88px 0 110px;
  background:#F5F4F7;
}
@media screen and (max-width:757px){
  .detail__related{
    padding:56px 0 72px;
  }
}

.detail__related-title{
  margin:0 0 28px;
  font-size:30px;
  font-weight:700;
  color:#4C4C4D;
}
@media screen and (max-width:757px){
  .detail__related-title{
    font-size:24px;
    margin:0 0 20px;
  }
}

.detail__related-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:30px;
}
@media screen and (max-width:1030px){
.detail__related-grid{
    grid-template-columns:repeat(3, 1fr);
    gap:12px;
  }
}
@media screen and (max-width:757px){
  .detail__related-grid{
    grid-template-columns:repeat(2, 1fr);
    gap:10px;
  }
}

.detail__button-wrap{
  margin-top:50px;
  text-align:right;
  display:flex;
  justify-content:flex-end;
}
@media screen and (max-width:757px){
  .detail__button-wrap{
    margin-top:40px;
    text-align:center;
  }
}

/* ボタン本体 */
.detail__button{
  display:flex;
  align-items:center;
  justify-content:space-between;

  width:320px;
  padding:15px 35px;

  border-radius:9999px;
  background:#0B3A78;
  color:#fff;

  font-size:20px;
  font-weight:400;
  letter-spacing:0.05em;

  box-shadow:0 4px 12px rgba(0,0,0,0.12);
  transition:all 0.25s ease;
}
@media screen and (max-width:757px){
.detail__button{
  width:90%;
  padding:10px 35px;
  font-size:18px;
  }
}

/* 矢印 */
.detail__button::after{
  content:"";
  width:12px;
  height:12px;
  border-top:2px solid #fff;
  border-right:2px solid #fff;
  transform:rotate(45deg);
  transition:transform 0.2s ease;
}

/* ホバー */
.detail__button:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 24px rgba(0,0,0,0.18);
}

/* 押したとき */
.detail__button:active{
  transform:translateY(0);
  box-shadow:0 4px 12px rgba(0,0,0,0.12);
}

/* 矢印ちょい動かす */
.detail__button:hover::after{
  transform:translateX(4px) rotate(45deg);
}