:root{color:#2d332b;background:#fbfaf6;font-family:Inter,Noto Sans TC,PingFang TC,Microsoft JhengHei,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;background:#fbfaf6}button,input,select,textarea{font:inherit}button,a{-webkit-tap-highlight-color:transparent}button{border:0;cursor:pointer}a{color:inherit;text-decoration:none}.appShell{min-height:100vh}.siteHeader{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:16px;width:100%;padding:10px clamp(16px,4vw,44px);border-bottom:1px solid #e8e1d3;background:#fbfaf6f0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.brandButton{display:flex;flex:0 0 auto;align-items:center;gap:10px;min-width:0;padding:0;color:#2f3d31;background:transparent;text-align:left}.brandButton img{display:block;width:54px;height:46px;flex:0 0 auto;border-radius:6px;background:transparent;object-fit:contain;object-position:center}.brandButton span{display:grid;gap:1px}.brandButton strong{font-size:16px;line-height:1.15;white-space:nowrap}.brandButton small{color:#7a756a;font-size:11px;line-height:1.1;white-space:nowrap}.navBar{display:flex;flex:1 1 auto;gap:4px;overflow-x:auto;padding:4px 0 4px 2px;scrollbar-width:thin}.navBar button{flex:0 0 auto;border-radius:999px;padding:9px 13px;color:#516052;background:transparent;font-size:14px;line-height:1;white-space:nowrap}.navBar button.active,.navBar button:hover{color:#fff;background:#6f815f}main{min-height:calc(100vh - 148px)}.heroPage{position:relative;display:grid;min-height:calc(100vh - 66px);padding-bottom:28px;overflow:hidden;background-color:#fbfaf6;background-image:linear-gradient(90deg,#ffffffd6,#ffffffc2 42%,#ffffffa8),url(/hero-spa.png);background-position:center,center;background-repeat:no-repeat;background-size:cover,cover}.heroOverlay{position:relative;z-index:1;align-self:center;width:min(640px,calc(100% - 32px));margin:54px 0 120px clamp(16px,7vw,86px)}.eyebrow{margin:0 0 10px;color:#718060;font-size:12px;font-weight:700;letter-spacing:0;text-transform:uppercase}h1,h2,p{margin-top:0}.visuallyHidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.heroBrandImage{display:block;width:min(310px,100%);height:auto;max-height:380px;margin:0 0 18px;object-fit:contain;object-position:left center}.heroLocalName{margin-bottom:10px;color:#374335;font-size:22px;font-weight:800;line-height:1.25}.heroText{max-width:520px;margin-bottom:24px;color:#4c554b;font-size:18px;line-height:1.7}.heroActions,.detailActions{display:flex;flex-wrap:wrap;gap:10px}.heroActions button,.detailActions button,.detailActions a,.primaryLink,.stackForm button,.productCard button,.orderSummary button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;border-radius:8px;padding:11px 16px;color:#fff;background:#627353;font-weight:700;line-height:1.2}.heroActions .secondary,.detailActions .secondary,.orderSummary .secondary{color:#354134;background:#efe7d8}.quickBand{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;align-self:end;width:min(1080px,calc(100% - 32px));margin:0 auto;overflow:hidden;border:1px solid #e5ddcf;border-radius:8px;background:#e5ddcf}.quickAction{display:grid;grid-template-columns:auto 1fr;grid-template-areas:"icon title" "icon text";gap:2px 10px;min-height:82px;padding:16px;color:#344034;background:#ffffffd6;text-align:left}.quickAction span{grid-area:icon;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;color:#5d714f;background:#edf2e8}.quickAction strong{grid-area:title;font-size:16px}.quickAction small{grid-area:text;color:#747266;font-size:13px}.pageSection{width:min(1120px,calc(100% - 32px));margin:0 auto;padding:42px 0 60px}.pageTitle{max-width:720px;margin-bottom:24px}.pageTitle h1{margin-bottom:10px;color:#2f3c31;font-size:clamp(30px,5vw,48px);line-height:1.15}.pageTitle p:last-child{color:#5f675b;font-size:16px;line-height:1.7}.bookingLayout,.contactLayout,.detailLayout,.checkoutLayout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:18px;align-items:start}.panel,.noticeCard,.serviceCard,.productCard,.detailPanel,.orderSummary,.instagramPanel,.qrBlock{border:1px solid #e7dece;border-radius:8px;background:#fffdf9;box-shadow:0 14px 36px #584b3214}.panel,.detailPanel,.orderSummary,.instagramPanel,.qrBlock{padding:22px}.calendarHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.calendarHeader h2,.bookingSide h2,.orderSummary h2{margin-bottom:0;color:#2f3c31}.legend{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px 12px;color:#666b5f;font-size:13px}.statusDot{display:inline-block;width:10px;height:10px;border-radius:50%}.statusDot.available{background:#cfe5cf}.statusDot.full{background:#f0cbc6}.statusDot.closed{background:#e6e3dc}.weekdayGrid,.calendarGrid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.weekdayGrid{margin-bottom:8px;color:#7b776d;font-size:13px;text-align:center}.calendarBlank,.calendarDay{aspect-ratio:1;min-width:0}.calendarDay{display:grid;place-items:center;gap:3px;border:1px solid transparent;border-radius:8px;padding:5px;color:#344034;font-size:13px;line-height:1.1}.calendarDay strong{font-size:17px}.calendarDay small{color:#5c6258;font-size:11px}.calendarDay.available{background:#dcebd9}.calendarDay.full{background:#f2d7d3}.calendarDay.closed{background:#ece9e2;color:#8d887d}.calendarDay.selected{border-color:#576a4b;outline:2px solid rgba(98,115,83,.22)}.calendarDay:disabled{cursor:not-allowed}.selectedMeta,.successMessage{display:inline-flex;align-items:center;gap:8px;color:#4d5a48}.slotList{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:14px 0 20px}.slotList button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;border:1px solid #d9dfd1;border-radius:8px;color:#3f493d;background:#f7faf4}.slotList button.selected{color:#fff;background:#6f815f}.stackForm{display:grid;gap:12px}.stackForm label{display:grid;gap:7px;color:#3f493d;font-weight:700}.stackForm input,.stackForm select,.stackForm textarea{width:100%;border:1px solid #d8d1c2;border-radius:8px;padding:11px 12px;color:#2f352f;background:#fff}.stackForm input:disabled,.stackForm select:disabled,.stackForm textarea:disabled{color:#8d887d;background:#f0eee8}.stackForm button:disabled{cursor:not-allowed;opacity:.55}.successMessage{margin:2px 0 0;border-radius:8px;padding:12px;background:#e8f2e3;font-weight:700;line-height:1.5}.muted{color:#6d7068;line-height:1.7}.noticeGrid,.cardGrid,.productGrid{display:grid;gap:14px}.noticeGrid{grid-template-columns:repeat(5,minmax(0,1fr))}.noticeCard{padding:18px}.noticeCard h2{margin-bottom:10px;color:#334034;font-size:18px}.noticeCard p{margin-bottom:0;color:#5b6259;line-height:1.7}.noticeCard.warning{border-color:#e7c5b9;background:#fff6f1}.cardGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.serviceCard{padding:22px}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;color:#526348;background:#edf2e8;font-size:12px;font-weight:700}.serviceCard h2,.productCard h2{margin:14px 0 8px;color:#303b31}.serviceCard p,.productCard p{color:#5f675b;line-height:1.65}.metaRow{display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px;margin:14px 0;color:#4b5745;font-weight:800}.tagRow{display:flex;flex-wrap:wrap;gap:7px}.tagRow span{border:1px solid #e2dbce;border-radius:999px;padding:5px 9px;color:#686b60;background:#fffaf1;font-size:12px}.productGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.productCard{display:grid;grid-template-columns:170px minmax(0,1fr);overflow:hidden}.productCard img{width:100%;height:100%;min-height:250px;object-fit:cover;background:#f2eee6}.productCard div{padding:18px}.productCard button{width:100%}.detailPage{padding-top:28px}.textButton{display:inline-flex;align-items:center;gap:8px;margin-bottom:18px;padding:0;color:#607451;background:transparent;font-weight:800}.detailImage{width:100%;min-height:420px;border:1px solid #e7dece;border-radius:8px;object-fit:cover;background:#f2eee6}.detailPanel h1{margin:12px 0 8px;color:#303b31;font-size:clamp(30px,5vw,46px);line-height:1.15}.detailPrice{color:#687b58;font-size:24px;font-weight:900}.detailPanel p{color:#596258;line-height:1.7}.detailInfo{border-top:1px solid #e7dece;margin-top:20px;padding-top:16px}.detailInfo h2{margin:14px 0 6px;color:#344034;font-size:17px}.detailActions a{background:#718563}.checkoutLayout{grid-template-columns:minmax(0,1fr) 360px}.checkoutForm{border:1px solid #e7dece;border-radius:8px;padding:22px;background:#fffdf9}.summaryItem,.summaryTotal{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid #ebe2d6;padding:12px 0;color:#4d574b}.summaryTotal{border-bottom:0;font-size:18px}.contactLayout{grid-template-columns:minmax(0,1fr) 320px}.qrBlock{display:grid;place-items:center;gap:12px}.qrPattern{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;width:190px;height:190px;border:8px solid #fff;background:#f5f1e9;box-shadow:0 0 0 1px #d8d1c2}.qrPattern span{border-radius:2px;background:#faf8f2}.qrPattern span.filled{background:#5f7154}.qrBlock p{margin-bottom:0;color:#5b6259;font-weight:800}.instagramPanel{display:grid;justify-items:start;max-width:520px;gap:10px}.instagramPanel svg{color:#647b58}.instagramPanel h2{margin:0;color:#303b31}.siteFooter{display:flex;justify-content:space-between;gap:16px;padding:24px clamp(16px,4vw,44px) 46px;border-top:1px solid #e8e1d3;color:#5d6359;background:#f5f0e7;font-size:13px}.siteFooter div{display:flex;flex-wrap:wrap;gap:8px 14px}.buildBadge{position:fixed;right:10px;bottom:10px;z-index:30;border:1px solid #ded6c8;border-radius:999px;padding:6px 10px;color:#65705f;background:#fffdf9eb;font-size:11px;box-shadow:0 8px 20px #52442c1f}@media(max-width:980px){.siteHeader{align-items:flex-start;flex-direction:column;gap:8px}.navBar{width:100%}.heroPage{min-height:calc(100vh - 112px)}.heroOverlay{margin-top:42px;margin-bottom:130px}.bookingLayout,.contactLayout,.detailLayout,.checkoutLayout,.noticeGrid,.cardGrid,.productGrid{grid-template-columns:1fr}.noticeGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:680px){.siteHeader{padding:9px 14px}.brandButton{gap:8px}.brandButton img{width:46px;height:40px}.brandButton strong{font-size:15px}.navBar button{flex:1 1 calc(33.333% - 6px);min-width:94px;padding:9px 11px;font-size:13px}.navBar{flex-wrap:wrap;gap:6px;overflow-x:visible}.heroPage{background-image:linear-gradient(180deg,#ffffffe6,#ffffffc7 58%,#ffffffb3),url(/hero-spa.png);background-position:center,center;background-size:cover,cover}.heroOverlay{width:min(100% - 28px,560px);margin:34px auto 138px}.heroBrandImage{width:min(220px,62vw);max-height:270px;margin-bottom:16px}.heroLocalName{font-size:20px}.heroText{font-size:16px}.quickBand{grid-template-columns:1fr}.quickAction{min-height:74px}.pageSection{width:min(100% - 28px,1120px);padding-top:30px}.calendarHeader{display:grid}.legend{justify-content:flex-start}.weekdayGrid,.calendarGrid{gap:4px}.calendarDay{border-radius:6px;padding:3px}.calendarDay strong{font-size:15px}.calendarDay small{font-size:10px}.slotList,.noticeGrid,.productCard{grid-template-columns:1fr}.productCard img{min-height:220px}.detailImage{min-height:300px}.siteFooter{display:grid;padding-bottom:52px}}
