@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100;300;400;700;900&display=swap');
@import url(/fonts/style.css);

/* $Reset
--------------------------------------------------------------------------------------*/
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,font,img,ins,kbd,q,s,samp,small,strike,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}:focus{outline:0}ins{text-decoration:none}del{text-decoration:line-through}table{border-collapse:collapse;border-spacing:0;}

/* $body,html
--------------------------------------------------------------------------------------*/
html,
body {width: 100%; height:100%; font-family: Arial,"微軟正黑體","新細明體","蘋果儷黑體",  Verdana, Helvetica, sans-serif; -webkit-text-size-adjust:none; -webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box;}
img{width: 100%;}
/* $共用
--------------------------------------------------------------------------------------*/
/* pc */
body{background: url("../images/pc_bg.jpg") no-repeat center top; background-color: #cfbeb4;}
.cont1{width: 1200px; width: 100%; position: relative; margin: 80px auto 0 auto; height: 100%;}
.kv{width:100%; height:483px; background: url("../images/pc_KV.png") no-repeat center top;}

/* kv */
.logo{ position: absolute; left: 50%; width: 162px; top: 60px; margin: 0 0 0 -81px; }
.logo img{ width: 100%; }
.bubble{ 
  position: absolute; 
  width: 242px; 
  height: 94px;
  left: 50%; 
  top: 100px; 
  margin: 0 0 0 -121px; 
  background: url("../images/bubble_pc.png") no-repeat left top;
  -webkit-background-size:cover;
  -moz-background-size:cover;
  background-size:cover;
}

/* --------2個珍珠-------*/
.bubble_t2 {
    font-size: 15px;
    color: #3c3b3a;
    text-align: center;
    letter-spacing: 3px;
    line-height: 2.3em;
    position: absolute;
    top: 333px;
    left: 50%;
    width: 320px;
    margin: 0 0 0 -160px;
}

/* --------4個珍珠-------*/
/* .bubble_t2 {
    font-size: 15px;
    color: #3c3b3a;
    text-align: center;
    letter-spacing: 3px;
    line-height: 2.3em;
    position: absolute;
    top: 215px;
    left: 50%; transform: translateX(-50%);
}  */

/* ----------------------黑白珍珠介紹---------------------- */
.content{ width: 100%; max-width: 1200px; margin: 40px auto; display: flex; justify-content: center;}

/* --------2個珍珠-------*/
.black_ct,
.original_ct{position: relative; width: 40%; text-align: center; }
/* .black_ct{position: relative; width: 400px;  text-align: center; } */

/* --------4個珍珠-------*/
/* .black_ct,
.original_ct,
.purple_ct,
.purple2_ct{position: relative; width: 400; text-align: center; } */

/* -------大白玉珍珠------- */
/* .white_ct{position: relative; width: 50%; float: right;  text-align: center;}
.white_ct{position: relative; width: 400px;    text-align: center;} */




/* 黑白珍珠共用 */
.title_area{width: 100%; display: flex; justify-content:center; align-items: center;}
.title_area.white_title{flex-direction: row-reverse;}
.title{ font-size: 36px;letter-spacing: 4px;}
.title .small{ font-size: 22px; }
.limit{color:#985a37;  font-size: 12px; margin-left: 8px;} 
.title_img{width: 64px; margin:8px;}

/* 風味 */
.taste_area{
  display: flex;
  justify-content: center;
}

.taste{
/*   margin: 20px; */
  margin: 5px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 14px;
}
.taste span { text-align: left; }

/* --------2個珍珠-------*/
.circle{
    display: inline-block;
    width: 50px;
    height: 50px;
    border-radius: 50%; 
    background: #fff;
    color: #202020;
    text-align: center;
    vertical-align: middle;
    font-size: 16px;
    letter-spacing: 2px;
    line-height: 50px;
    margin-right: 8px;
  }

/* --------4個珍珠-------*/
/* .circle{
    display: inline-block;
    width: 35px;
    height: 35px;
    border-radius: 50%; 
    background: #fff;
    color: #202020;
    text-align: center;
    vertical-align: middle;
    font-size: 14px;
    letter-spacing: 2px;
    line-height: 35px;
    margin-right: 5px;
  } */

/* 特點 */
.depiction_area{ margin-bottom: 40px;}
/* --------2個珍珠-------*/
.depiction{ font-size: 14px; margin: 16px auto; text-align: left; width:50%;}
/* --------4個珍珠-------*/
/* .depiction{ font-size: 14px; margin: 16px auto; text-align: left; width:75%;} */
.check{ width: 20px;  display: inline-block;}


/* ----------------------價目表---------------------- */
.price_area{
  width: 100%;
}
.price_area table{
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
}
.price_area table tbody tr th{
  padding: 8px 0; 
  background-color: #663f2c;
  color: #fff;
  border-right: 1px solid #fff;
}
.price_area table tbody tr th:last-child{
  border-right: none;
}
.price_area table tbody tr:first-child ~ tr{
  border-bottom: 1px solid #000;
}

.price_area table tbody tr td{
  margin: 0 auto;
  padding: 16px 0;
}
/* 分類 */
.category{
  display: inline-block;
  color: #fff;
  font-weight: bold;
  border-radius: 50px;
  padding: 8px 16px;
  text-align: left;
}
.citypearl{
  background-color: #000;
}
.citytea{
  background-color: #05b085;
}
/* 品名 */
.name{
  font-size: 20px;
  font-weight: bold;
  width: 400px;
}
.name small {font-size: .8em;}

/* 容量 */
.cup{
  border-radius: 50px;
  width: 48px;
  padding: 4px;
  margin: 0 auto;
  text-align: center;
  color: #fff;
}

.hot{
  background-color: #de6666;
}
.cold{
  background-color: #64a6e3;
}

/* 價錢 */
.price_area table tbody tr td:nth-child(3) ~ td{
  text-align: center;
  align-content: center;
}

/* icon */
.icon{
  text-align: center;
  vertical-align: middle;
}
.new{
  padding: 4px;
  font-size: 12px;
  color: #FFF;
  background:#ff684a;
  border-radius: 20px; 
  text-align: center;
  margin: 0 auto;
}
.best{
  color: #ff8c24;
}

/* 黑珍珠 白珍珠標記 */
.bubble_category{
  text-align: center;
}
.black_bubble,.white_bubble,.black2_bubble,.purple_bubble{
  border-radius: 12px;
  width: 12px;
  height: 12px;
  margin: 0 auto;
}
.black_bubble{
  background-color:#663f2c;
}
.white_bubble{
  background-color: #fff;
}
.black2_bubble{
  background-color:#000000;
}
.purple_bubble{
  background-color:#9884b5;
}
.tips_area{
  width: 100%;
  max-width: 1000px;
  height: 100px;
  margin: 24px auto;
  display: flex;
  position: relative;
}
.tips_title{
  font-weight: bold;
}
.tips{
  display:flex;
  margin-right: 4px;
}
.tips .black_bubble,
.tips .white_bubble,
.tips .black2_bubble,
.tips .purple_bubble{
  margin: 4px;
}

.ingredient_btn{
  background-color:#663f2c;
  color: #fff;
  padding: 16px;
  border-radius: 8px;
  text-decoration: none;
  width: 200px;
  text-align: center;
  position: absolute;
  right: 0;
}

/* footer */
footer{ margin-top: 44px; color: #424242; font-size: 13px; line-height: 3em; text-align: center; background: #e4d6cd ;}

/* top鍵 */
#gotop {
  display: none;
  position: fixed;
  right: 20px;
  bottom: 20px;
  padding: 10px 15px;
  font-size: 20px;
  background: #777;
  color: white;
  cursor: pointer;
}


/* =========================
   Header / Nav
========================= */
:root{
  --nav-h: 60px;
  --divider: #9BC6BC;
  --text: #5F5F5F;
  --hover: #00A475;
  --accent: #00A475;
  --ease: cubic-bezier(.2,.8,.2,1);
}
.no-scroll{ overflow: hidden; }
.site-header{ position: fixed; top: 0; left: 0; right: 0; height: var(--nav-h); background: #fff; z-index: 1000; overflow: hidden; transition: height 360ms var(--ease); }
.site-header .nav{ width: 100%; height: var(--nav-h); display: flex; align-items: center; gap: 12px; padding: 0 20px; position: relative; }
.site-header .brand{ height: 20px; display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; position: relative; z-index: 2; }
.site-header .brand img{ max-width: 100%; height: auto; display: block; }
/* 相容 .menu / .top-menu */
.site-header .menu,
.site-header .top-menu{ min-width: 0; }
.site-header .menu a,
.site-header .top-menu a{ color: var(--text); text-decoration: none; font-size: 18px; letter-spacing: .5px; transition: color 220ms var(--ease); }
.site-header .menu a:hover,
.site-header .top-menu a:hover{ color: var(--hover); }
.site-header .social_media{ display: flex; align-items: center; gap: 30px; flex: 0 0 auto; }
.site-header .social_media a{ display: inline-flex; align-items: center; justify-content: center; text-decoration: none; line-height: 1; }
.site-header .nav-toggle{ border: 0; background: transparent; padding: 0; margin: 0; cursor: pointer; align-items: center; justify-content: center; appearance: none; -webkit-appearance: none; }
.site-header .hamburger{ width: 22px; height: 2px; background: var(--accent); display: inline-block; position: relative; transition: background 260ms var(--ease); }
.site-header .hamburger::before,
.site-header .hamburger::after{ content: ""; position: absolute; left: 0; width: 22px; height: 2px; background: var(--accent); transition: top 320ms var(--ease), transform 320ms var(--ease); }
.site-header .hamburger::before{ top: -7px; }
.site-header .hamburger::after{ top: 7px; }
/* =========================
   PC
========================= */
@media (min-width: 768px){
  .site-header .nav{ padding: 0 35px; box-sizing: border-box;}
  .site-header .menu,
  .site-header .top-menu{ flex: 1; display: flex; align-items: center; justify-content: center; gap: 18px; }
  .site-header .menu a + a,
  .site-header .top-menu a + a{ position: relative; padding-left: 18px; }
  .site-header .menu a + a::before,
  .site-header .top-menu a + a::before{ content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 1px; height: 18px; background: var(--divider); opacity: 1; }
  .site-header .social_media a{ height: 24px; }
  .site-header .social_media .icon-fb,
  .site-header .social_media .icon-line{ font-size: 24px; line-height: 1; display: inline-block; }
  .site-header .nav-toggle{ display: none; }
}
/* =========================
   Mobile
========================= */
@media (max-width: 767.98px){
  .site-header .nav{ padding: 0 20px; }
  .site-header .menu,
  .site-header .top-menu,
  .site-header .social_media{ display: none; }
  .site-header .brand{ position: fixed; top: 20px; left: 20px; }
  /* 漢堡固定在視窗右上，展開前後同位置 */
  .site-header .nav-toggle{ position: fixed; top: calc((var(--nav-h) - 40px) / 2); right: 20px; width: 40px; height: 40px; display: inline-flex; z-index: 1101; }
  .site-header.is-open{ height: 100vh; }
  .site-header.is-open .nav{ height: 100%; align-items: flex-start; box-sizing: border-box; }
  .site-header.is-open .menu,
  .site-header.is-open .top-menu{ display: flex; flex-direction: column; align-items: center; position: absolute; top: 80px; left: 0; right: 0; width: 100%; gap: 0; padding: 0; }
  .site-header.is-open .menu a,
  .site-header.is-open .top-menu a{ width: min(520px, calc(100% - 48px)); text-align: center; padding: 22px 10px; position: relative; }
  .site-header.is-open .menu a + a::before,
  .site-header.is-open .top-menu a + a::before{ content: none; }
  .site-header.is-open .menu a:not(:last-child)::after,
  .site-header.is-open .top-menu a:not(:last-child)::after{ content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 1px; background: var(--divider); opacity: 1; }
  .site-header.is-open .social_media{ display: flex; position: absolute; left: 0; right: 0; bottom: 60px; justify-content: center; gap: 60px; }
  .site-header .social_media a{ height: 30px; }
  .site-header .social_media .icon-fb,
  .site-header .social_media .icon-line{ font-size: 30px; line-height: 1; display: inline-block; }
  .site-header.is-open .hamburger{ background: transparent; }
  .site-header.is-open .hamburger::before{ top: 0; transform: rotate(45deg); }
  .site-header.is-open .hamburger::after{ top: 0; transform: rotate(-45deg); }
}
/* =========================
   Header / Nav end
========================= */


/* 手機
--------------------------------------------------------------------------------------*/
@media only screen and (max-width:640px){

	body{
    background: url("../images/m_bg.jpg") no-repeat center top; 
    -webkit-background-size:contain; 
    -moz-background-size:contain; 
    background-size:contain; 
    background-color: #cfbeb4; 
  }
  .kv{
    width:100%; 
    height: 0px; 
    margin:40px 0;
    padding-bottom: 105.46%; 
    background: url("../images/m_KV.png") no-repeat left top; 
    -webkit-background-size:cover; 
    -moz-background-size:cover; 
    background-size:cover; 
    position: relative;
  }
  
  .bubble_t2 {
    font-size: 16px;
    color: #3c3b3a;
    text-align: center;
    letter-spacing: 0px;
    line-height: 1.9em;
    top: 200px;
    left: 50%;
/*     transform: translateX(-50%); */
/*     width: 92%; */
    text-align: center
  }
  /* ----------------------黑白珍珠介紹---------------------- */
  .content{
    flex-wrap: wrap; 
    margin: 12px 0;
  }
  .black_area{ 
    width: 100%;
    margin: 0 auto; 
    flex-direction: row-reverse;
  }  
  .white_area{ 
    margin: 100px auto 20px auto; 
  }
  .black_ct,.white_ct,.original_ct{
    width: 100%;
  }
  .black_ct:before{
    position: absolute;
    content: "";
    width: 100%;
    height: 1px;
    border-right: none;
    border-bottom: 1px dotted #9a897f;
    right: 0;
    top: auto;
    bottom: 0;    
  }
  .title_area{
    margin-top: 24px; 
  }
  .taste {
    width: 100%;
    margin: 24px auto;
  }
  .depiction_area{
    width: 62%;
    margin: 24px auto;
  }
  .depiction{
    width: 100%;
    margin: 24px auto;
  }

  /*---------------------- 價目表 ----------------------*/
  .citypearl{
    font-size: 14px;
  }
  .bubble_category{
    width: 40px;
  }
  .price_area{
    max-width: 360px;
    margin: 0 auto;
  }
  .cup {
    width: 28px;
    margin: 0 2px;
  }
  .name {
    font-size: 16px;
    font-weight: bold;
    /* width: 112px; */
    width: 150px;
  }

  .limit{
    display: block;
  }


.ingredient_btn{
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 0);
  }

}