/* 流體字級與容器留白 */
:root{
  --fs-base: clamp(14px, 1.8vw, 18px);
  --gutter: clamp(12px, 4vw, 24px);
}
html,body{ font-size: var(--fs-base); }

/* 讓 #intro 不再被 100vh 卡住；改用最小高 + 內距 */
#intro{
  min-height: 100dvh;           /* 支援現代瀏覽器的動態視窗高 */
  height: auto;                  /* 蓋掉原本的 100vh */
  padding: calc(var(--gutter) * 1.5) var(--gutter);
  overflow: visible;             /* 避免被切掉 */
  box-sizing: border-box;
  text-align: center;
}

/* 圖像與背景塊：拿掉固定像素，全面可縮放 */
#intro .logo{
  width: min(220px, 70vw);
  height: min(72px, 22vw);
  margin: 0 auto clamp(12px, 3vw, 20px);
  background-size: contain;
  background-position: center;
}

#intro .image{
  width: 100%;
  max-width: 560px;
  margin: clamp(12px, 3vw, 24px) auto 0;
  aspect-ratio: 16 / 10;         /* 沒圖時也不塌陷 */
  background-size: contain;      /* 不裁切圖片 */
  background-position: center;
  background-repeat: no-repeat;
}

/* 文字區：用 clamp 防爆字 */
#intro .title{
  font-size: clamp(20px, 5.2vw, 32px);
  line-height: 1.2;
  height: auto;                  /* 取消固定 28px 高度 */
}
#intro .content{
  margin-top: 10px;
  font-size: clamp(14px, 3.6vw, 18px);
  line-height: 1.6;
  height: auto;                  /* 取消固定 16px 高度 */
}

/* 下載區：按鈕全寬、圖片自適應，容器用 grid */
#intro .upload_box,
#download .upload_box{
  width: 100%;
  max-width: 740px;
  height: auto;                  /* 取消固定 44px */
  margin: clamp(12px, 3vw, 20px) auto 0;
  display: grid;
  grid-template-columns: 1fr;
  grid-row-gap: 12px;
  justify-items: center;
}
@media (min-width: 560px){
  #intro .upload_box,
  #download .upload_box{
    grid-template-columns: 1fr 1fr;
    grid-column-gap: 16px;
    grid-row-gap: 0;
  }
}

#intro .download,
#download .download{
  width: min(420px, 100%);
  height: auto;                  /* 讓高度跟著圖片等比 */
}
#intro .download > img,
#download .download > img{
  width: 100%;
  height: auto;
  display: block;
}

/* 下載描述：改用邏輯流而不是絕對定位 */
#intro > .download-desc{
  position: static;
  width: auto;
  margin: 10px 0 0;
  font-size: clamp(12px, 3.4vw, 14px);
}

/* 功能區：移除固定高度，避免溢出；圖片可縮放 */
.feature{
  height: auto;                  /* 取消 530px */
  padding: clamp(16px, 4vw, 28px) var(--gutter);
  border-top: 1px solid #e5ecec;
  text-align: center;
}
.feature .title{
  font-size: clamp(18px, 4.6vw, 24px);
  line-height: 1.3;
  margin-top: clamp(8px, 2vw, 16px);
}
.feature .desc{
  font-size: clamp(12px, 3.2vw, 14px);
  line-height: 1.6;
  margin-top: clamp(8px, 2.8vw, 16px);
}
.feature .image img{
  width: min(100%, 360px);
  height: auto;
}

/* Footer：高度自適應，加入安全區 */
#footer{
  height: auto;                  /* 取消 70px */
  padding: 14px var(--gutter) calc(14px + env(safe-area-inset-bottom, 0px));
  background-color: #ebf1f6;
}
#footer .copyright, #footer .copyright a{
  font-size: clamp(10px, 2.6vw, 12px);
  margin: 8px 0;
}

/* 蒙版提示：字級自適應 */
#mask .hint{
  font-size: clamp(14px, 3.6vw, 18px);
}

/* 極小螢幕：不要用 zoom，直接縮小內距與圖片 */
@media (max-width: 374px){
  #intro{ padding: 14px 10px; }
  #intro .image{ max-width: 300px; }
}
