@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');

/* CSS Document */
:root{
  --content-color-base: #333333;
  --content-color-pink: #ff526d;
  --content-color-red: #b2001d;
  --content-color-yellow: #fff44c;
  --bg-img-setting: no-repeat center center / contain;
  --bg-width-pc: max(100%, 1920px);
  --content-width: min((710vw / 7.5), 992px);
  --font-size-pc: 14px;
  --font-size-sp: calc(24vw / 7.5);
  --content-font-size: min(var(--font-size-sp), var(--font-size-pc));
  --font-sans: "Noto Sans JP", sans-serif;
  --content-hover-speed: 0.3s;
  --content-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.15);
  --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_s: 1px solid;
  --content-border_m: 2px solid;
}

.nopc{
  display: none
}
.main{
  font-family: var(--font-sans);
  font-size: var(--content-font-size);
  font-weight: 500;
  color: var(--content-color-base);
  position: relative;
  line-height: 1.0;
  background: #ffffe5;
}
.main *{
  box-sizing: border-box;
}
.inner{
  width: var(--content-width);
  margin: auto;
  position: relative
}
a{
  transition: var(--content-hover-speed);
}
.note__txt{
  display: block;
  font-size: 12px;
  padding-left: 1.0em;
  text-indent: -1.0em;
}

/***** タイトル・ナビ *****/
.title__wrapper{
  width: 100%;
  height: 500px;
  background: url("../img/pc_mv_bg.png") no-repeat center top;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.main-title{
  width: 480px;
  margin: auto;
  text-align: center;
}
.bodycopy{
  background: rgba(255 255 255 / 70%);
  padding: 10px;
  margin-bottom: 24px;
  text-align: center
}
.bodycopy__txt{
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5;
}
.nav__wrapper{
  width: 100%;
  background: var(--content-color-red);
}
.nav__wrapper>.inner{
  display: flex;
}
.nav__item{
  width: calc(100% - 125px);
  display: flex;
  flex-grow: 1
}
.nav__item>li{
  width: calc(100% / 2);
}
.nav__item>li>a{
  display: block;
  padding: 16px 0 24px;
  font-size: 16px;
  font-weight: bold;
  color: #FFF;
  text-align: center;
  position: relative
}
.nav__item>li>a::after{
  content: "";
  background: var(--bg-img-setting) var(--content-arrow-down);
  width: 16px;
  height: 10px;
  position: absolute;
  right: 0;
  bottom: 8px;
  left: 0;
  margin: auto;
}
.nav__item>li>a:hover{
  background: var(--content-color-pink);
}
.other_dep{
  width: 125px;
  height: 100%;
  background: var(--content-color-pink);
  font-size: 16px;
  font-weight: bold;
  color: #FFF;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  padding: 16px 0 24px;
  cursor: pointer
}
.other_dep::after{
  content: "";
  background: var(--bg-img-setting) var(--content-arrow-sankaku);
  width: 12px;
  height: 9px;
  position: absolute;
  right: 0;
  bottom: 8px;
  left: 0;
  margin: auto
}
.other__item{
  display: none;
  width: 125px;
  position: absolute;
  background: #FFF;
  z-index: 30
}
.other__item>li{
  text-align: center;
}
.other__item>li>a{
  display: block;
  font-size: 16px;
  padding: 8px 10px;
}
.other__item>li>a:hover{
  background: var(--content-color-pink);
  color: #FFF;
}

/*** プレミアム品種 ***/
.content__wrapper.premium{
  background: url("../img/bg_pink_st.png") repeat;
  padding: 80px 0
}
.premium__header{
  display: flex;
  margin-bottom: 32px;
}
.head-title#premium{
  width: 400px;
  display: flex;
  gap: 16px;
}
.head-title#premium::before{
  content: "";
  background: url("../img/icon_pre.svg") var(--bg-img-setting);
  width: 73px;
  height: 74px;
  display: block;
}
.head-title#premium>span{
  flex: 1;
  font-size: 38px;
  font-weight: 900;
  color: var(--content-color-red);
  line-height: 1.25
}
.head-title#premium>span>small{
  font-size: 28px
}
.readcopy{
  flex: 1;
  margin-bottom: 0;
  font-size: 16px;
  line-height: 1.5
}
.premium__list{
  display: flex;
  gap: 24px;
  margin-bottom: 48px;
}
.premium__list>li{
  width: calc((100% - (24px * 2)) / 3);
}
.premium__img{
  width: 257px;
  height: 257px;
  margin: auto;
  text-align: center;
  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__content{
  margin-top: -30px;
  position: relative;
  z-index: 30;
}
.premium__season{
  width: 236px;
  margin: 16px auto;
  text-align: center;
  position: relative;
  display: flex;
}
.premium__season>span{
  font-size: 20px;
  font-weight: bold;
  color: #FFF;
  background: var(--content-color-red);
  padding: 8px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 4px
}
.premium__season>span>small{
  font-size: 14px;
}
.premium__season::before,
.premium__season::after{
  content: "";
  display: block;
  width: 36px;
  height: 36px;
  background: var(--content-color-red);
}
.premium__season::before{
  clip-path: polygon(100% 0, 100% 50%, 100% 99%, 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: calc(25 / 14)
}

/*** テーマで選ぶ ***/
.content__wrapper.theme{
  padding-bottom: 48px;
}
.head-title#theme{
  background: var(--content-color-yellow);
  padding: 16px 0;
  font-size: 30px;
  font-weight: bold;
  color: var(--content-color-red);
  text-align: center;
  margin-bottom: 40px;
}
.theme__list{
  display: grid;
  gap: 12px;
  grid-template-columns: 104px 1fr 1fr 1fr 1fr;
  grid-template-rows: 1fr 1fr 1fr;
  margin-bottom: 40px;
}
.theme__list>li.theme__list_all{
  grid-column: 1 / 1;
  grid-row: 1 / 3;
  max-height: 140px;
  background: #FFF;
  border: var(--content-border_m) var(--content-color-red);
  font-size: 28px;
  font-weight: bold;
  color: var(--content-color-red);
  text-align: center;
  line-height: calc(35 / 28);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative
}
.theme__list>li.theme__list_all::after{
  content: "";
  background: var(--bg-img-setting) var(--content-arrow-down_red);
  width: 16px;
  height: 10px;
  position: absolute;
  right: 0;
  bottom: 20px;
  left: 0;
  margin: auto;
}
.theme__list>li.theme__list_all.is-active::after{
  background-image: var(--content-arrow-down)
}
.theme__list>li{
  background: #FFF;
  padding: 4px 4px 8px;
  box-shadow: var(--content-shadow);
}
.theme__list>li.is-active{
  background: var(--content-color-red);
  color: #FFF;
}
.theme__list>li.high{
  grid-column: 2 / 3;
  grid-row: 1 / 2;
}
.theme__list>li.food{
  grid-column: 3 / 4;
  grid-row: 1 / 2;
}
.theme__list>li.right{
  grid-column: 4 / 5;
  grid-row: 1 / 2;
}
.theme__list>li.flower{
  grid-column: 5 / 6;
  grid-row: 1 / 2;
}
.theme__list>li.onsen{
  grid-column: 2 / 3;
  grid-row: 2 / 3;
}
.theme__list>li.spot{
  grid-column: 3 / 4;
  grid-row: 2 / 3;
}
.theme__list>li.park{
  grid-column: 4 / 5;
  grid-row: 2 / 3;
}
.theme__list>li.exp{
  grid-column: 5 / 6;
  grid-row: 2 / 3;
}
.theme__list>li.stay{
  grid-column: 2 / 3;
  grid-row: 3 / 4;
}
.theme__list>li.train{
  grid-column: 3 / 4;
  grid-row: 3 / 4;
}
.nav__img{
  width: 100%;
  height: 66px;
  margin-bottom: 4px;
}
.nav__img>img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center
}
.nav__txt{
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  color: var(--content-color-pink)
}
.theme__list>li.is-active .nav__txt{
  color: #FFF
}

.select__content.is-hide{
  display: none
}
.select__content+.select__content{
  margin-top: 60px;
}
.sub-title{
  background: url("../img/bg_h2.png") repeat-x left top / contain;
  font-size: 24px;
  font-weight: bold;
  color: var(--content-color-pink);
  padding: 16px;
  margin-bottom: 24px;
  display: flex;
  gap: 24px;
  align-items: center
}
.sub-title::before{
  content: "";
  background: var(--bg-img-setting);
  display: block;
}
.sub-title.high::before{
  background-image: url("../img/icon_day_01.svg");
  width: 29px;
  height: 35px;
}
.sub-title.food::before{
  background-image: url("../img/icon_day_02.svg");
  width: 40px;
  height: 25px;
}
.sub-title.right::before{
  background-image: url("../img/icon_day_03.svg");
  width: 35px;
  height: 27px;
}
.sub-title.flower::before{
  background-image: url("../img/icon_day_04.svg");
  width: 38px;
  height: 36px;
}
.sub-title.onsen::before{
  background-image: url("../img/icon_day_05.svg");
  width: 34px;
  height: 34px;
}
.sub-title.spot::before{
  background-image: url("../img/icon_day_06.svg");
  width: 25px;
  height: 26px;
}
.sub-title.park::before{
  background-image: url("../img/icon_day_07.svg");
  width: 35px;
  height: 38px;
}
.sub-title.exp::before{
  background-image: url("../img/icon_day_08.svg");
  width: 30px;
  height: 25px;
}
.sub-title.stay::before{
  background-image: url("../img/icon_day_09.svg");
  width: 26px;
  height: 24px;
}
.sub-title.train::before{
  background-image: url("../img/icon_day_10.svg");
  width: 17px;
  height: 26px;
}

/*** 商品カセット・ボタン ***/
.product-list *{
  line-height: 1.4
}
.item-label::before{
  content: "";
  background: var(--bg-img-setting);
  width: 90px;
  height: 32px;
  position: absolute;
  top: 0;
  left: 0
}
.item-label.premium1::before{
  background-image: url("../img/ico_skyberri.png")
}
.item-label.premium2::before{
  background-image: url("../img/ico_milkyberry.png")
}
.item-label.premium3::before{
  background-image: url("../img/ico_kirapika.png")
}

.more__link{
  width: 650px;
  margin: 32px auto;
}
.more__link>a{
  display: block;
  background: #FFF;
  border: var(--content-border_m) var(--content-color-pink);
  font-size: 16px;
  font-weight: bold;
  color: var(--content-color-pink);
  text-align: center;
  padding: 16px 0;
  position: relative
}
.more__link>a::after{
  content: "";
  background: var(--bg-img-setting);
  background-image: var(--content-arrow-right_pink);
  width: 10px;
  height: 16px;
  position: absolute;
  top: 0;
  right: 24px;
  bottom: 0;
  margin: auto
}
.more__link>a:hover{
  background: var(--content-color-pink);
  color: #FFF;
}
.more__link>a:hover::after{
  background-image: var(--content-arrow-right);
}

.close-txt{
  font-size: 16px;
}
