html{
	scroll-behavior: smooth;
}

/* 全網頁只要滑鼠滑到連結就變手指 */
a:hover {
  cursor: pointer !important;
}

/* 這行是最上面的板頭 */
header>.inner {
  background-color: rgba(255, 255, 255, 0);
  -webkit-box-shadow: none;
  box-shadow: none;
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
}

/* hoho的logo */
header>.inner a.logo {
  background: url(../images/icon_hoho-02.svg) no-repeat center;
  background-size: cover;
  width: 180px;
  height: 140px;
  left: 0px;
}

/* hoho的logo滑鼠移過去後 */
header>.inner a.logo:hover {
  filter: brightness(1.1);
  transition: 0.2s;
}

/* 右上的icon */
header ul.wrap-link li i[class*="icon-"],
header ul.wrap-link li a[class*="icon-"] {
  background-color: #444;
  color: #ffffff;
  transition: 0.2s;
}

/* 右上的icon滑鼠移過去後 */
header ul.wrap-link li i[class*="icon-"]:hover,
header ul.wrap-link li a[class*="icon-"]:hover {
  background-color: rgb(255, 188, 2);
  color: #ffffff ;
  transition: 0.2s;
}

/* icon旁邊的文字 */
header ul.wrap-link li span {
  color: #444;
  margin-right: 10px;
}

/* 從這邊開始是內容大框架 */
.container {
  background-color: #ffffff;
}

.container img {
  vertical-align: top;
  max-width: 100%;
  height: auto;
}

.innerbox {
  position: relative;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 0 auto;
}

.showPC{
	display: block;
}
.showMB{
	display: none;
}

/* 客製內容從下面開始 */
.BGT{
	background: #ffffe7;
}

.kv-bg{
  width: 100%;
  background: url(../images/kv-bg.jpg);
  background-position: bottom center;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.kv{
  padding: 0;
  width: 1200px;
  height:auto;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.kv-tt{
  width: 100%;
  text-align: center;
  animation-name: kv-tt;
  animation-duration: 2s;
  animation-iteration-count: infinite;
  animation-timing-function: ease-in-out;
  margin-top: 60px;
  margin-left: auto;
  margin-right: auto;
}

@keyframes kv-tt{
  0%{
    transform:translateY(20px);
  }
  50%{
    transform:translateY(0px);
  }
  100%{
    transform:translateY(20px);
  }
}

.flexCon{
  display: flex;
}

.kv-act{
  margin-bottom: 24px;
}

.kv-act img{
  transition: 0.2s;
}

.kv-act img:hover{
  transform : scale(0.965);
}

.kv-actRBottom{
  position: relative;
}

.kv-actRBottom1, .kv-actRBottom2{
  position: absolute;
  width: 17%;
  height: 20%;
}

.kv-actRBottom1{
  left: 24%;
  top: 69%;
}

.kv-actRBottom2{
  left: 57.5%;
  top: 69%;
}

.dayday200{
  max-width: 100%;
  background-image: url(../images/ct1-bg.jpg);
  background-position: top center;
  background-repeat: no-repeat;
}

.ddTitle{
  padding-top: 100px;
}

.ddCon{
  width: 100%;
  background-image: url(../images/date_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
}

.ddConTop{
  padding: 4% 0;
}

.ddConBottom{
  padding: 3% 0;
}

.birth{
  max-width: 100%;
  background-image: url(../images/ct2-bg.jpg);
  background-position: top center;
  background-repeat: no-repeat;
}

.birthPro{
  display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 16px;
    margin-top: 24px;
    margin-bottom: 56px;
}

.birthPro a{
  width: 30%;
}

.birthTitle{
  padding-top: 64px;
}

.coffee{
    position: relative;
    max-width: 100%;
    background-image: url(../images/ct3-bg.jpg);
    background-position: top center;
    background-repeat: no-repeat;
    padding: 48px 0 0 0;
}

.coffee a {
    position: absolute;
    width: 25%;
}

.coffeeBtn1{
    left: 6%;
    top: 78%;
}

.coffeeBtn2{
    left: 35%;
    top: 78%;
}

.AFTEE3{
    max-width: 100%;
    background-image: url(../images/ct4-bg.jpg);
    background-position: top center;
    background-repeat: no-repeat;
}

.product_Model{
      max-width: 100%;
      background-image: url(../images/ct6-bg.jpg);
      background-position: top center;
      background-size: contain;
      margin-top: 0 !important;
    padding-top: 48px;
}

.lastPro{
    max-width: 100%;
    background-image: url(../images/ct6-bg.jpg);
    background-position: top center;
    background-size: contain;
    padding: 24px 0;
    margin-top: -16px;
}

.lastPro > div{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.lastPro > div a{
  width: 45%;
}



/*         以上修改          */


.kv-cp{
  width: 1200px;
  height: auto;
  display: flex;
  flex-wrap: wrap;
  margin-top: 30px;
  margin-bottom: 50px;
}

.kv-cp.showPC {
  display: flex;
  width: 100%; 
  align-items: flex-start; 
  justify-content: space-between; 
  flex-wrap: wrap;
  margin-top: 30px; 
  margin-bottom: 50px;
}

#kv-cp01{
  width: 33.33%;
  transition: 0.2s;
  text-align: left;
}
#kv-cp01>a>img{
  max-width: 100%;
}
#kv-cp01:hover{transform : scale(0.965);}

#kv-cp02{
  width: 33.33%;
  transition: 0.2s;
  text-align: center;
}
#kv-cp02>a>img{
  max-width: 100%;
}

#kv-cp02:hover{transform : scale(0.965);}

#kv-cp03{
  width: 33.33%;
  transition: 0.2s;
  text-align: right;
}
#kv-cp03>a>img{
  max-width: 100%;
}
#kv-cp03:hover{transform : scale(0.965);}

#kv-cp04 {
  width: 100%;
  transition: 0.2s;
  margin-top: 20px;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start; 
}

#kv-cp04 > a > img {
  max-width: 100%;
}

#kv-cp04:hover {
  transform: scale(0.965);
}

.ct-bg{
	  width: 100%;
    background-size: cover;
  	background: url(../images/bg-PC.jpg);
    background-repeat: no-repeat;
    background-position: top center;
    
  	/* background-position: bottom center;
  	background-repeat: no-repeat;
  	background-size: cover; */
}

.ct{
  width: 1200px;
  display: flex;
  margin: auto;
  flex-wrap: wrap;
}

#ct01{
	margin-top: 100px;
  margin: bottom 100%;
}

.ct01-ct{
	max-width: 1200px;
  background-size: cover;
	background-image: url(../images/date_bg.png);
	background-repeat: no-repeat;
}

.ct01-cp{
	width: 100%;
  padding-top: 2%;
  padding-bottom: 2%;
	margin-top: 20px;
}
.ct01-cp img {
	width: 100%;
	margin-top: 20px;
	display: flex;
  justify-content: center;
}

.ct01-cpBottom{
	width: 100%;
  padding-bottom: 4%;
  padding-top: 4%;
}

.ct01-cp-bt{
  width: 46%;
  filter:drop-shadow(0px 0px 5px #3f0d0035);
  transition: 0.2s;
  
}
.ct01-cp-bt:hover{transform : scale(0.965);}

#ct02{
	margin-top: 300px;
  display: flex;
  justify-content: center;
  justify-content: space-around;
  margin-top: 2%;
  gap: 50px;
}


#ct03{
  margin-top: 170px;
  background-size: cover; 
  background-repeat: no-repeat;
  background-position: center center; 
}


#ct03_bnt{
  display: flex;
  margin-top: -100px;
  margin-left: 40px;
  gap: 50px;
  
}

#ct04{
	margin-top: 100px;
  background-size: cover; 
  background-repeat: no-repeat;
  background-position: top center;
}

#ct05{
	margin-top: 30px;
  margin-bottom: 100;
  display: flex;
}
/* 電腦版 ct05 (橫向排列) */
#ct05, #ct05-2 {
    display: flex;
    justify-content: space-between; 
    flex-wrap: wrap;
    margin-bottom: 20px; /* 區塊間距 */
}

/* 電腦版圖片連結 (每行兩張) */
#ct05 a.showPC, #ct05-2 a.showPC {
    width: 49%; /* 佔約一半 */
    text-align: center;
}



.finalPro{
	margin-top: 40px;
	padding: 0% 4%;
  margin-bottom: 100px;
	filter: drop-shadow(rgba(#3f0d0070) 0px 0px 10px);
}
.finalPro a:hover{
	-webkit-filter: brightness(105%); /* Safari */
    filter: brightness(105%);
}

@media (max-width: 600px) {
	.modal-content {
		padding: 24px 16px;
        max-height: 500px;
        overflow: scroll;
	}

	.modal-content h2 {
		font-size: 22px;
        padding: 16px 16px 0;
		margin-bottom: 0px;
	}

	.modal-content p {
		font-size: 16px;
        line-height: normal;
        padding: 8px 8px 0;
	}
}

/*以上彈窗*/





/* 活動說明 */
.rule{
	position: relative;
	padding: 40px 16px;
	background-color: #fff4b5;
}

.rule h5{
	font-size: 32px;
	font-weight: 700;
	text-align: center;
	margin-bottom: 24px;
}

.rule p{
	font-size: 18px;
	font-weight: 400;
	line-height: 32px;
}

.rule p span{
	display: block;
	margin-left: 20px;
}

.rule a{
	color: #3895b4;
	text-decoration: underline;
}

/*側邊欄*/
.navButton{
	display: none;
	justify-content: space-between;
	background-color: #fff;
	padding: 0px 16px;
	height: 40px;
	line-height: 40px;
	position: fixed;
	bottom: 0;
	width: 100%;
	box-sizing: border-box;
	transition: top .4s ease-in-out;
	box-shadow: 0 0 8px rgba(0,0,0,.2);
	z-index: 999;
}

.navButton a{
	color: #000;
	text-decoration: none;
	font-size: 16px;
}

.navButton_pc{
	display: block;
	position: fixed;
	right: 0px;
	top: 150px;
	width: 156px;
	height: 260px;
	padding: 100px 16px 0px 52px;
	background-image: url("../images/navbg.png");
	background-position: top center;
	background-repeat: no-repeat;
	transition: right .4s ease-in-out;
	filter:drop-shadow(4px 8px 8px rgb(201, 20, 0));
	z-index: 999;
}

.navButton_pc a{
	display: block;
    text-align: center;
    width: 100%;
    font-size: 16px;
	line-height: 28px;
	font-weight: 700;
    color: #181818;
    text-decoration: none;
}

.navButton_pc a:hover{
	color: #cc3c39;
	font-weight: 900;
}

.navHide .navButton_pc {
	right: -156px;
} 

    

/*swiper*/
.swiper {
    width: 100%;
    max-width: 1200px;
    height: auto;
    margin: 0px auto;
}

#swiper-one {
    margin: 0 auto !important;
}

.swiper-slide {
    width: 325px;
    height: auto !important;
    text-align: center;
    font-size: 18px;
    background: transparent;
    padding: 0px 0 0 0;
    /* Center slide text vertically */
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
}






/* 回到上方 */
a#backTop {
  background-color: #444;
	bottom: 52px;
}



@media (max-width: 1280px) {
.kv{
    width: 100%;
    height: auto;
  }

.kv-tt{
    width: 80%;
  }
.kv-cp{
  width: 90%;
}

.ct{
  width: 100%;
  display: flex;
  justify-content: center;
}

#ct01{
  width: 96%;
}

.ct01-ct{
  width: 100%;
  background-size: contain;
}

#ct02{
  width: 90%;
}
#ct03{
  width: 90%;
}
#ct04{
  width: 90%;
}
#ct05{
  width: 90%;
}

  .ddCon {
    background-size: contain;
  }

  

  
}
@media (max-width: 1030px) {

  
}

@media (max-width: 845px) {

  
}

@media (max-width: 780px) {
	.showPC{
		display: none;
	}
	.showMB{
		display: block;
	}

  /* hoho的logo */
  header>.inner a.logo {
    background: url(../images/icon_hoho-02.svg) no-repeat center;
    background-size: cover;
    width: 130px;
    height: 100px;
    left: -10px;
  }

  .kv-bg{
    width: 100%;
    background-image: url(../images/kv-bg-mb.jpg); 
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: cover; 
    min-height: 800px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }

  .kv-tt{
    margin: 56px auto 0 auto;
    width: 98%;
  }

  .kv-cp-mb{
    width: 80%;
    display: block;
    margin: 30px auto;
  }

  .dayday200 {
      background-position: top right;
      background-size: 250%;
    }
    .dayday200 > .innerbox{
      padding: 0 2%;
    }
    .ddCon.showMB {
      background-image: none;
    }
    .ddTitle {
      padding: 72px 4% 0;
    }
    .birthPro {
      padding: 0 16px;
    }
    .birthPro a{
      width: 45%;
    }
    .birthTitle {
        padding-top: 40px;
    }
    .coffee{
        padding: 24px 0 16px 0;
        background-size: 210%;
    }
    .coffee a {
        width: 31%;
    }
    .coffeeBtn1 {
        left: 6%;
        top: 76%;
    }
    .coffeeBtn2 {
        left: 40%;
        top: 76%;
    }
    .AFTEE3 {
      padding: 32px;
        background-position: top left;
        background-size: 250%;
    }
    .product_Model{
        padding-top: 0px;
    }
    .lastPro{
        margin-top: 0px;
    }
    .lastPro > div{
    }
    .lastPro > div a{
      width: 48%;
    }



  


  .ct-bg{
  width: 100%;
  background-image: url(../images/bg-PC.jpg); 
  background-position: bottom center;
  background-repeat: no-repeat;
  background-size: cover; 
  min-height: 800px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
  #ct01{
  width: 80%;
  margin-top: 75px;
  }
  .ct01-cp-bt{
  width: 90%;
  }

  #ct02{
  width: 80%;
  margin-top: 75px;
}

  #ct03{
  width: 80%;
  margin-top: 75px;
}

  #ct04{
  width: 80%;
  margin-top: 75px;
}

  #ct05{
  width: 80%;
  margin-top: 75px;
}

.showPC {
    display: none !important; 
}
.showMB {
    display: block !important;
}
#ct03_bnt{
    width: 80%;
    display: flex; 
    flex-direction: column;
    margin: 0 auto; 
    gap: 10px;
    align-items: center;
}

#ct03_bnt img {
    display: block; 
    max-width: 100%;
    height: auto;
}


  .rule p span {
    margin-left: 25px;
  }  
	

}


  @media (max-width: 650px) {

	.rule h5{
		font-size: 24px;
	}

	.rule p {
		font-size: 16px;
		line-height: 28px;
	}

  }

  @media only screen and (max-width: 490px) {
    #ct01{
  margin-top: 50px;
}
#ct02{
  margin-top: 50px;
}
#ct03{
  margin-top: 50px;
}
#ct04{
  margin-top: 50px;
}
#ct05{
  margin-top: 50px;
}

#ct05, #ct05-2 {
  display: block; /* 讓容器恢復為標準區塊 */
}

/* 手機板垂直排列 */
#ct05 a.showMB, #ct05-2 a.showMB {
  display: block;
  width: 100%;
  margin-bottom: 15px; /* 圖片間距 */
  position: static; 
  height: auto;
  padding: 0;
}

#ct05 a.showMB img, #ct05-2 a.showMB img {
  position: static;
  width: 100%;
  height: auto;
  object-fit: contain; 
  object-position: center center; 
  margin: 0 auto; 
}

  }

  @media only screen and (max-width: 420px) {

  }

  

  /*以下自訂*/
  .mySwiper{
    overflow: hidden;
  }
  .swiper-wrapper{
    display: inline-flex;
  }
  .mySwiper .swiper-slide{
    width: 389px;
    height: 453px;
  }
  .plus1Swiper{
	overflow: hidden;
}

