@charset "UTF-8";
/* ========================
  🎨 Design Tokens - Variables
======================== */
/* Color */
/* Breakpoints（對齊 Bootstrap） */
/* Font Family */
/* =========================================
  📐 Section Spacing System v2

  規則：
  - .section-pad        = 全站預設 padding，貼在 <section>
  - .section-pad--px-0  = 手機 X 軸 0，桌機自動補回
  - .section-pad--py-0  = 手機 Y 軸 0，桌機自動補回
  - .section-pad--pt-0  = 手機上方 0，桌機自動補回
  - .section-pad--pb-0  = 手機下方 0，桌機自動補回
  - .section-pad--ps-0  = 手機左側 0，桌機自動補回
  - .section-pad--pe-0  = 手機右側 0，桌機自動補回
  - .section-gutter     = section 等級的 row 間距，貼在 Bootstrap .row
  - 其餘削減用 Bootstrap：py-0 / py-lg-0 / px-0 …

  手機滿版用法：
  <section class="section-pad section-pad--px-0">
    <img>
    <div class="px-mobile-section">文字</div>
  </section>
========================================= */
/* ─── Root Tokens ────────────────────────────────────────── */
:root {
  /* Mobile */
  --section-padding-px: clamp(2.1875rem, calc(0.0275rem + 9.22vw), 5.7356rem);
  --section-padding-py: clamp(2rem, calc(0.1737rem + 7.79vw), 5rem);
  /* Desktop */
  --section-padding-px-lg: clamp(4.1981rem, calc(0.0004rem + 6.77vw), 8.125rem);
  --section-padding-py-lg: clamp(3.125rem, calc(0.0517rem + 4.96vw), 6rem);
  --section-gutter-y: clamp(2rem, calc(0.8rem + 6.51vw), 10rem);
  --section-gutter-x: clamp(2.1736rem, calc(-0.0142rem + 9.33vw), 10rem);
}

/* ─── .section-pad ───────────────────────────────────────── */
.section-pad {
  padding-inline: var(--section-padding-px);
  padding-block: var(--section-padding-py);
}
@media (min-width: 992px) {
  .section-pad {
    padding-inline: var(--section-padding-px-lg);
    padding-block: var(--section-padding-py-lg);
  }
}
.section-pad {
  /* 手機 X 軸 0，桌機補回 */
}
.section-pad--px-0 {
  padding-inline: 0;
}
@media (min-width: 992px) {
  .section-pad--px-0 {
    padding-inline: var(--section-padding-px-lg);
  }
}
.section-pad {
  /* 手機 Y 軸 0，桌機補回 */
}
.section-pad--py-0 {
  padding-block: 0;
}
@media (min-width: 992px) {
  .section-pad--py-0 {
    padding-block: var(--section-padding-py-lg);
  }
}
.section-pad {
  /* 手機上方 0，桌機補回 */
}
.section-pad--pt-0 {
  padding-top: 0;
}
@media (min-width: 992px) {
  .section-pad--pt-0 {
    padding-top: var(--section-padding-py-lg);
  }
}
.section-pad {
  /* 手機下方 0，桌機補回 */
}
.section-pad--pb-0 {
  padding-bottom: 0;
}
@media (min-width: 992px) {
  .section-pad--pb-0 {
    padding-bottom: var(--section-padding-py-lg);
  }
}
.section-pad {
  /* 手機左側 0，桌機補回 */
}
.section-pad--ps-0 {
  padding-left: 0;
}
@media (min-width: 992px) {
  .section-pad--ps-0 {
    padding-left: var(--section-padding-px-lg);
  }
}
.section-pad {
  /* 手機右側 0，桌機補回 */
}
.section-pad--pe-0 {
  padding-right: 0;
}
@media (min-width: 992px) {
  .section-pad--pe-0 {
    padding-right: var(--section-padding-px-lg);
  }
}

/* ─── .section-gutter（Bootstrap .row 的 section 等級間距）── */
.section-gutter {
  --bs-gutter-y: var(--section-gutter-y);
  --bs-gutter-x: 0;
}
@media (min-width: 992px) {
  .section-gutter {
    --bs-gutter-y: 0;
    --bs-gutter-x: var(--section-gutter-x);
  }
}

/* ─── 手機局部回填 ───────────────────────────────────────── */
/* section-pad--bleed 內，讓部分內容保有手機 padding
   用法：<div class="px-mobile-section"> */
@media (max-width: 991px) {
  .px-mobile-section {
    padding-inline: var(--section-padding-px);
  }
}

/* ========================
  🎨 Root Tokens
======================== */
:root {
  /* Color Tokens（跨 class 共用）*/
  --color-primary: #b6895d;
  --color-primary-hover: #856646;
  --color-primary-rgb: 182,
  137,
  93;
  --color-secondary: #bea850;
  --color-secondary-hover: #a68915;
  --color-secondary-rgb: 190,
  168,
  80;
  --color-gray: #888888;
  --color-gray-hover: #656565;
  --color-gray-rgb: 136,
  136,
  136;
}

body {
  font-family: "Noto Sans TC", "PingFang TC", "Microsoft JhengHei", sans-serif;
  line-height: 1.66;
  letter-spacing: 0.04em;
  font-size: 1rem;
}
@media (max-width: 991px) {
  body {
    font-size: 0.9rem;
  }
}

/* ========================
  🏷 Page Typography Patterns
  語意標題 class — 全站共用標題組合樣式
  修改此處即可全站同步，不需逐一改 section
  需要差異化時，在 style.scss 內的 pageXX 局部覆蓋
======================== */
/* 英文裝飾大標（LOCATION / CONCEPT 等）
   字體切換：直接加 .font-* class
   modifier: --primary */
.page-en-title {
  font-size: clamp(2.25rem, 25.7px + 3.21vw, 4.5rem);
  font-family: "Playfair Display", "Times New Roman", serif;
  font-weight: 300;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  white-space: nowrap;
}
.page-en-title--primary {
  color: #b6895d;
}

/* 中文主標題
   字體切換：直接加 .font-* class
   modifier: --primary */
.page-zh-title {
  font-size: clamp(1.2rem, 15.5px + 1.14vw, 2rem);
  font-family: "Noto Serif TC", "PMingLiU", serif;
  font-weight: normal;
  line-height: 1.8;
  letter-spacing: 0.5rem;
}
.page-zh-title--primary {
  color: #b6895d;
}

/* 中文次標題（Optional）modifier: --primary */
.page-zh-subtitle {
  font-size: clamp(1.1rem, 15.8px + 0.57vw, 1.5rem);
  font-family: "Noto Sans TC", "PingFang TC", "Microsoft JhengHei", sans-serif;
  font-weight: 400;
}
.page-zh-subtitle--primary {
  color: #b6895d;
}

/* 英文次標題（Optional）modifier: --primary */
.page-en-subtitle {
  font-size: clamp(1.1rem, 15.8px + 0.57vw, 1.5rem);
  font-family: "Helvetica Neue", Arial, sans-serif;
  font-weight: 400;
  letter-spacing: 0.05em;
}
.page-en-subtitle--primary {
  color: #b6895d;
}

/* 中文小標籤（Optional）modifier: --primary */
.page-zh-label {
  font-size: clamp(0.65rem, 9.9px + 0.14vw, 0.75rem);
  font-family: "Noto Sans TC", "PingFang TC", "Microsoft JhengHei", sans-serif;
  font-weight: 400;
  color: #b6895d;
}
.page-zh-label--primary {
  color: #b6895d;
}

/* 英文小標籤（Optional）modifier: --primary */
.page-en-label {
  font-size: clamp(0.65rem, 9.9px + 0.14vw, 0.75rem);
  font-family: "Helvetica Neue", Arial, sans-serif;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #b6895d;
}
.page-en-label--primary {
  color: #b6895d;
}

/* 圖說 / 註解（Optional）
  字體切換：直接加 .font-* class
   modifier: --primary */
.page-caption {
  font-size: clamp(0.65rem, 9.9px + 0.14vw, 0.75rem);
  font-family: "Noto Sans TC", "PingFang TC", "Microsoft JhengHei", sans-serif;
  font-weight: 400;
}
.page-caption--primary {
  color: #b6895d;
}

/* ========================
  📢 Slogan（廣告標語系統）
  用於 Banner / Footer 品牌訴求語
  字體切換：直接加 .font-* class
======================== */
/* 廣告標語容器：無預設對齊，搭配 .text-spread 啟用字元均分 */
.slogan-wrap {
  max-width: 100%;
  margin-inline: auto;
}

/* 標語字級一（最大） modifier: --primary */
.page-slogan-heading1 {
  font-size: clamp(1.5rem, 17.1px + 2.14vw, 3rem);
  font-family: "Noto Serif TC", "PMingLiU", serif;
  font-weight: normal;
  letter-spacing: 0.3rem;
  line-height: 1.8;
}
.page-slogan-heading1--primary {
  color: #b6895d;
}

/* 標語字級二（次大） modifier: --primary */
.page-slogan-heading2 {
  font-size: clamp(1.25rem, 14px + 1.5vw, 2.4rem);
  font-family: "Noto Serif TC", "PMingLiU", serif;
  font-weight: normal;
  letter-spacing: 0.25rem;
  line-height: 1.8;
}
.page-slogan-heading2--primary {
  color: #b6895d;
}

/* 標語字級三（中） modifier: --primary */
.page-slogan-heading3 {
  font-size: clamp(1.1rem, 12px + 0.9vw, 1.8rem);
  font-family: "Noto Sans TC", "PingFang TC", "Microsoft JhengHei", sans-serif;
  font-weight: 400;
  letter-spacing: 0.15rem;
  line-height: 2;
}
.page-slogan-heading3--primary {
  color: #b6895d;
}

/* 標語小標籤（小） modifier: --primary */
.page-slogan-label {
  font-size: clamp(0.65rem, 9.9px + 0.14vw, 0.75rem);
  font-family: "Helvetica Neue", Arial, sans-serif;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #b6895d;
}
.page-slogan-label--primary {
  color: #b6895d;
}

/* ========================
  ✨ Text Decoration Utilities
======================== */
/* 字元均分
   1. 加在 .slogan-wrap 上 → 所有子行統一均分：<div class="slogan-wrap text-spread">
   2. 單一元素獨立使用 → <h2 class="page-slogan-heading1 text-spread">
   兩者都需在 style.scss 設定 width */
.text-spread {
  max-width: 100%;
  margin-inline: auto;
  text-align: justify;
  -moz-text-align-last: justify;
       text-align-last: justify;
  white-space: nowrap;
}

/* 線條夾文字
   顏色繼承父層，深色背景自動變白：<p class="title-lined text-white">
   用法：<p class="title-lined page-slogan-heading3"> */
.title-lined {
  display: flex;
  align-items: center;
}
.title-lined::before, .title-lined::after {
  content: "";
  flex: 1;
  height: 1px;
  background: currentColor;
  opacity: 0.5;
}
.title-lined::before {
  margin-right: 1.5rem;
}
.title-lined::after {
  margin-left: 1.5rem;
}

/* ========================
  📐 Text Alignment
======================== */
/*
  .txt-wrap 標準結構：
  .txt-wrap
    ├── .txt-title    → 標題群組（label / title / subtitle）
    ├── .txt-body     → 段落內文（<p> 自動套用對齊規則）
    └── small.page-caption
*/
.txt-wrap .txt-title {
  margin-bottom: 2rem;
}
.txt-wrap .txt-body p {
  text-align: justify;
  text-justify: inter-ideograph;
  -moz-text-align-last: left;
       text-align-last: left;
  word-break: break-all;
}
@media (min-width: 992px) {
  .txt-wrap .txt-body p {
    text-align: inherit;
    -moz-text-align-last: auto;
         text-align-last: auto;
    word-break: normal;
  }
}
.txt-wrap .txt-body p.text-center {
  text-align: center;
  -moz-text-align-last: center;
       text-align-last: center;
  word-break: normal;
}
@media (min-width: 992px) {
  .txt-wrap .txt-body p.text-lg-center {
    -moz-text-align-last: center;
         text-align-last: center;
  }
}
@media (min-width: 992px) {
  .txt-wrap .txt-body p.text-justify {
    text-align: justify;
    text-justify: inter-ideograph;
    -moz-text-align-last: left;
         text-align-last: left;
    word-break: break-all;
  }
}

/* ========================
  🔤 Font System
======================== */
.font-zh-sans {
  font-family: "Noto Sans TC", "PingFang TC", "Microsoft JhengHei", sans-serif;
}

.font-zh-serif {
  font-family: "Noto Serif TC", "PMingLiU", serif;
}

.font-en-sans {
  font-family: "Helvetica Neue", Arial, sans-serif;
}

.font-en-serif {
  font-family: "Playfair Display", "Times New Roman", serif;
}

/* ========================
  🎞 Plugins
======================== */
/* slick */
.slick-prev {
  left: 0;
  z-index: 10;
}
.slick-prev:before {
  content: "\f284";
}

.slick-next {
  right: 0;
}
.slick-next:before {
  content: "\f285";
}

.slick-next,
.slick-prev {
  width: auto;
  height: auto;
}

.slick-prev:before,
.slick-next:before {
  font-family: bootstrap-icons !important;
  font-size: 3rem;
}

/* fancybox */
.fancybox-navigation {
  height: 100vh;
}

/* ========================
  📐 Section Layout
======================== */
/* 垂直置中滿版 section */
.section-center {
  min-height: 100svh;
  display: flex;
  align-items: center;
}

/* ========================
  🖼 Image
======================== */
/*
  .img-wrap 支援兩種內部結構：

  舊版（background-image）：
  <div class="img-wrap">
    <div class="img-ratio">
      <div class="img-bg" style="background-image: url(xxx.jpg);"></div>
    </div>
    <div class="img-caption">說明</div>
  </div>

  新版（<img> + aspect-ratio）：
  <div class="img-wrap">
    <img class="img-cover" style="aspect-ratio: 10/7;"
         src="xxx.jpg" alt="..." loading="lazy">
    <div class="img-caption">說明</div>
  </div>
*/
.img-wrap {
  position: relative;
}
.img-wrap a {
  display: block;
}
.img-wrap .img-ratio {
  position: relative;
  width: 100%;
  padding-top: 70%;
}
.img-wrap .img-ratio .img-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
.img-wrap.img-gradient::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 55%;
  background: linear-gradient(to bottom, transparent, rgba(0, 0, 0, 0.55));
  z-index: 1;
  pointer-events: none;
}
.img-wrap.img-gradient .img-caption {
  z-index: 2;
}

.img-cover {
  display: block;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.img-caption {
  position: absolute;
  right: 0;
  bottom: 0;
  color: #fff;
  width: 100%;
  text-align: right;
  padding: 3px;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.678);
  font-size: clamp(0.65rem, 9.9px + 0.14vw, 0.75rem);
}

/* ========================
  🗺 google Map Embed 
======================== */
.map-embed iframe {
  display: block;
  width: 100% !important;
  height: clamp(300px, 50vh, 700px) !important;
  border: none;
}

/* ========================
  🎭 Stage / Layer（分層進場）
======================== */
.stage-wrap {
  position: absolute;
  inset: 0;
}

.stage,
.layer {
  position: absolute;
  inset: 0;
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}

/* ========================
  🔧 Base
======================== */
*,
*::before,
*::after {
  position: relative;
  box-sizing: border-box;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

footer {
  margin-top: auto;
}

/* ========================
  🎨 Color System
======================== */
.text-primary {
  color: var(--color-primary) !important;
}

.text-secondary {
  color: var(--color-secondary) !important;
}

.text-gray {
  color: var(--color-gray) !important;
}

.bg-primary {
  background-color: var(--color-primary) !important;
}

.bg-secondary {
  background-color: var(--color-secondary) !important;
}

.bg-gray {
  background-color: var(--color-gray) !important;
}

.border-primary {
  border-color: var(--color-primary) !important;
}

.border-secondary {
  border-color: var(--color-secondary) !important;
}

.border-gray {
  border-color: var(--color-gray) !important;
}

.form-check-input:checked {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.btn-primary {
  color: #fff;
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}
.btn-primary:hover, .btn-primary:focus, .btn-primary.focus {
  background-color: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
}
.btn-primary:active, .btn-primary.active {
  background-color: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
}

.btn-outline-primary {
  color: var(--color-primary);
  border-color: var(--color-primary);
}
.btn-outline-primary:hover, .btn-outline-primary:focus, .btn-outline-primary.focus {
  color: #fff;
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}
.btn-outline-primary:active, .btn-outline-primary.active {
  color: #fff;
  background-color: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
}

.btn-secondary {
  color: #fff;
  background-color: var(--color-secondary);
  border-color: var(--color-secondary);
}
.btn-secondary:hover, .btn-secondary:focus, .btn-secondary.focus {
  color: #fff;
  background-color: var(--color-secondary-hover);
  border-color: var(--color-secondary-hover);
}
.btn-secondary:active, .btn-secondary.active {
  color: #fff;
  background-color: var(--color-secondary-hover);
  border-color: var(--color-secondary-hover);
}

.btn-outline-secondary {
  color: var(--color-secondary);
  border-color: var(--color-secondary);
}
.btn-outline-secondary:hover, .btn-outline-secondary:focus, .btn-outline-secondary.focus {
  color: #fff;
  background-color: var(--color-secondary);
  border-color: var(--color-secondary);
}
.btn-outline-secondary:active, .btn-outline-secondary.active {
  color: #fff;
  background-color: var(--color-secondary-hover);
  border-color: var(--color-secondary-hover);
}

.btn-gray {
  color: #fff;
  background-color: var(--color-gray);
  border-color: var(--color-gray);
}
.btn-gray:hover, .btn-gray:focus, .btn-gray.focus {
  color: #fff;
  background-color: var(--color-gray-hover);
  border-color: var(--color-gray-hover);
}
.btn-gray:active, .btn-gray.active {
  color: #fff;
  background-color: var(--color-gray-hover);
  border-color: var(--color-gray-hover);
}

.btn-outline-gray {
  color: var(--color-gray);
  border-color: var(--color-gray);
}
.btn-outline-gray:hover, .btn-outline-gray:focus, .btn-outline-gray.focus {
  color: #fff;
  background-color: var(--color-gray);
  border-color: var(--color-gray);
}
.btn-outline-gray:active, .btn-outline-gray.active {
  color: #fff;
  background-color: var(--color-gray-hover);
  border-color: var(--color-gray-hover);
}

/* ========================
  🎭 form
======================== */
.form-control {
  border-radius: 0;
  background-color: rgba(255, 255, 255, 0.596);
}
.form-control:focus {
  color: #333333;
  background-color: #fff;
  border-color: var(--color-primary);
  outline: 0;
  box-shadow: 0 0 10px 3px rgba(var(--color-primary-rgb), 0.44);
}

/* ========================
  🔗 Link / Button
======================== */
a,
.btn {
  text-decoration: none;
  border-radius: 0;
}
a:hover,
.btn:hover {
  text-decoration: none;
}

a:focus,
button:focus {
  outline: none !important;
}/*# sourceMappingURL=main.css.map */