@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap');

/* CSS Document */
:root{
  --content-color-base: #2C2A29;
  --content-color-pink: #ff526d;
  --content-color-red: #b2001d;
  --content-color-yellow: #fff44c;
  --bg-img-setting: no-repeat center center / contain;
  --content-width-sp: calc(336vw / 3.75);
  --content-width-pc: 1104px;
  --content-width: min(var(--content-width-sp), var(--content-width-pc));
  --content-bg-width-pc: max(100%, 1920px);
  --font-size-pc: 14px;
  --font-size-sp: calc(14vw / 3.75);
  --font-sans: 'Noto Sans JP', serif;
  --font-serif: "Noto Serif JP", serif;
  --content-font-size: min(var(--font-size-sp), var(--font-size-pc));
  --content-hover-speed: 0.3s;
  --content-arrow-down: url(../img/arrow_down01.png);
  --content-arrow-down-red: url(../img/arrow_down02.png);
  --content-arrow-right: url(../img/arrow_more01.png);
  --content-arrow-right_pink: url(../img/arrow_more02.png);
  --content-arrow-sankaku: url(../img/arrow_dep.svg);
  --content-border-1: 1px solid;
  --content-border-2: 2px solid;
}

.is-pc,
.is-tb{
  display: none
}
.main{
  font-family: var(--font-sans);
  font-size: var(--content-font-size);
  color: var(--content-color-base);
  line-height: 1.3;
  position: relative;
  background: #ffffe5
}
.main *{
  box-sizing: border-box;
}
.inner{
  width: var(--content-width);
  margin: auto;
  position: relative;
}
a{
  transition: var(--content-hover-speed);
}

/***** タイトル・ナビ *****/
.mv-wrapper{
  width: 100%;
}
.mv-wrapper .inner{
  width: 100vw;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.bodycopy{
  background: rgba(255 255 255 / 70%);
  padding: calc(8vw / 3.75) calc(16vw / 3.75);
  text-align: center;
  font-weight: bold;
  line-height: 1.5;
}
.nav-wrapper{
  width: 100%;
  background: var(--content-color-yellow);
}
.nav-wrapper>.inner{
  padding: calc(8vw / 3.75) 0
}
.nav-list{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: calc(24vw / 3.75)
}
.nav-list>li:first-child{
  padding-right: calc(24vw / 3.75);
  border-right: var(--content-border-1) var(--content-color-red);
}
.nav-list>li>a{
  display: block;
  padding: calc(8vw / 3.75) 0 calc(24vw / 3.75);
  font-size: calc(14vw / 3.75);
  font-weight: bold;
  color: var(--content-color-red);
  text-align: center;
  position: relative
}
.nav-list>li>a::after{
  content: "";
  background: var(--bg-img-setting) var(--content-arrow-down-red);
  width: calc(12vw / 3.75);
  height: calc(8vw / 3.75);
  position: absolute;
  right: 0;
  bottom: calc(8vw / 3.75);
  left: 0;
  margin: auto;
}
.nav-list>li>a:hover{
  background: #FFF;
}

.content-wrapper{
  padding: calc(48vw / 3.75) 0 calc(64vw / 3.75)
}
.content-wrapper .inner{
  display: grid;
  gap: calc(24vw / 3.75)
}
.head-title{
  font-size: calc(32vw / 3.75);
  font-weight: 900;
  color: var(--content-color-red);
}
.note-txt{
  display: block;
  padding-left: 1.0em;
  text-indent: -1.0em;
  font-size: 12px;
}
.is-fit{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/*** プレミアム品種 ***/
.content-wrapper.premium{
  background: url("../img/bg_pink_st.png") repeat;
}
.premium-headbox{
  display: grid;
  gap: calc(16vw / 3.75);
}
.head-title#premium{
  display: flex;
  gap: calc(8vw / 3.75);
}
.head-title#premium::before{
  content: "";
  background: url("../img/icon_pre.svg") var(--bg-img-setting);
  width: calc(73vw / 3.75);
  height: calc(74vw / 3.75);
  display: block;
}
.head-title#premium>span{
  flex: 1;
  line-height: 1.25
}
.head-title#premium>span>small{
  font-size: calc(24vw / 3.75);
}
.readcopy{
  font-size: 16px;
  line-height: 1.8
}
.premium-list{
  display: grid;
  gap: calc(24vw / 3.75);
}
.premium-list>li{
  display: grid;
  gap: calc(80vw / 3.75);
}
.premium-img{
  position: relative
}
.premium-img>img{
  clip-path: polygon(50% 0, 85% 15%, 100% 50%, 85% 85%, 50% 100%, 15% 85%, 0 50%, 15% 15%);
}
.premium-title{
  position: absolute;
  right: 0;
  bottom: calc(-60vw / 3.75);
  left: 0;
  margin: auto;
}
.premium-season{
  margin: 0 auto calc(16vw / 3.75);
  text-align: center;
  position: relative;
  display: flex;
  justify-content: center
}
.premium-season>span{
  font-size: 20px;
  font-weight: bold;
  color: #FFF;
  background: var(--content-color-red);
  padding: calc(8vw / 3.75);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(4vw / 3.75);
}
.premium-season>span>small{
  font-size: 14px;
}
.premium-season::before,
.premium-season::after{
  content: "";
  display: block;
  width: calc(21vw / 3.75);
  height: calc(42vw / 3.75);
  background: var(--content-color-red);
}
.premium-season::before{
  clip-path: polygon(100% 0, 100% 50%, 100% 100%, 50% 100%, 100% 50%, 50% 0);
}
.premium-season::after{
  clip-path: polygon(50% 0, 0 50%, 50% 100%, 0 100%, 0 50%, 0 0);
}
.premium-txt{
  line-height: 1.5
}

/*** テーマで選ぶ ***/
.head-title#theme{
  text-align: center;
}
.theme-list{
  display: grid;
  gap: calc(8vw / 3.75);
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: calc(50vw / 3.75) repeat(4, 1fr);
  align-items: flex-start
}
.theme-list>li.theme-list-all{
  grid-column: 1 / 4;
  grid-row: 1 / 2;
  background: #FFF;
  border: var(--content-border-2) var(--content-color-red);
  font-size: calc(20vw / 3.75);
  font-weight: bold;
  color: var(--content-color-red);
  text-align: center;
  position: relative
}
.theme-list>li.theme-list-all::after{
  content: "";
  background: var(--bg-img-setting);
  background-image: var(--content-arrow-down_red);
  width: calc(8vw / 3.75);
  height: calc(12vw / 3.75);
  position: absolute;
  top: 0;
  right: calc(16vw / 3.75);
  bottom: 0;
  margin: auto;
}
.theme-list>li.theme-list-all.is-active::after{
  background-image: var(--content-arrow-down)
}
.theme-list>li{
  background: #FFF;
  padding: calc(4vw / 3.75) calc(4vw / 3.75) calc(8vw / 3.75);
  box-shadow: 0px 2px 5px 0px rgba(0 0 0 / 15%);
}
.theme-list>li.is-active{
  background: var(--content-color-red);
  color: #FFF;
}
.nav-img{
  width: 100%;
  height: calc(40vw / 3.75);
  margin-bottom: calc(4vw / 3.75)
}
.nav-txt{
  font-size: calc(12vw / 3.75);
  font-weight: bold;
  text-align: center;
  color: var(--content-color-red)
}
.theme-list>li.is-active .nav-txt{
  color: #FFF
}
.select-wrapper{
  display: grid;
  gap: calc(64vw / 3.75);
}
.select-content.is-hide{
  display: none
}
.sub-title{
  display: flex;
  gap: calc(8vw / 3.75);
  align-items: center;
  justify-content: center;
  margin-bottom: calc(16vw / 3.75);
}
.sub-title>span{
  font-size: calc(22vw / 3.75);
  font-weight: bold;
  color: var(--content-color-pink);
}
.sub-title::before,
.sub-title::after{
  content: "";
  background: var(--bg-img-setting);
  display: block;
}
.sub-title.assort::before,
.sub-title.assort::after{
  background-image: url("../img/icon_day_11.svg");
  width: 29px;
  height: 35px;
}
.sub-title.high::before,
.sub-title.high::after{
  background-image: url("../img/icon_day_01.svg");
  width: 29px;
  height: 35px;
}
.sub-title.food::before,
.sub-title.food::after{
  background-image: url("../img/icon_day_02.svg");
  width: 40px;
  height: 25px;
}
.sub-title.light::before,
.sub-title.light::after{
  background-image: url("../img/icon_day_03.svg");
  width: 35px;
  height: 27px;
}
.sub-title.flower::before,
.sub-title.flower::after{
  background-image: url("../img/icon_day_04.svg");
  width: 38px;
  height: 36px;
}
.sub-title.onsen::before,
.sub-title.onsen::after{
  background-image: url("../img/icon_day_05.svg");
  width: 34px;
  height: 34px;
}
.sub-title.spot::before,
.sub-title.spot::after{
  background-image: url("../img/icon_day_06.svg");
  width: 25px;
  height: 26px;
}
.sub-title.park::before,
.sub-title.park::after{
  background-image: url("../img/icon_day_07.svg");
  width: 35px;
  height: 38px;
}
.sub-title.exp::before,
.sub-title.exp::after{
  background-image: url("../img/icon_day_08.svg");
  width: 30px;
  height: 25px;
}
.sub-title.stay::before,
.sub-title.stay::after{
  background-image: url("../img/icon_day_09.svg");
  width: 26px;
  height: 24px;
}
.sub-title.train::before,
.sub-title.train::after{
  background-image: url("../img/icon_day_10.svg");
  width: 17px;
  height: 26px;
}

/*** 商品カセット・ボタン ***/
.item-label::before{
  content: "";
  background: var(--bg-img-setting);
  width: 90px;
  height: 32px;
  position: absolute;
  top: 0;
  left: 0
}
.item-label.tag_a::before{
  background-image: url("../img/ico_skyberri.png")
}
.item-label.tag_b::before{
  background-image: url("../img/ico_milkyberry.png")
}
.item-label.tag_c::before{
  background-image: url("../img/ico_kirapika.png")
}
.more-link{
  width: 100%;
  margin: calc(16vw / 3.75) auto 0;
}
.more-link>a{
  display: block;
  border-radius: 100px;
  background: var(--content-color-pink);
  font-size: calc(14vw / 3.75);
  font-weight: bold;
  color: #FFF;
  text-align: center;
  padding: calc(16vw / 3.75) 0;
  position: relative
}
.more-link>a::after{
  content: "";
  background: var(--bg-img-setting);
  background-image: var(--content-arrow-right);
  width: calc(8vw / 3.75);
  height: calc(12vw / 3.75);
  position: absolute;
  top: 0;
  right: calc(10vw / 3.75);
  bottom: 0;
  margin: auto
}
.more-link>a:hover{
  opacity: .8
}
