:root{
  --ink:#33402a;
  --pine:#465236;
  --olive:#75815a;
  --sage:#a8b08c;
  --cream:#f6f1e3;
  --paper:#fbf8ef;
  --card:#fffdf6;
  --gold:#b1934f;
  --gold-deep:#96793a;
  --gold-soft:#d8c48c;
  --seal-red:#a4392c;
  --shadow:0 24px 60px -24px rgba(51,64,42,.28);
  --serif:'Noto Serif TC','Cormorant Garamond',serif;
  --sans:'Noto Sans TC',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  font-size:clamp(1rem,.92rem + .4vw,1.15rem);
  line-height:1.75;
  overflow-x:hidden;
}
::selection{background:var(--pine);color:var(--cream)}
a:focus-visible,button:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:6px}

body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  opacity:.045;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E");
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.serif{font-family:var(--serif)}
.wrap{max-width:1180px;margin:0 auto;padding:0 clamp(20px,5vw,48px)}

/* halftone dot texture (from brand collateral) */
.dots{
  position:absolute;pointer-events:none;
  background-image:radial-gradient(rgba(177,147,79,.35) 1.2px,transparent 1.3px);
  background-size:14px 14px;
  -webkit-mask-image:radial-gradient(closest-side,#000,transparent);
  mask-image:radial-gradient(closest-side,#000,transparent);
}

/* reveal */
.rv{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.22,.8,.3,1),transform .9s cubic-bezier(.22,.8,.3,1)}
.rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.12s}.rv-d2{transition-delay:.24s}.rv-d3{transition-delay:.36s}.rv-d4{transition-delay:.48s}
@media (prefers-reduced-motion:reduce){
  .rv{opacity:1;transform:none;transition:none}
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important}
}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .4s,box-shadow .4s,padding .4s;padding:22px 0}
nav.scrolled{background:rgba(251,248,239,.94);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(51,64,42,.12);padding:12px 0}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand .seal{width:44px;height:44px;flex:none}
.brand-name{font-family:var(--serif);font-weight:700;font-size:1.25rem;letter-spacing:.18em;color:var(--pine)}
.brand-name small{display:block;font-family:var(--sans);font-weight:400;font-size:.62rem;letter-spacing:.5em;color:var(--olive)}
.nav-links{display:flex;gap:clamp(14px,2.6vw,32px);font-size:.95rem;letter-spacing:.12em;font-weight:500}
.nav-links a{position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--gold);transition:width .35s}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--pine);color:var(--cream);padding:12px 26px;border-radius:999px;font-size:.92rem;letter-spacing:.12em;font-weight:500;transition:background .3s,transform .3s}
.nav-cta:hover{background:var(--ink);transform:translateY(-2px)}
@media(max-width:900px){.nav-links{display:none}}

/* ---------- hero ---------- */
header{
  position:relative;min-height:100svh;display:flex;align-items:center;
  background:
    radial-gradient(1200px 600px at 85% 0%,rgba(216,196,140,.28),transparent 60%),
    linear-gradient(165deg,#fbf8ef 0%,#f4eeda 55%,#ece4c9 100%);
  overflow:hidden;
}
header .dots{right:-60px;top:8%;width:420px;height:420px;opacity:.8}
header::after{content:"";position:absolute;left:0;right:0;bottom:0;height:10px;background:var(--pine)}
.hero-grid{
  position:relative;z-index:2;width:100%;
  display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(24px,5vw,72px);
  align-items:center;padding-top:120px;padding-bottom:90px;
}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:.8rem;letter-spacing:.42em;color:var(--gold-deep);font-weight:500;margin-bottom:26px}
.hero-eyebrow::before{content:"";width:44px;height:1px;background:var(--gold)}
h1{font-family:var(--serif);font-weight:900;font-size:clamp(2.9rem,7vw,5.4rem);line-height:1.18;letter-spacing:.08em;color:var(--pine)}
h1 .accent{
  background:linear-gradient(120deg,var(--gold-deep),var(--gold),#c9ab62);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-sub{margin-top:26px;max-width:32em;font-weight:400;font-size:clamp(1.08rem,1.6vw,1.3rem);line-height:1.85;color:#525a41}
.hero-tags{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.hero-tags span{border:1px solid rgba(70,82,54,.35);border-radius:999px;padding:8px 20px;font-size:.92rem;letter-spacing:.2em;color:var(--pine)}
.hero-actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:42px;align-items:center}
.btn{display:inline-flex;align-items:center;gap:10px;padding:17px 38px;border-radius:999px;font-weight:500;letter-spacing:.14em;font-size:1.02rem;transition:transform .3s,box-shadow .3s,background .3s}
.btn-green{background:var(--pine);color:var(--cream);box-shadow:0 14px 34px -12px rgba(51,64,42,.5)}
.btn-green:hover{transform:translateY(-3px);background:var(--ink)}
.btn-gold{background:var(--gold);color:#fffdf6;box-shadow:0 14px 34px -12px rgba(150,121,58,.55)}
.btn-gold:hover{transform:translateY(-3px);background:var(--gold-deep)}
.btn-ghost{border:1px solid rgba(70,82,54,.45);color:var(--pine)}
.btn-ghost:hover{background:rgba(70,82,54,.08);transform:translateY(-3px)}

/* seal visual */
.hero-visual{position:relative;display:flex;justify-content:center}
.seal-ring{
  position:relative;width:clamp(240px,26vw,360px);aspect-ratio:1;border-radius:50%;
  border:1.5px solid rgba(150,121,58,.6);
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 40%,#fffdf6,rgba(255,253,246,0) 70%);
  animation:breathe 7s ease-in-out infinite;
}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.035)}}
.seal-ring::before{content:"";position:absolute;inset:14px;border-radius:50%;border:1px dashed rgba(150,121,58,.45)}
.seal-char{font-family:var(--serif);font-weight:900;font-size:clamp(6rem,11vw,9.5rem);color:var(--pine);text-shadow:0 12px 34px rgba(70,82,54,.25)}
.seal-orbit{position:absolute;inset:-34px;animation:spin 40s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.seal-orbit svg{width:100%;height:100%}
.seal-orbit text{fill:rgba(117,129,90,.75);font-size:11px;letter-spacing:6px;font-family:var(--sans)}
.offer-chip{
  position:absolute;right:-8px;bottom:6px;background:var(--seal-red);color:#f8ede4;
  border-radius:50%;width:122px;height:122px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:var(--serif);transform:rotate(8deg);box-shadow:0 18px 40px -14px rgba(0,0,0,.45);
  animation:chip 5s ease-in-out infinite;text-align:center;
}
@keyframes chip{0%,100%{transform:rotate(8deg) translateY(0)}50%{transform:rotate(5deg) translateY(-8px)}}
.offer-chip b{font-size:1.28rem;line-height:1.25;letter-spacing:.08em}
.offer-chip span{font-size:.66rem;letter-spacing:.16em;margin-top:5px;font-family:var(--sans)}
.hero-vertical{
  position:absolute;top:50%;right:clamp(8px,2vw,34px);transform:translateY(-50%);
  writing-mode:vertical-rl;letter-spacing:.55em;font-family:var(--serif);
  font-size:.95rem;color:rgba(70,82,54,.35);z-index:2;
}
@media(max-width:960px){
  header{min-height:auto}
  .hero-grid{grid-template-columns:1fr;padding-top:118px;padding-bottom:64px}
  .hero-visual{order:1;margin-top:44px}
  .seal-ring{width:236px}
  .seal-orbit{inset:-26px}
  .offer-chip{width:96px;height:96px;right:4%;bottom:-4px}
  .offer-chip b{font-size:1.05rem}
  .offer-chip span{font-size:.6rem}
  .hero-vertical{display:none}
  .hero-actions .btn{width:100%;justify-content:center}
}

/* ---------- section shell ---------- */
section{padding:clamp(80px,10vw,130px) 0;position:relative}
.sec-head{max-width:660px;margin-bottom:clamp(40px,6vw,70px)}
.kicker{display:inline-flex;align-items:center;gap:10px;color:var(--gold-deep);font-size:.82rem;letter-spacing:.42em;font-weight:500;margin-bottom:18px}
.kicker::before{content:"";width:38px;height:1px;background:var(--gold)}
h2{font-family:var(--serif);font-weight:700;font-size:clamp(2.1rem,4.2vw,3.1rem);letter-spacing:.05em;line-height:1.3;color:var(--pine)}
.sec-head p{margin-top:18px;color:#525a41;font-weight:400;font-size:1.08em;max-width:60ch}

/* ---------- services ---------- */
#services{background:var(--paper)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.5vw,32px)}
.svc{
  position:relative;background:var(--card);border-radius:22px;
  padding:clamp(28px,3vw,44px);overflow:hidden;
  border:1px solid rgba(150,121,58,.28);
  transition:transform .45s cubic-bezier(.22,.8,.3,1),box-shadow .45s;
}
.svc:hover{transform:translateY(-10px);box-shadow:var(--shadow)}
.svc .num{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:3.4rem;color:rgba(150,121,58,.22);line-height:1}
.svc h3{font-family:var(--serif);font-size:1.6rem;font-weight:700;margin:14px 0 4px;letter-spacing:.08em;color:var(--pine)}
.svc .en{font-size:.78rem;letter-spacing:.3em;color:var(--gold-deep);text-transform:uppercase;margin-bottom:16px}
.svc p{font-size:1.02rem;color:#525a41;font-weight:400}
.svc ul{list-style:none;margin-top:18px;font-size:.98rem;color:var(--pine)}
.svc li{display:flex;gap:10px;align-items:baseline;padding:5px 0}
.svc li::before{content:"—";color:var(--gold)}
.svc::after{content:"";position:absolute;right:-40px;bottom:-40px;width:150px;height:150px;border-radius:50%;border:1px solid rgba(177,147,79,.35);transition:transform .5s}
.svc:hover::after{transform:scale(1.25)}
@media(max-width:860px){.svc-grid{grid-template-columns:1fr}}

/* ---------- pillars ---------- */
#pillars{background:var(--pine);color:var(--cream)}
#pillars .kicker{color:var(--gold-soft)}#pillars .kicker::before{background:var(--gold-soft)}
#pillars h2{color:var(--cream)}
#pillars .sec-head p{color:rgba(246,241,227,.72)}
.pillar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(246,241,227,.15);border:1px solid rgba(246,241,227,.15)}
.pillar{background:var(--pine);padding:clamp(28px,3vw,44px) clamp(20px,2vw,32px);transition:background .35s}
.pillar:hover{background:#3c4730}
.pillar .glyph{font-size:2rem;margin-bottom:18px;color:var(--gold-soft)}
.pillar h3{font-family:var(--serif);font-size:1.3rem;letter-spacing:.14em;font-weight:600;margin-bottom:10px}
.pillar p{font-size:.98rem;font-weight:400;color:rgba(246,241,227,.82)}
@media(max-width:860px){.pillar-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.pillar-grid{grid-template-columns:1fr}}

/* ---------- audience ---------- */
.aud-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.5vw,32px)}
.aud{border-left:3px solid var(--gold);background:var(--cream);padding:30px 28px;border-radius:0 18px 18px 0;transition:transform .4s,box-shadow .4s}
.aud:hover{transform:translateX(6px);box-shadow:var(--shadow)}
.aud h3{font-family:var(--serif);font-size:1.35rem;font-weight:700;margin-bottom:10px;letter-spacing:.06em;color:var(--pine)}
.aud p{font-size:1rem;color:#525a41;font-weight:400}
@media(max-width:860px){.aud-grid{grid-template-columns:1fr}}

/* ---------- offers ---------- */
#offer{background:linear-gradient(150deg,var(--cream),#ece4c9)}
#offer .dots{left:-80px;bottom:-40px;width:380px;height:380px}
.offer-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.5vw,32px);position:relative;z-index:2}
.ticket{
  position:relative;background:var(--card);border-radius:24px;overflow:hidden;
  border:1.5px solid rgba(150,121,58,.45);box-shadow:var(--shadow);
  padding:clamp(30px,3.5vw,48px);
  display:flex;flex-direction:column;
}
.ticket::before{
  content:"";position:absolute;top:0;bottom:0;left:0;width:10px;
  background:repeating-linear-gradient(to bottom,var(--gold) 0 6px,transparent 6px 14px);
  opacity:.5;
}
.ticket .tk-tag{
  align-self:flex-start;background:var(--pine);color:var(--gold-soft);
  font-size:.8rem;letter-spacing:.34em;padding:7px 18px;border-radius:999px;margin-bottom:22px;font-weight:500;
}
.ticket h3{font-family:var(--serif);font-size:clamp(1.5rem,2.4vw,2rem);font-weight:900;letter-spacing:.1em;color:var(--pine)}
.ticket .tk-price{font-family:var(--serif);font-weight:900;font-size:clamp(2.6rem,4.5vw,3.6rem);line-height:1.1;margin:14px 0 4px}
.tk-price.free{color:var(--gold-deep)}
.tk-price.money{color:var(--pine)}
.tk-price small{font-size:.34em;font-weight:500;letter-spacing:.1em;color:var(--gold-deep)}
.tk-worth{font-size:.95rem;color:#77704f}
.tk-worth s{color:var(--seal-red)}
.ticket ul{list-style:none;margin:22px 0 26px;font-size:1.08rem;color:var(--ink)}
.ticket li{display:flex;gap:12px;align-items:baseline;padding:7px 0;border-bottom:1px dashed rgba(150,121,58,.3)}
.ticket li b{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gold-deep);font-size:1.25rem;flex:none}
.ticket .tk-note{font-size:.88rem;color:#77704f;margin-bottom:22px}
.ticket .btn{margin-top:auto;align-self:flex-start}
.tk-100{
  position:absolute;top:26px;right:26px;width:88px;height:88px;border-radius:50%;
  border:1.5px solid var(--seal-red);color:var(--seal-red);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:var(--serif);transform:rotate(10deg);font-weight:700;
}
.tk-100 b{font-size:1.3rem;line-height:1}
.tk-100 span{font-size:.6rem;letter-spacing:.2em;font-family:var(--sans);margin-top:3px}
.offer-fineprint{margin-top:26px;font-size:.88rem;line-height:1.9;color:#77704f;max-width:72ch;position:relative;z-index:2}
@media(max-width:860px){.offer-grid{grid-template-columns:1fr}}

/* ---------- pricing ---------- */
#pricing{background:var(--paper)}
.price-banner{
  display:inline-flex;align-items:baseline;gap:14px;
  background:var(--pine);color:var(--cream);border-radius:999px;
  padding:12px 32px;margin-bottom:40px;font-family:var(--serif);letter-spacing:.1em;
}
.price-banner s{color:var(--gold-soft)}
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.5vw,32px)}
.plan{
  position:relative;background:var(--card);border:1px solid rgba(150,121,58,.3);
  border-radius:22px;padding:clamp(26px,2.8vw,40px);
  transition:transform .45s cubic-bezier(.22,.8,.3,1),box-shadow .45s,border-color .45s;
  display:flex;flex-direction:column;
}
.plan:hover{transform:translateY(-10px);box-shadow:var(--shadow);border-color:var(--gold)}
.plan.best{border:1.5px solid var(--gold);background:linear-gradient(170deg,#fffdf6,#f6efda)}
.plan .disc{
  align-self:flex-start;background:var(--seal-red);color:#f8ede4;
  font-family:var(--serif);font-weight:700;font-size:1.05rem;letter-spacing:.1em;
  padding:5px 18px;border-radius:999px;margin-bottom:18px;
}
.plan h3{font-family:var(--serif);font-size:1.25rem;font-weight:700;letter-spacing:.08em;color:var(--pine)}
.plan .meta{font-size:.92rem;color:#77704f;margin:12px 0 4px}
.plan .meta s{color:var(--seal-red)}
.plan .per{font-family:var(--serif);font-weight:900;font-size:clamp(2.4rem,4vw,3.2rem);color:var(--pine);line-height:1.15;margin:10px 0 2px}
.plan .per small{font-size:.34em;color:var(--gold-deep);letter-spacing:.08em;font-weight:500}
.plan .total{font-size:1rem;color:#525a41}
.plan ul{list-style:none;margin-top:20px;font-size:.95rem;color:#525a41;font-weight:400}
.plan li{display:flex;gap:10px;align-items:baseline;padding:4px 0}
.plan li::before{content:"✓";color:var(--gold-deep);font-weight:700}
.plan .badge-best{
  position:absolute;top:-14px;right:22px;background:var(--gold);color:#fffdf6;
  font-size:.72rem;letter-spacing:.26em;padding:6px 16px;border-radius:999px;font-weight:500;
  box-shadow:0 10px 22px -8px rgba(150,121,58,.6);
}
.floor-note{
  margin-top:44px;background:var(--pine);color:var(--cream);border-radius:20px;
  padding:clamp(24px,3vw,36px) clamp(24px,4vw,48px);
  display:flex;flex-wrap:wrap;align-items:center;gap:10px 26px;justify-content:center;text-align:center;
  font-family:var(--serif);letter-spacing:.08em;
}
.floor-note .big{font-weight:900;font-size:clamp(2rem,4.5vw,3rem);color:var(--gold-soft)}
.floor-note span{font-size:1.15rem}

/* medical list */
.med{margin-top:clamp(60px,8vw,90px)}
.med-list{display:grid;gap:16px;max-width:820px}
.med-item{
  display:flex;align-items:center;gap:22px;flex-wrap:wrap;
  background:var(--card);border:1px solid rgba(150,121,58,.3);border-radius:999px;
  padding:20px 34px;transition:transform .35s,box-shadow .35s;
}
.med-item:hover{transform:translateX(8px);box-shadow:var(--shadow)}
.med-item .ic{
  width:54px;height:54px;border-radius:50%;background:var(--olive);flex:none;
  display:flex;align-items:center;justify-content:center;color:#fffdf6;font-size:1.4rem;
}
.med-item .t{flex:1;min-width:200px}
.med-item .t h4{font-family:var(--serif);font-size:1.35rem;font-weight:700;letter-spacing:.08em;color:var(--pine)}
.med-item .t small{font-size:.8rem;letter-spacing:.14em;color:#77704f}
.med-item .p{font-family:var(--serif);font-weight:900;font-size:2rem;color:var(--pine);white-space:nowrap}
.med-item .p small{font-size:.5em;color:var(--gold-deep);font-weight:500}
.plan-note{margin-top:22px;font-size:.88rem;line-height:1.9;color:#77704f;max-width:72ch}
@media(max-width:900px){.plan-grid{grid-template-columns:1fr}}

/* ---------- contact ---------- */
#contact{background:var(--ink);color:var(--cream)}
#contact .kicker{color:var(--gold-soft)}#contact .kicker::before{background:var(--gold-soft)}
#contact h2{color:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,70px)}
.c-item{padding:22px 0;border-bottom:1px solid rgba(246,241,227,.15);display:flex;justify-content:space-between;gap:20px;align-items:baseline}
.c-item .label{font-size:.8rem;letter-spacing:.35em;color:var(--gold-soft);flex:none}
.c-item .val{font-weight:400;text-align:right}
.c-item .val a{border-bottom:1px solid var(--gold-soft)}
.wa-panel{background:rgba(246,241,227,.06);border:1px solid rgba(246,241,227,.15);border-radius:24px;padding:clamp(28px,3vw,44px);text-align:center}
.wa-panel h3{font-family:var(--serif);font-size:1.65rem;font-weight:700;letter-spacing:.1em;margin-bottom:12px}
.wa-panel p{font-weight:400;color:rgba(246,241,227,.85);font-size:1.05rem;margin-bottom:28px}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}

/* ---------- footer ---------- */
footer{background:var(--ink);color:rgba(246,241,227,.55);padding:34px 0;border-top:1px solid rgba(246,241,227,.12)}
.foot{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:.9rem;letter-spacing:.12em}

/* floating WhatsApp */
.fab{
  position:fixed;right:22px;bottom:22px;z-index:60;width:58px;height:58px;border-radius:50%;
  background:#22c05a;display:flex;align-items:center;justify-content:center;
  box-shadow:0 16px 34px -10px rgba(0,0,0,.4);transition:transform .3s;
}
.fab:hover{transform:scale(1.1)}
.fab svg{width:30px;height:30px;fill:#fff}

/* ---------- treatment menu numbers ---------- */
.med-item .ic.num{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.15rem;font-weight:600}
.menu-list{max-width:820px}

/* ---------- enquiry form ---------- */
.enquiry{
  margin-top:clamp(40px,6vw,70px);
  background:rgba(246,241,227,.06);border:1px solid rgba(246,241,227,.15);
  border-radius:24px;padding:clamp(28px,4vw,52px);
}
.enquiry h3{font-family:var(--serif);font-size:1.65rem;font-weight:700;letter-spacing:.1em;margin-bottom:10px}
.enquiry>p{font-weight:400;color:rgba(246,241,227,.85);font-size:1.05rem;margin-bottom:30px}
.enquiry form{display:grid;gap:22px;max-width:640px}
.form-row{display:grid;gap:8px}
.form-row label{font-size:.85rem;letter-spacing:.3em;color:var(--gold-soft);font-weight:500}
.form-row input,.form-row textarea{
  font-family:var(--sans);font-size:1.05rem;color:var(--cream);
  background:rgba(251,248,239,.08);border:1px solid rgba(246,241,227,.25);
  border-radius:14px;padding:15px 18px;width:100%;
  transition:border-color .3s,background .3s;
}
.form-row input::placeholder,.form-row textarea::placeholder{color:rgba(246,241,227,.4)}
.form-row input:focus,.form-row textarea:focus{
  outline:none;border-color:var(--gold);background:rgba(251,248,239,.12);
}
.form-row textarea{resize:vertical;min-height:120px}
.enquiry .btn{justify-self:start;border:none;cursor:pointer;font-family:var(--sans)}

/* ---------- mobile refinements ---------- */
@media(max-width:640px){
  /* voucher tickets: keep title clear of the 首100 stamp */
  .tk-100{width:70px;height:70px;top:20px;right:18px}
  .tk-100 b{font-size:1rem}
  .tk-100 span{font-size:.55rem}
  .ticket h3{padding-right:86px}
  .ticket .tk-price{font-size:2.5rem}

  /* price menu: cards, not stretched pills */
  .med-item{
    border-radius:18px;flex-wrap:nowrap;gap:14px;
    padding:16px 18px;
  }
  .med-item:hover{transform:none}
  .med-item .ic{width:42px;height:42px;font-size:1.1rem}
  .med-item .ic.num{font-size:1rem}
  .med-item .t{min-width:0}
  .med-item .t h4{font-size:1.12rem;letter-spacing:.04em}
  .med-item .t small{display:none}
  .med-item .p{font-size:1.45rem}

  /* contact rows: stack label over value, left aligned */
  .c-item{flex-direction:column;align-items:flex-start;gap:6px}
  .c-item .val{text-align:left}

  /* form + panels */
  .enquiry .btn,.wa-panel .btn{width:100%;justify-content:center}
  .offer-grid .btn{width:100%;justify-content:center}

  /* tighter section rhythm on phones */
  section{padding:64px 0}
  .sec-head{margin-bottom:36px}
}
