@charset "UTF-8";

/* ------------------------------------------------------------
カテゴリページ・商品ページ
------------------------------------------------------------ */
.fv {
  position: relative;
}
.fv_logo{
  width: 58%;
  position: absolute;
  top: 60.8%;
  left: 0;
  right: 0;
  margin: 0 auto;
}
.fv_icon{
  position: absolute;
  top: 52.5%;
  left: 5.4%;
  width: 18.6%;
}
.fv_lens_list {
  display: flex;
  position: absolute;
  top: 79%;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  list-style: none;
}
.fv_lens_list_item{
  position: absolute;
  width: 17%;
}
.fv_lens_list_item:first-child{
  left: 0;
  z-index: 9;
}
.fv_lens_list_item:nth-child(2){
  left: 9.8%;
  z-index: 8;
}
.fv_lens_list_item:nth-child(3){
  left: 19.8%;
  z-index: 7;
}
.fv_lens_list_item:nth-child(4){
  left: 30%;
  z-index: 6;
}
.fv_lens_list_item:nth-child(5){
  left: 40.8%;
  z-index: 5;
}
.fv_lens_list_item:nth-child(6){
  left: 52%;
  z-index: 4;
}
.fv_lens_list_item:nth-child(7){
  left: 62%;
  z-index: 3;
}
.fv_lens_list_item:nth-child(8){
  left: 72.5%;
  z-index: 2;
}
.fv_lens_list_item:nth-child(9){
  left: 82.5%;
  z-index: 1;
}
.release{
    position: relative;
}
.release_main {
    position: absolute;
    top: 22.5%;
    left: 10%;
    width: 80%;
}
.release_sub{
    position: absolute;
    top: 51%;
    right: 5.8%;
    width: 46.1%;
    opacity: 0;
    transform: scale(0.3);
    transition: opacity 0.4s ease-out, transform 0.4s ease-out;
}
.release_list{
  list-style: none;
}
.release_list_item{
    position: absolute;
    opacity: 0;
    transform: scale(0.3);
    transition: opacity 0.4s ease-out, transform 0.4s ease-out;
}
/* 大ハート（anime）にactiveが付いたら連動表示 */
.release_main.active ~ .release_sub {
  opacity: 1;
  transform: scale(1);
  transition-delay: 0.3s;
}
/* 表示時：ふわっと登場 → 継続的にぽこぽこ動く */
.release_main.active ~ .release_list .release_list_item {
  opacity: 1;
  transform: scale(1);
  animation: popPop 1.5s ease-in-out infinite;
  transition-delay: 0.5s;
}
/* 各アイテムに遅延をつける（ふわっと順番に） */
.release_list_item.heart01 { transition-delay: 0.1s; animation-delay: 0.6s; }
.release_list_item.heart02 { transition-delay: 0.15s; animation-delay: 0.7s; }
.release_list_item.heart03 { transition-delay: 0.2s; animation-delay: 0.8s; }
.release_list_item.heart04 { transition-delay: 0.25s; animation-delay: 0.9s; }
.release_list_item.heart05 { transition-delay: 0.3s; animation-delay: 1s; }
.release_list_item.heart06 { transition-delay: 0.35s; animation-delay: 1.1s; }

/* ポコポコかわいい動き */
@keyframes popPop {
  0%, 100% { transform: scale(.9); }
  50%      { transform: scale(1.2); }
}

.release_sub {
  transition-delay: 0.2s;
}

.release_list_item.heart01{
  top: 26%;
  left: 18%;
  width: 2.45%;
}
.release_list_item.heart02{
  top: 31%;
  left: 11%;
  width: 4.9%;
}
.release_list_item.heart03{
  top: 43%;
  right: 12%;
  width: 1.96%;
}
.release_list_item.heart04{
  top: 46%;
  right: 19%;
  width: 3.22%;
}
.release_list_item.heart05{
  top: 69%;
  left: 40%;
  width: 1.4%;
}
.release_list_item.heart06{
  top: 72%;
  left: 7.3%;
  width: 2.45%;
}

.lineup {
  background-color: #f5c8dd;
  position: relative;
  padding-top: 50%;
}
@media screen and (max-width: 480px) {
  .lineup {
    padding-top: 54vw;
  }
}
.lineup::before{
  background-image: url(/images/pc/type/se_fabulous1d/bg_lineup_wave.webp);
  background-position: top center;
  background-repeat: no-repeat;
  content: "";
  display: block;
  width: 100%;
  height: 5vw;
  position: absolute;
  top: -5vw;
  left: 0;
  right: 0;
  margin: 0 auto;
}
.lineup_title{
  position: absolute;
  width: 31.8%;
  left: 0;
  right: 0;
  top: 3%;
  margin: 0 auto;
}
.lineup_text{
  position: absolute;
  width: 82.6%;
  left: 0;
  right: 0;
  top: 9%;
  margin: 0 auto;
}
.lineup_image{
  position: absolute;
  width: 28.2%;
  top: 33%;
  left: -19.5%;
  right: 0;
  margin: 0 auto;
}

.lineup_wrap{
  background-image: url(/images/pc/type/se_fabulous1d/bg_lineup_top.webp),url(/images/pc/type/se_fabulous1d/bg_lineup_bottom.webp);
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: top center, bottom center;
  padding: 5% 0 12%;
}
.lineup_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 0 9.6%;
  list-style: none;
}
.lineup_list_item {
  width: 48%;
  position: relative;
  margin-bottom: 18px;
}
.lineup_list_item a{
  text-decoration: none;
}
.lineup_list_item:first-of-type img{
  width: 83%;
  margin: 0 auto;
}
.lineup_lens {
  position: absolute;
  top: 61%;
  left: -9%;
  width: 36%;
}
.lineup_SubTitle{
  color: #c80f32;
  font-size: 1.2rem;
  letter-spacing: 3px;
  text-align: left;
  margin-top: 8px;
  padding-left: 25%;
}
@media screen and (max-width: 480px) {
  .lineup_SubTitle{
    font-size: 2.66vw;
  }
}
.campaign {
  position: relative;
}
.campaign_main {
  position: absolute;
  top: 17.5%;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 86%;
  z-index: 2;
}
.campaign_frame {
  position: absolute;
  top: 19%;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 82.2%;
}
.campaign_btn{
  position: absolute;
  top: 79.5%;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 97.2%;
}
.campaign_icon_s{
  position: absolute;
  top: 18%;
  right: 13%;
  width: 2.8%;
}
.campaign_icon_l{
  position: absolute;
  top: 24%;
  right: 16%;
  width: 4.6%;
}
.campaign_icon_s,
.campaign_icon_l{
  opacity: 1;
  transform: scale(1);
  animation: popPop 1.5s ease-in-out infinite;
  transition-delay: 0.5s;
}

/*まとめ買いページ*/
.campaign.campaign_no_link .campaign_main {
  top: 20.5%;
}
.campaign.campaign_no_link .campaign_frame {
  top: 22%;
}
.campaign.campaign_no_link .campaign_icon_s{
  top: 21%;
}
.campaign.campaign_no_link .campaign_icon_l{
  top: 27%;
}

.about{
  background-color: #f5c8dd;
  position: relative;
  padding-top: 40%;
}
.about_title{
  position: absolute;
  top: 3.5%;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 42%;
}
.about_image{
  position: relative;
}
.about_lens{
  position: absolute;
  top: 46%;
  left: 8%;
  width: 43.8%;
}
.about_text{
  position: absolute;
  top: 48%;
  right: 10%;
  width: 38.5%;
}

.color_list_item {
  position: relative;
  list-style: none;
}
.color_list_wrap{
  align-items: center;
  display: flex;
  flex-direction: row-reverse;
  position: absolute;
  top: 34%;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 86%;
}
.color_lens{
  position: relative;
  margin-right: -7%;
}
.color_lens::before {
  content: "";
  position: absolute;
  top: 90%;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 34%;
  height: 12%;
  border-radius: 50%;
  background-color: rgba(0, 0, 0, 0.4);
  filter: blur(10px);
  transform: translateY(10px);
  mix-blend-mode: multiply;
  z-index: -1;
  pointer-events: none;
}
.color_name{
  font-size: 1.2rem;
  color: #c80f32;
  text-align: center;
  position: absolute;
  font-weight: 700;
  left: 0;
  right: 0;
  top: 6%;
  letter-spacing: 5px;
}
@media screen and (max-width: 480px) {
  .color_name{
    font-size: 2.2vw;
  }
}
.color_text{
  color: #c80f32;
  font-size: 2.2rem;
  font-weight: 700;
  text-align: center;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 6%;
  line-height: 1.6;
  margin: 0 auto;
  letter-spacing: 3px;
}
@media screen and (max-width: 480px) {
  .color_text{
    font-size: 3.73vw;
    line-height: 1.4;
  }
}
.color_list_item:last-child .color_text{
  bottom: 5%;
}

.specBg{
  background-image: url(/images/pc/type/se_fabulous1d/bg_spec_top.webp),url(/images/pc/type/se_fabulous1d/bg_spec_bottom.webp);
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: top center, bottom center;
  padding: 5% 0;
}
.spec_image{
  width: 76.6%;
  margin: 0 auto 10px;
}
.spec_text{
  color: #444;
  font-size: 2.4rem;
  margin-bottom: 10px;
  text-align: center;
  letter-spacing: 3px;
  line-height: 1.4;
  font-weight: 500;
}
@media screen and (max-width: 480px) {
  .spec_text{
    font-size: 3.73vw;
    line-height: 1.6;
  }
}
.spec_lens_list {
  display: flex;
  align-items: center;
  position: relative;
  width: 82.9%;
  margin: 0 auto 10px;
  list-style: none;
}
.spec_lens_list_item{
  position: relative;
  margin-left: -42px;
  z-index: 0;
}
@media screen and (max-width: 480px) {
  .spec_lens_list_item{
    margin-left: -23px;
  }
}
.spec_lens_list_item:first-child{
  margin-left: 0;
  z-index: 9;
}
.spec_lens_list_item:nth-child(2){
  z-index: 8;
}
.spec_lens_list_item:nth-child(3){
  z-index: 7;
}
.spec_lens_list_item:nth-child(4){
  z-index: 6;
}
.spec_lens_list_item:nth-child(5){
  z-index: 5;
}
.spec_lens_list_item:nth-child(6){
  z-index: 4;
}
.spec_lens_list_item:nth-child(7){
  z-index: 3;
}
.spec_lens_list_item:nth-child(8){
  z-index: 2;
}
.spec_lens_list_item:nth-child(9){
  z-index: 1;
}
.specInfo{
  margin: 0 5%;
}

.specDetail{
  border-bottom: 2px solid #c80f32;
  display: flex;
  flex-wrap: wrap;
  margin: 2.5% 5% 5%;
  padding: 0 3% 3%;
  position: relative;
}
.specDetail::before{
  background-image: url(/images/pc/type/se_fabulous1d/icon_spec_heart.webp);
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center center;
  content: "";
  display: block;
  width: 35px;
  height: 35px;
  position: absolute;
  top: calc(50% - 28px);
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: 2;
}
@media screen and (max-width: 480px) {
  .specDetail::before{
    width: 21px;
    height: 21px;
    top: calc(50% - 19px);
  }
}
.specDetail_block{
  align-items: center;
  width: 50%;
  display: flex;
  flex-direction: column;
  min-height: 310px;
}
@media screen and (max-width: 480px) {
  .specDetail_block{
    min-height: 210px;
  }
}
.specDetail_image{
  margin-bottom: 5%;
}
.specDetail_block img{
  margin: 0 auto;
}
.specDetail_block:nth-of-type(1){
  border-right: 2px solid #c80f32;
  border-bottom: 2px solid #c80f32;
  padding-top: 1.7%;
}
.specDetail_block:nth-of-type(1) img{
  width: 70%;
}
@media screen and (max-width: 480px) {
  .specDetail_block:nth-of-type(1) img{
    width: 54%;
  }
}
.specDetail_block:nth-of-type(2){
  border-bottom: 2px solid #c80f32;
  padding-top: 1.8%;
}
@media screen and (max-width: 480px) {
  .specDetail_block:nth-of-type(2){
    padding-top: 3.2%;
  }
}
.specDetail_block:nth-of-type(2) img{
  width: 71.5%;
}
@media screen and (max-width: 480px) {
  .specDetail_block:nth-of-type(2) img{
    width: 68.5%;
  }
}
.specDetail_block:nth-of-type(3){
  border-right: 2px solid #c80f32;
  padding-top: 4.25%;
}
.specDetail_block:nth-of-type(3) img{
  width: 70%;
}
@media screen and (max-width: 480px) {
  .specDetail_block:nth-of-type(3) img{
    width: 63%;
  }
}
.specDetail_block:nth-of-type(4){
  padding-top: 5.55%;
}
.specDetail_block:nth-of-type(4) img{
  width: 90%;
}
@media screen and (max-width: 480px) {
  .specDetail_block:nth-of-type(4) img{
    width: 84.5%;
  }
}
.specDetail_text {
  font-size: 1.4rem;
  color: #444;
  margin-top: 6px;
  line-height: 1.6;
  text-align: center;
}
@media screen and (max-width: 480px) {
  .specDetail_text {
    font-size: 2.4vw;
  }
}
.specDetail_note{
  font-size: 1.1rem;
  text-align: center;
}
@media screen and (max-width: 480px) {
  .specDetail_note{
    font-size: 2vw;
  }
}
.specPwr{
  margin: 0 9.5%;
}

/*単品ページ*/
.contentsSingle{
  background-color: #f6c8dd;
  padding-bottom: 5vw;
}
.other_products{
  margin-top: 40px;
}
.other_products_title{
  background-color: #c80f31;
  color: #fff;
  font-size: 2rem;
  font-weight: bold;
  text-align: left;
  padding: 10px 15px;
}
@media screen and (max-width: 480px) {
  .other_products_title{
    font-size: 5.33333vw;
  }
}
.other_products_text {
  font-size: 2rem;
  font-weight: bold;
  color:#c80f31;
  text-align: center;
  padding:10px;
}
@media screen and (max-width: 480px) {
  .other_products_text {
    font-size: 4vw;
  }
}

.lp_bnr_4plus2{
  margin: 20px auto;
}
@media screen and (max-width: 480px) {
  .lp_bnr_4plus2{
    display: none;
  }
}

.anime {
  opacity: 0; 
  transform: translate(50px, -50px) scale(1);
}

.anime.active {
  animation: enterAndBounce 0.8s ease-out forwards;
  transform-origin: bottom left;
}

@keyframes enterAndBounce {
  0%   {
    opacity: 0;
    transform: translate(50px, -50px) scale(1);
  }
  20%  {
    opacity: 1;
    transform: translate(0, 0) scale(0.88, 0.92);
  }
  35%  {
    opacity: 1;
    transform: translate(0, 0) scale(1.15, 1.1);
  }
  50%  {
    opacity: 1;
    transform: translate(0, 0) scale(0.96, 0.98);
  }
  65%  {
    opacity: 1;
    transform: translate(0, 0) scale(1.07, 1.04);
  }
  75%  {
    opacity: 1;
    transform: translate(0, 0) scale(0.98, 0.99);
  }
  85%  {
    opacity: 1;
    transform: translate(0, 0) scale(1.03, 1.015);
  }
  100% {
    opacity: 1;
    transform: translate(0, 0) scale(1);
  }
}

/* シンプルフェードアップ */
.fadeUp {
  opacity: 0;
  transform: translateY(20px); /* 少し下に配置 */
  transition: opacity 0.4s ease-out, transform 0.4s ease-out;
}
.fadeUp.active {
  opacity: 1;
  transform: translateY(0);
}
/* 遅延時間を transition-delay で指定する */
.fadeUp.delay1 { transition-delay: 0s; }
.fadeUp.delay2 { transition-delay: 0.1s; }
.fadeUp.delay3 { transition-delay: 0.2s; }
.fadeUp.delay4 { transition-delay: 0.3s; }
.fadeUp.delay5 { transition-delay: 0.4s; }
.fadeUp.delay6 { transition-delay: 0.5s; }
.fadeUp.delay7 { transition-delay: 0.6s; }
.fadeUp.delay8 { transition-delay: 0.7s; }
.fadeUp.delay9 { transition-delay: 0.8s; }

/* シンプルフェードイン */
.fadeIn {
  opacity: 0;
  transition: opacity 0.4s ease-out;
}
.fadeIn.active {
  opacity: 1;
}
/* 遅延時間を transition-delay で指定する */
.fadeIn.delay1 { transition-delay: 0.5s; }
.fadeIn.delay2 { transition-delay: 0.2s; }

.expansion{
  opacity: 0;
  transform: scale(0.1);
  transition: opacity 0.4s ease-out, transform 0.4s ease-out;
}
.expansion.active {
  animation: scaleBounce 0.6s ease-out forwards;
  opacity: 1;
  transform: scale(1);
  transition-delay: 0.3s;
}
@keyframes scaleBounce {
  0% {
    transform: scale(0.1);
    opacity: 0;
  }
  50% {
    transform: scale(1.1);
    opacity: 1;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

/* カテゴリページ*/
.fa1dCate .lineup_SubTitle {
  font-size: 1.4rem;
}
@media screen and (max-width: 480px) {
  .fa1dCate .lineup_SubTitle {
    font-size: 2.66vw;
  }
}

.fa1dCate .color_name {
  font-size: 1.6rem;
}
@media screen and (max-width: 480px) {
  .fa1dCate .color_name{
    font-size: 2.2vw;
  }
}

.fa1dCate .color_text {
  font-size: 3.5rem;
  line-height: 1.6;
}
@media screen and (max-width: 480px) {
  .fa1dCate .color_text{
    font-size: 3.73vw;
    line-height: 1.4;
  }
}

.fa1dCate .spec_text {
  font-size: 3rem;
  line-height: 1.4;
}
@media screen and (max-width: 480px) {
  .fa1dCate .spec_text{
    font-size: 3.73vw;
    line-height: 1.6;
  }
}

.fa1dCate .specDetail_block:nth-of-type(1) img,
.fa1dCate .specDetail_block:nth-of-type(2) img,
.fa1dCate .specDetail_block:nth-of-type(3) img,
.fa1dCate .specDetail_block:nth-of-type(4) img {
  width: auto;
}
@media screen and (max-width: 480px) {
  .fa1dCate .specDetail_block:nth-of-type(1) img{
    width: 54%;
  }
  .fa1dCate .specDetail_block:nth-of-type(2) img{
    width: 68.5%;
  }
  .fa1dCate .specDetail_block:nth-of-type(3) img{
    width: 63%;
  }
  .fa1dCate .specDetail_block:nth-of-type(4) img{
    width: 84.5%;
  }
}

.fa1dCate .specDetail_text {
  font-size: 2rem;
  margin: 13px 0;
}
@media screen and (max-width: 480px) {
  .fa1dCate .specDetail_text {
    font-size: 2.4vw;
    margin: 13px 0 0;
  }
}

.fa1dCate .specDetail_note{
  font-size: 1.5rem;
}
@media screen and (max-width: 480px) {
  .fa1dCate .specDetail_note{
    font-size: 2vw;
  }
}

.fa1dCate .campaign_imgText {
  position: absolute;
  left: 0;
  bottom: 36.5%;
}

.fa1dCate .campaign_btn01 {
  position: absolute;
  left: 0;
  bottom: 22.2%;
}

.fa1dCate .campaign_btn02 {
  position: absolute;
  left: 0;
  bottom: 8%;
}