@charset "utf-8";

/* -------------------------- Font --------------------------

font-family: "Zen Kaku Gothic New", serif;
font-weight: 300, 400, 500, 700, 900;

font-family: "Lato", serif;
font-weight: 100, 300, 400, 700, 900;

font-family: "Allison", cursive;
font-weight: 400;

*/

/* -------------------------- overwrite -------------------------- */

@media (max-width : 767px) {
  body{
    min-width:auto;
    overflow-x: hidden;
  }
}

/* -------------------------- Common -------------------------- */

.hyd_wrap{
  font-family: "Zen Kaku Gothic New", serif;
  font-weight:400;
  letter-spacing: 0;
  color:#19140f;
  overflow:hidden;
}
.hyd_wrap img{
  vertical-align: middle;
}
.sp_block{
  display:none;
}

@media (max-width : 767px) {
  .pc_block{
    display:none;
  }
  .sp_block{
    display:block;
  }
}

/* -------------------------- FV -------------------------- */

.hyd_fv{
  position:relative;
  z-index:2;
  display:flex;
  height:776px;
}
.hyd_fv_logo{
  position:absolute;
  z-index:5;
  top:27px;
  left:calc(50% - 115px);
  width:231px;
}
.hyd_fv_item{
  position:relative;
  width:25%;
  overflow:hidden;
}
.hyd_fv_item.vt{
  background: url("fv_v_bg.png") no-repeat center center / cover transparent;
}
.hyd_fv_item.ex{
  background: url("fv_ex_bg.png") no-repeat center center / cover transparent;
}
.hyd_fv_item.az{
  background: url("fv_az_bg.png") no-repeat center center / cover transparent;
}
.hyd_fv_item.pd{
  background: url("fv_pd_bg.png") no-repeat center center / cover transparent;
}
.hyd_fv_bubble{
  position:absolute;
}
.hyd_fv_bubble.vt_01{
  top:-50px;
  left:-50px;
  width:200px;
}
.hyd_fv_bubble.vt_02{
  right:-20px;
  bottom:132px;
  width:97px;
}
.hyd_fv_bubble.ex_01{
  top:76px;
  left:25px;
  width:87px;
}
.hyd_fv_bubble.ex_02{
  bottom:245px;
  right:0;
  width:124px;
}
.hyd_fv_bubble.az_01{
  top:53px;
  right:12px;
  width:85px;
}
.hyd_fv_bubble.az_02{
  bottom:240px;
  left:10px;
  width:97px;
}
.hyd_fv_bubble.pd_01{
  top:167px;
  left:34px;
  width:72px;
}
.hyd_fv_bubble.pd_02{
  bottom:55px;
  right:2px;
  width:97px;
}
.hyd_fv_text{
  position:absolute;
  z-index:2;
  left:calc(50% - 122px);
  bottom:25px;
  width:245px;
}
.hyd_fv_note{
  position:absolute;
  bottom:10px;
  left:45px;
  font-weight:500;
  font-size:10px;
  letter-spacing: 0.025em;
}

@media (max-width : 767px) {
  .hyd_fv{
    display:block;
    height:auto;
  }
  .hyd_fv_logo{
    top:10px;
    left:calc(50% - 61px);
    width:132px;
  }
  .hyd_fv_sp_head{
    height:75px;
    background: url("fv_head_sp.png") no-repeat center center / cover transparent;
  }
  .hyd_fv_item{
    position:relative;
    width:auto;
    height:160px;
    overflow:hidden;
  }
  .hyd_fv_item.vt{
    background: url("fv_v_bg_sp.png") no-repeat center center / cover transparent;
  }
  .hyd_fv_item.ex{
    background: url("fv_ex_bg_sp.png") no-repeat center center / cover transparent;
  }
  .hyd_fv_item.az{
    background: url("fv_az_bg_sp.png") no-repeat center center / cover transparent;
  }
  .hyd_fv_item.pd{
    background: url("fv_pd_bg_sp.png") no-repeat center center / cover transparent;
    overflow:visible;
  }
  .hyd_fv_bubble.vt_01{
    top:-40px;
    left:125px;
    width:75px;
  }
  .hyd_fv_bubble.vt_02{
    left:5px;
    right:auto;
    bottom:44px;
    width:42px;
  }
  .hyd_fv_bubble.ex_01{
    top:6px;
    left:12px;
    width:34px;
  }
  .hyd_fv_bubble.ex_02{
    bottom:-15px;
    left:147px;
    right:auto;
    width:65px;
  }
  .hyd_fv_bubble.az_01{
    top:auto;
    bottom:-5px;
    left:0;
    right:auto;
    width:46px;
  }
  .hyd_fv_bubble.az_02{
    bottom:0;
    left:auto;
    right:11px;
    width:58px;
  }
  .hyd_fv_bubble.pd_01{
    top:15px;
    left:-23px;
    width:46px;
  }
  .hyd_fv_bubble.pd_02{
    bottom:-10px;
    left:150px;
    right:auto;
    width:56px;
  }

  .hyd_fv_text{
    left:27px;
    bottom:12px;
    width:124px;
  }
  .hyd_fv_note_sp{
    position:absolute;
    top:5px;
    right:5px;
    font-weight:500;
    font-size:6px;
    line-height:2;
  }
}

/* -------------------------- Bubble Animation -------------------------- */

.fv_bubble_anim{
  animation: hydraBubbleAnim 2s ease-in-out infinite alternate;
}
.anim_01{
  animation-duration: 1.2s;
}
.anim_02{
  animation-duration: 1.4s;
}
.anim_03{
  animation-duration: 1.6s;
}
.anim_04{
  animation-duration: 1.8s;
}
.anim_05{
  animation-duration: 2.0s;
}
.anim_06{
  animation-duration: 2.2s;
}
.anim_07{
  animation-duration: 2.4s;
}
.anim_08{
  animation-duration: 2.6s;
}


@keyframes hydraBubbleAnim {
  0% {
    transform:translateY(0);
  }
  100% {
    transform:translateY(50px);
  }
}

/* -------------------------- Message -------------------------- */

.hyd_content_bg{
  position:relative;
  background-repeat: repeat-y;
  background-position: center top;
  background-size: 100% auto;
  background-image: url('bg_part_white.png');
}

@media (max-width : 767px) {
  .hyd_content_bg{
    background:#eef0ff;
  }  
}

/* -------------------------- Message -------------------------- */

.hyd_msg{
  position:relative;
  max-width:680px;
  padding:56px 0 10px;
  margin:0 auto;
}
.hyd_msg_desc{
  font-size:16px;
  line-height:2;
  letter-spacing: 0.05em;
  text-align: center;
}
.hyd_msg_bubble{
  position:absolute;
  top:66px;
  left:-200px;
  width:154px;
}

@media (max-width : 767px) {
  .hyd_msg{
    max-width:none;
    padding:80px 0 10px;
    margin:0;
  }
  .hyd_msg_desc{
    font-size:14px;
    line-height:1.857;
  }
  .hyd_msg_bubble{
    top:15px;
    left:-43px;
    width:129px;
  }
  .hyd_msg_bubble2{
    position:absolute;
    top:280px;
    right:-25px;
    width:60px;  
  }
}

/* -------------------------- Lineup index -------------------------- */

.hyd_lineup_index{
  max-width:800px;
  margin:0 auto 30px;
}
.hyd_lineup_index_title{
  border-bottom:1px solid #000;
  margin:0 0 15px;
}
.hyd_lineup_index_title > span{
  display:block;
  font-family: "Allison", cursive;
  font-size:70px;
  line-height:1;
  text-align:right;
  color:#FFF;
  margin-bottom:-4px;
}
.hyd_lineup_index_list{
  display:flex;
  flex-flow:row wrap;
  justify-content: space-between;
  gap:2px 0;
  margin:0 0 24px;
}
.hyd_lineup_index_item{
  display:block;
  width:378px;
}
.hyd_lineup_index_item.pd{
  width:402px;
}
.hyd_lineup_index_item img{
  display:block;
  width:100%;
}
.hyd_lineup_index_note{
  font-size:10px;
  line-height:1.8;
}

.hyd_store_limited_title {
  display: block;
  padding: 40px 0 30px;
  text-align: center;
}

@media (max-width : 767px) {
  .hyd_lineup_index{
    max-width:none;
    padding:0 25px;
    margin:0 0 30px;
  }
  .hyd_lineup_index_title{
    border-bottom:1px solid #000;
    margin:0 0 15px;
  }
  .hyd_lineup_index_title > span{
    font-size:60px;
    margin-bottom:-4px;
  }
  .hyd_lineup_index_list{
    gap:2px 0;
  }
  .hyd_lineup_index_item{
    width:100%;
  }
  .hyd_lineup_index_item.pd{
    width:100%;
  }
  .hyd_lineup_index_note{
    font-size:10px;
    line-height:1.5;
  }

  .hyd_store_limited_title {
    padding: 20px 0 15px;
  }
  .hyd_store_limited_title img {
    width: 43%;
    margin: 0 auto;
  }
}

/* -------------------------- Common Fadeup -------------------------- */

.fadeup{
  transition:opacity 1s, transform 1s;
}
.fadeup.standby{
  opacity:0;
  transform:translateY(50px);
}

/* -------------------------- Lineup Detail -------------------------- */

.hyd_detail_bg_parts{
  position:relative;
}
.hyd_detail_bg_bubble_01{
  position:absolute;
  top:276px;
  right:0;
  width:106px;
}
.hyd_detail_bg_bubble_02{
  position:absolute;
  top:859px;
  right:0;
  width:111px;
}
.hyd_detail_bg_bubble_03{
  position:absolute;
  top:1060px;
  left:0;
  width:231px;
}

.hyd_detail{
  max-width:1120px;
  margin:0 auto 55px;
}
.hyd_detail_list{
  display:flex;
  flex-flow:column nowrap;
  gap:30px 0;
}
.hyd_detail_item{}
.hyd_detail_item_pic_wrap{
  position:relative;
}
.hyd_detail_item_pic{
  display:block;
  width:100%;
}
.hyd_detail_item_pic > img{
  display:block;
  width:100%;
}
.hyd_detail_item_btns{
  position:absolute;
  bottom:56px;
  right:60px;
  display:flex;
  gap:0 15px;
}
.hyd_detail_item_btn_more{
  display:flex;
  justify-content: center;
  align-items: center;
  gap:0 21px;
  width:240px;
  height:51px;
  background-color: #000;
  border-radius:100vh;
}
.hyd_detail_item_btn_more:hover{
  opacity:0.75;
}
.hyd_detail_item_btn_more_icon{
  width:14px;
}
.hyd_detail_item_btn_more_text{
  font-weight:500;
  font-size:22px;
  line-height:1.5;
  letter-spacing: 0.05em;
  color:#FFF;
}
.hyd_detail_item_btn_cart{
  display:flex;
  justify-content: center;
  align-items: center;
  gap:0 10px;
  width:240px;
  height:51px;
  background-color: #FFF;
  border:2px solid #000;
  border-radius:100vh;
}
.hyd_detail_item_btn_cart:hover{
  opacity:0.75;
}
.hyd_detail_item_btn_cart_icon{
  width:27px;
}
.hyd_detail_item_btn_cart_text{
  font-weight:500;
  font-size:22px;
  line-height:1.5;
  letter-spacing: 0.05em;
  color:#000;
}
.hyd_detail_item_note{
  font-weight:400;
  font-size:13px;
  line-height:18px;
  text-align:right;
  padding:10px 15px 0;
}

.hyd_detail_item.az .hyd_detail_item_btn_more{
  background-color: #00a0b8;
}
.hyd_detail_item.ex .hyd_detail_item_btn_more{
  background-color: #552378;
}
.hyd_detail_item.fl .hyd_detail_item_btn_more{
  background-color: #000;
}
.hyd_detail_item.vt .hyd_detail_item_btn_more{
  background-color: #ff2323;
}

.hyd_detail_item.az .hyd_detail_item_btn_cart{
  border-color: #00a0b8;
}
.hyd_detail_item.ex .hyd_detail_item_btn_cart{
  border-color: #552378;
}
.hyd_detail_item.vt .hyd_detail_item_btn_cart{
  border-color: #ff2323;
}
.hyd_detail_item.az .hyd_detail_item_btn_cart_icon{
  filter: brightness(0) saturate(100%) invert(51%) sepia(34%) saturate(3447%) hue-rotate(152deg) brightness(87%) contrast(102%);
}
.hyd_detail_item.ex .hyd_detail_item_btn_cart_icon{
  filter: brightness(0) saturate(100%) invert(16%) sepia(16%) saturate(7462%) hue-rotate(257deg) brightness(101%) contrast(97%);
}
.hyd_detail_item.vt .hyd_detail_item_btn_cart_icon{
  filter: brightness(0) saturate(100%) invert(29%) sepia(81%) saturate(5989%) hue-rotate(4deg) brightness(99%) contrast(113%);
}
.hyd_detail_item.az .hyd_detail_item_btn_cart_text{
  color: #00a0b8;
}
.hyd_detail_item.ex .hyd_detail_item_btn_cart_text{
  color: #552378;
}
.hyd_detail_item.vt .hyd_detail_item_btn_cart_text{
  color: #ff2323;
}


@media (max-width : 767px) {
  .hyd_detail_bg_parts{
    display:none;
  }
  
  .hyd_detail{
    max-width:none;
    margin:0;
  }

  .hyd_detail_list{
    display:block;
  }
  .hyd_detail_item{
    position:relative;
  }
  .hyd_detail_item_pic_wrap{
    position:relative;
  }
  .hyd_detail_item_btns{
    position:absolute;
    bottom:20.8vw;
    right:0;
    display:flex;
    flex-flow:column nowrap;
    align-items: center;
    gap:10px 0;
    width:100%;
  }
  .hyd_detail_item_btn_more{
    width:284px;
    height:39px;
  }
  .hyd_detail_item_btn_more_icon{
    width:11px;
  }
  .hyd_detail_item_btn_more_text{
    font-size:16px;
  }
  .hyd_detail_item_btn_cart{
    width:284px;
    height:39px;
  }
  .hyd_detail_item_btn_cart_icon{
    width:20px;
  }
  .hyd_detail_item_btn_cart_text{
    font-size:16px;
  }
  .hyd_detail_item_note{
    position:absolute;
    bottom:45px;
    left:calc(50% - 142px);
    width:284px;
    font-size:8px;
    line-height:11px;
    text-align:left;
    padding:0;
  }

  .hyd_detail_item.ex .hyd_detail_item_btns{
    bottom:26vw;
  }
  .hyd_detail_item.fl .hyd_detail_item_btns{
    bottom:23vw;
  }
  .hyd_detail_item.vt .hyd_detail_item_btns{
    bottom:36vw;
  }

}

/* -------------------------- Approach -------------------------- */

.hyd_apr{
}
.hyd_apr_pic{
  display:block;
  width:100%;
}
.hyd_apr_pic > img{
  display:block;
  width:100%;
}

@media (max-width : 767px) {
  .hyd_apr{
  }
}

/* -------------------------- Other -------------------------- */

.hyd_other{
  background-color: #eef0ff;
  padding:40px 0 100px;
}
.hyd_other_title{
  text-align: center;
  margin:0 0 30px;
}
.hyd_other_title_main{
  display:block;
  font-family: "Allison", cursive;
  font-size:80px;
  line-height:0.9;
}
.hyd_other_title_desc{
  font-size:22px;
}
.hyd_other_list{
  display:flex;
  justify-content: center;
  gap:0 20px;
}
.hyd_other_item{
  width:320px;
  background-image:url('other_v_bg.jpg');
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  padding:20px;
}
.hyd_other_item_in{
  position:relative;
  border:1px solid #ff9e00;
  background-color: rgba(255,255,255,0.9);
}
.hyd_other_item_badge{
  position:absolute;
  top:28px;
  left:-10px;
  width:95px;
}
.hyd_other_item_pdt{
  display:block;
  height:178px;
  padding:13px 0 0 103px;
}
.hyd_other_item_pdt > img{
  width:128px;
}
.hyd_other_item_title{
  font-weight:500;
  font-size:18px;
  text-align: center;
  color:#FFF;
  background-color: #ff9e00;
  padding:11px 0;
  margin:0 0 15px;
}
.hyd_other_item_desc{
  font-size:20px;
  line-height:1.5;
  text-align: center;
  color:#ff9e00;
  margin:0 0 10px;
}
.hyd_other_item_price{
  font-size:22px;
  text-align: center;
  margin:0 0 24px;
}
.hyd_other_item_price > small{
  font-size:16px;
}
.hyd_other_item_more,
.hyd_other_item_cart{
  display:flex;
  justify-content: center;
  align-items: center;
  width:240px;
  height:60px;
  font-weight:700;
  font-size:16px;
  text-decoration: none;
  margin:0 auto;
}
.hyd_other_item_more{
  border:1px solid #ff9e00;
  color:#ff9e00;
  margin-bottom:10px;
}
.hyd_other_item_cart{
  background-color: #ff9e00;
  color:#FFF;
  margin-bottom:20px;
}

.hyd_other_item.hydra_f{
  background-image:url('other_f_bg.jpg');
}
.hyd_other_item.hydra_f .hyd_other_item_in{
  border:1px solid #555555;
}
.hyd_other_item.hydra_f .hyd_other_item_pdt{
  padding:22px 0 0 111px;
}
.hyd_other_item.hydra_f .hyd_other_item_pdt > img{
  width:98px;
}
.hyd_other_item.hydra_f .hyd_other_item_title{
  background-color: #555555;
}
.hyd_other_item.hydra_f .hyd_other_item_desc{
  color:#555555;
}
.hyd_other_item.hydra_f .hyd_other_item_more{
  border:1px solid #555555;
  color:#555555;
}
.hyd_other_item.hydra_f .hyd_other_item_cart{
  background-color: #555555;
}

@media (max-width : 767px) {
  .hyd_other{
    background: linear-gradient(to bottom, #f4f2f4 0%, #eef0ff 100px);
    padding:30px 0 50px;
  }
  .hyd_other_title{
    text-align: center;
    transform:translateY(0);
    margin:0 0 24px;
  }
  .hyd_other_title_main{
    font-size:70px;
  }
  .hyd_other_title_desc{
    font-size:18px;
  }
  .hyd_other_list{
    display:block;
  }
  .hyd_other_item{
    width:315px !important;
    padding:15px;
    margin:0 7.5px;
  }
  .hyd_other_item_title{
    padding:8px 0;
    margin:0 0 10px;
  }
  .hyd_other_item_desc{
    font-size:18px;
    line-height:1.44;
    margin:0 0 6px;
  }
  .hyd_other_item_price{
    font-size:19px;
    margin:0 0 18px;
  }
  .hyd_other_item_price > small{
    font-size:14px;
  }
  .hyd_other_item_more,
  .hyd_other_item_cart{
    width:auto;
    height:50px;
    font-weight:700;
    font-size:14px;
    margin:0 15px;
  }
  .hyd_other_item_more{
    margin-bottom:15px;
  }
  .hyd_other_item_cart{
    margin-bottom:25px;
  }

  .hyd_other_list .slick-dots {
    position: relative;
    bottom: auto;
    display: flex;
    justify-content: center;
    gap:0 5px;
    width: 100%;
    list-style: none;
    text-align: center;
    padding: 0;
    margin:25px 0 0;
  }
  .hyd_other_list .slick-dots li {
    position: relative;
    display: inline-block;
    width: 8px;
    height: 8px;
    margin: 0 0;
    padding: 0;
    cursor: pointer;
  }
  .hyd_other_list .slick-dots li button {
    font-size: 0;
    line-height: 0;
    display: block;
    width: 100%;
    height: 100%;
    padding: 0;
    cursor: pointer;
    color: transparent;
    border: 2px solid #000;
    border-radius:50%;
    outline: none;
    background: transparent;
  }
  .hyd_other_list .slick-dots li.slick-active button {
    background: #000;
  }
}

@media (max-width : 767px) {
  .hyd_store_limited_index .hyd_lineup_index_item {
    margin-bottom: 10px;
  }
}

/* -------------------------- チャート -------------------------- */
.hyd_ct_wrap {
  position: relative;
  max-width: 840px;
  padding: 40px 20px;
  margin: 0 auto;
  z-index: 1;
}
.hyd_ct_title {
  width: 60%;
  padding-right: 7%;
  margin: 0 auto -1%;
}
.hyd_ct_body {
  position: relative;
  max-width: 680px;
  margin: 0 auto 40px;
}
.hyd_ct_pro {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.hyd_chart_note {
  width:537px;
  font-weight:400;
  font-size:13px;
  line-height:18px;
  margin:0 auto;
}
.hyd_detail_bg_bubble_04 {
  position: absolute;
  top: -700px;
  right: -60px;
}
.hyd_detail_bg_bubble_05 {
  position: absolute;
  top: -160px;
  left: -20px;
}
@media (max-width : 767px) {
  .hyd_ct_title {
    width: 79%;
    padding-right: 9.5%;
  }
  .hyd_ct_wrap {
    padding: 30px 15px;
  }
  .hyd_ct_body {
    margin-bottom: 24px;
  }
  .hyd_chart_note {
    width:284px;
    font-size:8px;
  }
}