:root{
  --black:#070706;
  --deep:#10110d;
  --deep2:#171610;
  --white:#fffdf8;
  --paper:#ffffff;
  --gold:#d2b26f;
  --gold2:#f2dfaa;
  --ink:#231f19;
  --muted:#72695e;
  --line:rgba(210,178,111,.32);
  --line-dark:rgba(35,31,25,.16);
  --green:#173225;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:76px}
body{
  margin:0;
  font-family:"Noto Serif TC","PingFang TC","Microsoft JhengHei",serif;
  color:var(--white);
  background:var(--black);
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.top-anchor{position:absolute;top:0;left:0;width:1px;height:1px}

.section-dark{background:var(--black)}
.section-white{background:var(--paper);color:var(--ink)}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  height:76px;
  padding:0 clamp(18px,5vw,58px);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  background:rgba(5,5,4,.86);
  border-bottom:1px solid rgba(210,178,111,.18);
  backdrop-filter:blur(14px);
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.brand__icon{
  width:44px;
  height:44px;
  object-fit:contain;
  flex:none;
}
.brand__text{
  display:flex;
  flex-direction:column;
  line-height:1.05;
}
.brand__text strong{
  color:var(--gold2);
  font-size:22px;
  letter-spacing:.12em;
  white-space:nowrap;
}
.brand__text small{
  color:rgba(255,253,248,.75);
  font-size:10px;
  letter-spacing:.28em;
  margin-top:6px;
}
.site-nav{
  display:flex;
  gap:clamp(18px,3vw,42px);
  align-items:center;
  font-size:14px;
  letter-spacing:.12em;
}
.site-nav a{
  color:rgba(255,253,248,.82);
}
.site-nav a:hover{color:var(--gold2)}
.nav-toggle{display:none}
.hamburger{display:none}

.hero{
  min-height:620px;
  display:grid;
  grid-template-columns:.88fr 1.12fr;
  align-items:center;
  gap:clamp(22px,4vw,58px);
  padding:clamp(54px,6vw,86px) clamp(24px,6vw,78px) clamp(46px,6vw,72px);
  overflow:hidden;
  background:
    radial-gradient(circle at 80% 30%, rgba(210,178,111,.16), transparent 26rem),
    linear-gradient(112deg, rgba(7,7,6,.99) 0%, rgba(7,7,6,.93) 38%, rgba(7,7,6,.72) 62%, rgba(7,7,6,.60) 100%),
    linear-gradient(180deg,#15130e 0%,#070706 100%);
  position:relative;
}
.hero::after{
  content:"";
  position:absolute;
  inset:auto 6vw 34px 6vw;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(210,178,111,.32),transparent);
}
.hero__copy{
  max-width:560px;
  position:relative;
  z-index:1;
}
.eyebrow{
  margin:0 0 18px;
  color:var(--gold);
  font-size:12px;
  letter-spacing:.28em;
  font-weight:700;
}
.hero h1{
  margin:0 0 24px;
  color:var(--gold2);
  font-size:clamp(40px,5vw,64px);
  line-height:1.32;
  letter-spacing:.08em;
  font-weight:500;
}
.lead{
  max-width:520px;
  margin:0;
  color:rgba(255,253,248,.78);
  font-size:17px;
  line-height:2.1;
  letter-spacing:.045em;
}
.hero__actions{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  margin-top:34px;
}
.btn{
  min-width:160px;
  height:48px;
  padding:0 24px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--gold);
  letter-spacing:.12em;
  font-size:15px;
}
.btn--gold{
  background:linear-gradient(180deg,#f4dfaa,#bc9752);
  color:#1b140b;
}
.btn--outline{
  color:var(--gold2);
  background:rgba(0,0,0,.12);
}
.hero__visual{
  margin:0;
  position:relative;
  z-index:1;
}
.hero__visual::before{
  content:"";
  position:absolute;
  width:70%;
  height:70%;
  right:2%;
  top:12%;
  border-radius:50%;
  background:radial-gradient(circle,rgba(210,178,111,.12),transparent 68%);
  filter:blur(12px);
}
.hero__visual img{
  position:relative;
  z-index:1;
  margin-left:auto;
  width:min(100%,720px);
  filter:drop-shadow(0 30px 52px rgba(0,0,0,.62));
}

.belief{
  min-height:172px;
  display:grid;
  grid-template-columns:1fr 280px;
  align-items:center;
  gap:30px;
  padding:46px clamp(24px,8vw,110px);
  border-top:1px solid #eee;
  border-bottom:1px solid #eee;
}
.belief__text h2{
  margin:0 0 14px;
  font-size:clamp(28px,3.5vw,42px);
  line-height:1.42;
  letter-spacing:.08em;
  font-weight:400;
}
.belief__text p{
  max-width:790px;
  margin:0;
  color:var(--muted);
  font-size:16px;
  line-height:2;
}
.botanical{
  justify-self:end;
  color:#938a7f;
  width:240px;
  opacity:.7;
}

.structure{
  padding:62px clamp(24px,6vw,76px) 70px;
  background:
    linear-gradient(180deg,#0b0c09,#11120d);
}
.section-heading{
  margin-bottom:38px;
}
.center{text-align:center}
.section-heading p{
  margin:0 0 10px;
  color:var(--gold);
  font-size:12px;
  letter-spacing:.26em;
}
.section-heading h2{
  margin:0;
  color:var(--gold2);
  font-size:clamp(28px,3.6vw,42px);
  line-height:1.35;
  letter-spacing:.12em;
  font-weight:400;
}
.dark-heading h2{color:var(--ink)}
.dark-heading p{color:#8a764f}
.structure-grid{
  width:min(100%,var(--max));
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.structure-grid article{
  padding:28px 22px 30px;
  text-align:center;
  border-left:1px solid var(--line);
}
.structure-grid article:first-child{border-left:0}
.round-icon{
  width:78px;
  height:78px;
  margin:0 auto 14px;
  border:1.5px solid var(--gold);
  border-radius:50%;
  display:grid;
  place-items:center;
  color:var(--gold);
}
.round-icon svg{
  width:42px;
  height:42px;
  fill:none;
  stroke:currentColor;
  stroke-width:2.4;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.structure-grid h3{
  margin:0 0 6px;
  color:var(--gold2);
  font-size:22px;
  letter-spacing:.12em;
  font-weight:400;
}
.structure-grid p{
  margin:0;
  color:rgba(255,253,248,.68);
  font-size:14px;
  line-height:1.7;
}

.composition{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:420px;
  border-top:1px solid rgba(210,178,111,.18);
  border-bottom:1px solid rgba(210,178,111,.18);
}
.composition__image{
  margin:0;
  min-height:420px;
  overflow:hidden;
}
.composition__image img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.composition__text{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:56px clamp(28px,6vw,78px);
  background:linear-gradient(180deg,#10110d,#090a08);
}
.composition__text h2{
  margin:0 0 16px;
  color:var(--gold2);
  font-size:clamp(32px,4vw,46px);
  font-weight:400;
  letter-spacing:.12em;
}
.composition__intro{
  margin:0 0 22px;
  color:rgba(255,253,248,.72);
  line-height:1.9;
}
.composition-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:11px;
}
.composition-list li{
  display:grid;
  grid-template-columns:90px 1fr;
  gap:10px;
  align-items:start;
  color:rgba(255,253,248,.75);
  line-height:1.75;
}
.composition-list strong{
  color:var(--gold);
  font-weight:400;
  letter-spacing:.08em;
}

.support{
  padding:54px clamp(24px,8vw,100px);
}
.support-row{
  width:min(100%,960px);
  margin:0 auto;
  padding:22px 0;
  display:grid;
  grid-template-columns:160px 1fr;
  gap:24px;
  border-top:1px solid var(--line-dark);
}
.support-row:last-child{
  border-bottom:1px solid var(--line-dark);
}
.support-row h3{
  margin:0;
  color:#685735;
  font-size:24px;
  font-weight:400;
  letter-spacing:.14em;
}
.support-row p{
  margin:0;
  color:var(--ink);
  font-size:17px;
  line-height:1.9;
}
.support-row span{
  color:#a79778;
  margin:0 8px;
}

.detail-strip{
  display:grid;
  grid-template-columns:1fr 1fr;
  border-top:1px solid rgba(210,178,111,.18);
  border-bottom:1px solid rgba(210,178,111,.18);
}
.detail-strip article{
  min-height:176px;
  display:grid;
  grid-template-columns:220px 1fr;
  align-items:center;
  gap:26px;
  padding:24px clamp(20px,5vw,58px);
  border-left:1px solid rgba(210,178,111,.22);
  background:linear-gradient(90deg,#080807,#11120d);
}
.detail-strip article:first-child{border-left:0}
.detail-strip img{
  width:220px;
  height:130px;
  object-fit:cover;
  border-radius:2px;
}
.detail-strip h3{
  margin:0 0 8px;
  color:var(--gold2);
  font-size:26px;
  letter-spacing:.12em;
  font-weight:400;
}
.detail-strip p{
  margin:0;
  color:rgba(255,253,248,.72);
}

.pairing{
  padding:56px clamp(24px,8vw,100px);
}
.pairing-grid{
  width:min(100%,920px);
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:26px;
}
.pairing-grid article{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:20px;
  align-items:center;
  padding:18px;
  border:1px solid var(--line-dark);
  background:#fff;
}
.pairing-grid img{
  width:160px;
  height:120px;
  object-fit:cover;
}
.pairing-grid h3{
  margin:0 0 8px;
  color:#685735;
  font-size:24px;
  font-weight:400;
  letter-spacing:.1em;
}
.pairing-grid p{
  margin:0;
  color:var(--muted);
}

.recommend{
  padding:50px clamp(24px,8vw,100px) 64px;
  border-top:1px solid #eee;
}
.recommend-grid{
  width:min(100%,1080px);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.recommend-grid article{
  padding:26px 24px;
  border:1px solid var(--line-dark);
  background:#fffdfa;
}
.recommend-grid span{
  display:block;
  margin-bottom:12px;
  color:#806737;
  font-size:23px;
  letter-spacing:.12em;
}
.recommend-grid p{
  margin:0;
  color:var(--muted);
  line-height:1.8;
}

.reserve{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  align-items:center;
  gap:40px;
  padding:58px clamp(24px,6vw,78px);
  background:
    radial-gradient(circle at 92% 32%,rgba(42,85,54,.34),transparent 18rem),
    linear-gradient(180deg,#0b0c09,#070706);
}
.reserve__copy h2{
  margin:0 0 16px;
  color:var(--gold2);
  font-size:clamp(30px,4vw,46px);
  line-height:1.45;
  font-weight:400;
  letter-spacing:.09em;
}
.reserve__copy p{
  margin:0;
  color:rgba(255,253,248,.7);
  font-size:18px;
}
.reserve__box{
  border:1px solid var(--line);
  padding:30px;
  background:rgba(255,253,248,.03);
}
.reserve__box h3{
  margin:0 0 24px;
  color:var(--gold2);
  font-size:30px;
  font-weight:400;
  letter-spacing:.12em;
}
.reserve__box ol{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  list-style:none;
  margin:0 0 26px;
  padding:0;
}
.reserve__box li{
  color:rgba(255,253,248,.74);
  text-align:center;
  line-height:1.6;
}
.reserve__box span{
  width:36px;
  height:36px;
  margin:0 auto 10px;
  border:1px solid var(--gold);
  border-radius:50%;
  display:grid;
  place-items:center;
  color:var(--gold2);
}
.btn--wide{
  width:100%;
}

@media(max-width:980px){
  html{scroll-padding-top:68px}
  .site-header{
    height:68px;
  }
  .brand__icon{width:36px;height:36px}
  .brand__text strong{font-size:18px;letter-spacing:.08em}
  .brand__text small{display:none}
  .hamburger{
    display:grid;
    gap:5px;
    width:32px;
    cursor:pointer;
  }
  .hamburger span{
    display:block;
    height:2px;
    background:var(--gold2);
  }
  .site-nav{
    position:absolute;
    left:0;
    right:0;
    top:68px;
    display:none;
    grid-template-columns:1fr;
    gap:0;
    background:rgba(5,5,4,.97);
    border-bottom:1px solid rgba(210,178,111,.18);
  }
  .site-nav a{
    padding:16px 24px;
    border-top:1px solid rgba(210,178,111,.12);
  }
  .nav-toggle:checked ~ .site-nav{display:grid}

  .hero{
    min-height:auto;
    grid-template-columns:1fr;
    padding:34px 20px 44px;
  }
  .hero__visual{order:-1}
  .hero__visual img{
    margin:0 auto;
    width:min(100%,620px);
  }
  .hero__copy{
    text-align:left;
    max-width:680px;
    margin:0 auto;
  }
  .hero h1{
    font-size:clamp(36px,7vw,52px);
  }
  .lead{
    font-size:16px;
  }
  .belief{
    grid-template-columns:1fr;
    padding:42px 24px;
  }
  .botanical{
    justify-self:center;
    width:200px;
  }
  .structure-grid{
    grid-template-columns:repeat(5, minmax(110px,1fr));
    overflow-x:auto;
  }
  .structure-grid article{
    min-width:132px;
  }
  .composition{
    grid-template-columns:1fr;
  }
  .composition__image{
    min-height:280px;
  }
  .composition__text{
    padding:42px 24px;
  }
  .support-row{
    grid-template-columns:1fr;
    gap:6px;
  }
  .detail-strip{
    grid-template-columns:1fr;
  }
  .detail-strip article{
    border-left:0;
    border-top:1px solid rgba(210,178,111,.18);
  }
  .pairing-grid{
    grid-template-columns:1fr;
  }
  .recommend-grid{
    grid-template-columns:1fr;
  }
  .reserve{
    grid-template-columns:1fr;
  }
}

@media(max-width:560px){
  .site-header{
    padding:0 18px;
  }
  .hero{
    padding-top:20px;
  }
  .hero h1{
    font-size:34px;
    line-height:1.45;
  }
  .eyebrow{
    font-size:10px;
    letter-spacing:.2em;
  }
  .hero__actions{
    display:grid;
    gap:12px;
  }
  .btn{
    width:100%;
  }
  .belief__text h2{
    font-size:26px;
  }
  .belief__text p{
    font-size:15px;
    line-height:1.9;
  }
  .structure{
    padding:44px 0;
  }
  .section-heading{
    padding:0 22px;
  }
  .structure-grid{
    border-left:0;
    border-right:0;
  }
  .composition-list li{
    grid-template-columns:1fr;
    gap:2px;
  }
  .support{
    padding:42px 20px;
  }
  .support-row h3{
    font-size:22px;
  }
  .support-row p{
    font-size:15px;
  }
  .detail-strip article{
    grid-template-columns:1fr;
    gap:16px;
    padding:24px 20px;
    text-align:left;
  }
  .detail-strip img{
    width:100%;
    height:170px;
  }
  .pairing{
    padding:42px 20px;
  }
  .pairing-grid article{
    grid-template-columns:1fr;
  }
  .pairing-grid img{
    width:100%;
    height:170px;
  }
  .recommend{
    padding:42px 20px 52px;
  }
  .reserve{
    padding:44px 20px;
  }
  .reserve__box{
    padding:24px 18px;
  }
  .reserve__box ol{
    grid-template-columns:1fr;
  }
}


/* =========================================================
   Support section fixed to match reference mockup
   White horizontal band / centered title / 3 columns
   ========================================================= */

.support{
  padding:34px clamp(22px, 7vw, 92px) 38px !important;
  background:#fffdf8 !important;
  color:var(--ink) !important;
  border-top:1px solid rgba(35,31,25,.10);
  border-bottom:1px solid rgba(35,31,25,.10);
}

.support-inner{
  width:min(100%, 1060px);
  margin:0 auto;
}

.support-title{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:22px;
  margin:0 auto 20px;
}

.support-title span{
  display:block;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(122,103,66,.42), transparent);
}

.support-title h2{
  margin:0;
  color:#2a241b;
  font-size:clamp(24px, 2.7vw, 34px);
  font-weight:400;
  letter-spacing:.18em;
  white-space:nowrap;
}

.support-columns{
  display:grid;
  grid-template-columns:1fr 1.3fr 1fr;
  border-top:1px solid rgba(35,31,25,.14);
  border-bottom:1px solid rgba(35,31,25,.14);
}

.support-columns article{
  min-height:86px;
  padding:18px 26px 16px;
  text-align:center;
  display:flex;
  flex-direction:column;
  justify-content:center;
  border-left:1px solid rgba(35,31,25,.16);
}

.support-columns article:first-child{
  border-left:0;
}

.support-columns h3{
  margin:0 0 8px;
  color:#4a3b21;
  font-size:18px;
  font-weight:500;
  letter-spacing:.18em;
}

.support-columns p{
  margin:0;
  color:#2b261f;
  font-size:15px;
  line-height:1.85;
  letter-spacing:.05em;
}

/* neutralize previous row layout */
.support-row{
  display:initial !important;
  width:auto !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
}

@media(max-width:760px){
  .support{
    padding:34px 20px 36px !important;
  }

  .support-title{
    gap:14px;
    margin-bottom:16px;
  }

  .support-title h2{
    font-size:24px;
    letter-spacing:.12em;
  }

  .support-columns{
    grid-template-columns:1fr;
    border-top:1px solid rgba(35,31,25,.13);
    border-bottom:1px solid rgba(35,31,25,.13);
  }

  .support-columns article{
    border-left:0;
    border-top:1px solid rgba(35,31,25,.12);
    min-height:auto;
    padding:18px 12px;
  }

  .support-columns article:first-child{
    border-top:0;
  }

  .support-columns p{
    font-size:14px;
    line-height:1.8;
  }
}


/* =========================================================
   Recommend section fixed to match reference mockup
   White horizontal band / fine dividers / compact 3 choices
   ========================================================= */

.recommend{
  padding:36px clamp(22px, 7vw, 92px) 42px !important;
  background:#fffdf8 !important;
  color:var(--ink) !important;
  border-top:1px solid rgba(35,31,25,.10);
  border-bottom:1px solid rgba(35,31,25,.10);
}

.recommend-inner{
  width:min(100%, 1060px);
  margin:0 auto;
}

.recommend-title{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:22px;
  margin:0 auto 22px;
}

.recommend-title span{
  display:block;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(122,103,66,.42), transparent);
}

.recommend-title h2{
  margin:0;
  color:#2a241b;
  font-size:clamp(24px, 2.7vw, 34px);
  font-weight:400;
  letter-spacing:.18em;
  white-space:nowrap;
}

.recommend-columns{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  border-top:1px solid rgba(35,31,25,.13);
  border-bottom:1px solid rgba(35,31,25,.13);
}

.recommend-columns article{
  display:grid;
  grid-template-columns:54px 1fr;
  align-items:center;
  gap:16px;
  padding:22px 26px;
  border-left:1px solid rgba(35,31,25,.15);
  background:#fffdf8;
}

.recommend-columns article:first-child{
  border-left:0;
}

.recommend-icon{
  width:46px;
  height:46px;
  border:1px solid rgba(122,103,66,.45);
  border-radius:50%;
  display:grid;
  place-items:center;
  color:#7a6742;
}

.recommend-icon svg{
  width:28px;
  height:28px;
  fill:none;
  stroke:currentColor;
  stroke-width:2.2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.recommend-columns h3{
  margin:0 0 6px;
  color:#4a3b21;
  font-size:20px;
  font-weight:400;
  letter-spacing:.14em;
}

.recommend-columns p{
  margin:0;
  color:#5e574f;
  font-size:14.5px;
  line-height:1.75;
  letter-spacing:.035em;
}

/* neutralize previous card layout */
.recommend-grid{
  display:initial !important;
  width:auto !important;
  margin:0 !important;
  gap:0 !important;
}

@media(max-width:760px){
  .recommend{
    padding:34px 20px 38px !important;
  }

  .recommend-title{
    gap:14px;
    margin-bottom:18px;
  }

  .recommend-title h2{
    font-size:24px;
    letter-spacing:.10em;
  }

  .recommend-columns{
    grid-template-columns:1fr;
  }

  .recommend-columns article{
    border-left:0;
    border-top:1px solid rgba(35,31,25,.12);
    padding:18px 12px;
  }

  .recommend-columns article:first-child{
    border-top:0;
  }

  .recommend-columns h3{
    font-size:18px;
  }

  .recommend-columns p{
    font-size:14px;
  }
}
