/* ===============================
  HEADER
=============================== */
#header .pc-nav ul li .title a { color:#fff; }

#header h1 {
  background: url(https://file003.shop-pro.jp/PA01141/465/img/logo-white.png) no-repeat center top / cover;
}

@media screen and (max-width:1024px){
  #header h1 {
    background: url(https://file003.shop-pro.jp/PA01141/465/img/logo.png) no-repeat center top / cover;
  }
}

/* ===============================
  ANNOUNCEMENT BAR
=============================== */
.announcement-bar{
  position:fixed;
  top:0;
  left:0;
  z-index:9999;
  width:100%;
  background:#FFF8F0;
  text-align:center;
  font-size:14px;
  font-weight:600;
}

.announcement-link{
  display:block;
  padding:10px 0;
  color:#000;
  text-decoration:none;
}

body{ padding-top:40px; }
body.home{ padding-top:0; }

/* ===============================
  RANKING
=============================== */
.ranking-list{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:40px;
  margin-top:40px;
}

.ranking-list li{
  position:relative;
  text-align:center;
  list-style:none;
}

.ranking-list img{
  width:100%;
  transition:0.3s;
}

.ranking-list li:hover img{
  transform:translateY(-5px);
}

.rank-name{
  margin-top:14px;
  font-size:16px;
  letter-spacing:0.05em;
}

.item-name{
  margin-top:10px;
  font-size:14px;
  letter-spacing:0.04em;
}

.rank-badge{
  position:absolute;
  top:10px;
  left:10px;
  width:28px;
  height:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  border-radius:50%;
  background:#000;
  color:#fff;
}

/* ランキング色 */
.ranking-list li:nth-child(1) .rank-badge{ background:#D4AF37; }
.ranking-list li:nth-child(2) .rank-badge{ background:#C0C0C0; color:#333; }
.ranking-list li:nth-child(3) .rank-badge{ background:#CD7F32; }

/* ===============================
  COMMON TITLE
=============================== */
#top-newitem h2,
#top-ranking h2,
#top-comingsoon h2,
#top-category h2,
#top-feature h2,
#top-news h2{
  text-align:center !important;
  letter-spacing:0.12em;
  margin-bottom:40px;
}

.h2-common:after{
  content:"";
  display:block;
  width:40px;
  height:1px;
  background:#333;
  margin:15px auto 0;
}

/* ===============================
  COMING SOON
=============================== */

/* 1枚だけ表示 */
#top-comingsoon .comingsoon-list li:not(:first-child){
  display:none;
}

/* レイアウト */
#top-comingsoon .comingsoon-list{
  display:flex;
  justify-content:center;
  gap:20px;
}

#top-comingsoon .comingsoon-list li{
  width:23%;
}

/* バナー位置 */
#top-comingsoon .img-wrap{
  position:relative;
}

#top-comingsoon .soon{
  position:absolute;
  top:10px;
  left:10px;
  background:rgba(0,0,0,0.7);
  color:#fff;
  padding:6px 10px;
  font-size:11px;
  letter-spacing:0.1em;
}

/* ===============================
  SP
=============================== */
@media screen and (max-width:768px){

  #top-newitem h2,
  #top-ranking h2{
    margin-bottom:30px;
  }

  .ranking-list{
    grid-template-columns:repeat(2,1fr);
    gap:20px;
  }

  .rank-name{ font-size:13px; }

  #top-comingsoon{
    margin:40px 0;
  }

  #top-comingsoon .comingsoon-list{
    flex-wrap:wrap;
  }

  #top-comingsoon .comingsoon-list li{
    width:48%;
    margin-bottom:20px;
  }

  #top-concept .h2-common{
    text-align:center !important;
  }
  

  /* CTA */
  .bottom-cta{
    position:fixed;
    bottom:12px;
    left:50%;
    transform:translateX(-50%);
    z-index:9999;
  }

  .bottom-cta a{
    display:block;
    background:rgba(0,0,0,0.75);
    color:#fff;
    padding:10px 18px;
    font-size:11px;
    letter-spacing:1.5px;
    border-radius:20px;
    text-decoration:none;
  }
}

/* PCではCTA非表示 */
@media screen and (min-width:769px){
  .bottom-cta{ display:none !important; }
}

#top-comingsoon{
  display:none !important;
}