:root {
  --ink: #17211c;
  --forest: #18221d;
  --forest-soft: #24332b;
  --cream: #f3eee4;
  --paper: #faf7f0;
  --terracotta: #c7773c;
  --gold: #d5a95c;
  --muted: #666e68;
  --line: rgba(23, 33, 28, .16);
  --wrap: min(1180px, calc(100% - 40px));
  --serif: "Iowan Old Style", "Palatino Linotype", "Noto Serif TC", "Songti TC", serif;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans TC", "PingFang TC", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 88px; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--sans); line-height: 1.75; -webkit-font-smoothing: antialiased; }
body.menu-open { overflow: hidden; }
img { display: block; width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
.wrap { width: var(--wrap); margin-inline: auto; }
.section { padding: clamp(88px, 11vw, 150px) 0; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; }
.skip-link { position: fixed; left: 12px; top: -80px; z-index: 1000; padding: 10px 16px; background: white; color: #111; }
.skip-link:focus { top: 12px; }

.site-header { position: fixed; inset: 0 0 auto; z-index: 100; color: white; transition: background .3s, box-shadow .3s; }
.site-header.is-scrolled { background: rgba(24, 34, 29, .94); box-shadow: 0 8px 30px rgba(0, 0, 0, .14); backdrop-filter: blur(16px); }
body.menu-open .site-header { -webkit-backdrop-filter: none; backdrop-filter: none; }
.nav-shell { width: min(1320px, calc(100% - 40px)); height: 82px; margin: auto; display: flex; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; gap: 12px; line-height: 1; }
.brand img { width: 46px; height: 46px; }
.brand span { display: grid; gap: 5px; }
.brand b { font-family: var(--serif); font-size: 23px; font-weight: 700; letter-spacing: .09em; text-shadow: 0 1px 8px rgba(0,0,0,.28); }
.brand small { font-size: 10px; font-weight: 600; letter-spacing: .25em; opacity: .88; }
.site-nav { display: flex; align-items: center; gap: 24px; font-size: 14px; letter-spacing: .08em; }
.site-nav > a:not(.nav-book) { position: relative; }
.site-nav > a:not(.nav-book)::after { content: ""; position: absolute; inset: auto 0 -7px; height: 1px; background: currentColor; transform: scaleX(0); transition: transform .25s; }
.site-nav > a:hover::after, .site-nav > a:focus-visible::after { transform: scaleX(1); }
.nav-book { padding: 11px 19px; border: 1px solid rgba(255,255,255,.6); border-radius: 999px; transition: background .2s, color .2s; }
.nav-book:hover { color: var(--forest); background: white; }
.menu-toggle { display: none; width: 46px; height: 46px; padding: 10px; border: 0; color: white; background: transparent; }
.menu-toggle span:not(.sr-only) { display: block; height: 1px; margin: 6px 0; background: currentColor; transition: transform .2s; }

.hero { min-height: 760px; height: 100svh; position: relative; display: grid; align-items: center; color: white; overflow: hidden; background: var(--forest); }
.hero-media, .hero-media img, .hero-shade { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero-media img { object-fit: cover; object-position: center 48%; }
.hero-shade { background: linear-gradient(90deg, rgba(10,18,13,.82) 0%, rgba(10,18,13,.52) 47%, rgba(10,18,13,.12) 80%), linear-gradient(0deg, rgba(10,18,13,.42), transparent 45%); }
.hero-content { position: relative; z-index: 2; padding-top: 70px; }
.eyebrow { margin: 0 0 23px; color: var(--gold); font-size: 12px; font-weight: 700; letter-spacing: .27em; }
.eyebrow.dark { color: #9a5c30; }
.hero h1, .section-heading h2, .story-copy h2, .booking-band h2 { margin: 0; font-family: var(--serif); font-weight: 500; line-height: 1.16; letter-spacing: .02em; }
.hero h1 { max-width: 850px; font-size: clamp(48px, 7.2vw, 102px); text-wrap: balance; }
.hero h1 em { color: #e1af67; font-style: normal; }
.hero-copy { max-width: 590px; margin: 27px 0 31px; color: rgba(255,255,255,.82); font-size: clamp(16px, 1.8vw, 20px); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 13px; }
.button { min-height: 52px; display: inline-flex; align-items: center; justify-content: center; padding: 13px 25px; border: 1px solid transparent; border-radius: 3px; font-size: 15px; font-weight: 700; letter-spacing: .06em; transition: transform .2s, background .2s; }
.button:hover { transform: translateY(-2px); }
.button-primary { color: white; background: var(--terracotta); }
.button-primary:hover { background: #d48448; }
.button-ghost { border-color: rgba(255,255,255,.55); background: rgba(255,255,255,.04); }
.button-ghost:hover { background: rgba(255,255,255,.12); }
.hero-facts { display: flex; gap: clamp(25px, 5vw, 65px); margin: 48px 0 0; padding: 0; list-style: none; }
.hero-facts li { display: grid; gap: 2px; }
.hero-facts b { color: #e7c487; font-family: var(--serif); font-size: 25px; font-weight: 500; }
.hero-facts span { color: rgba(255,255,255,.62); font-size: 12px; letter-spacing: .08em; }
.scroll-cue { position: absolute; z-index: 3; right: 38px; bottom: 35px; width: 38px; height: 65px; border: 1px solid rgba(255,255,255,.45); border-radius: 999px; }
.scroll-cue span { position: absolute; top: 12px; left: 50%; width: 4px; height: 4px; border-radius: 50%; background: white; animation: scroll 2s infinite; }
@keyframes scroll { 0% { opacity: 0; transform: translate(-50%, 0); } 40% { opacity: 1; } 100% { opacity: 0; transform: translate(-50%, 25px); } }

.intro { background: var(--cream); }
.intro-grid { display: grid; grid-template-columns: .9fr 1.1fr; align-items: start; gap: clamp(45px, 9vw, 130px); }
.section-heading h2, .story-copy h2 { font-size: clamp(38px, 5vw, 66px); }
.intro-copy { padding-top: 25px; border-top: 1px solid var(--line); font-size: clamp(16px, 1.7vw, 19px); }
.intro-copy p:first-child { margin-top: 0; }
.intro-copy p:last-child { color: var(--muted); }
.section-heading.centered { max-width: 720px; margin: 0 auto 55px; text-align: center; }
.section-heading.centered > p:last-child { max-width: 630px; margin: 20px auto 0; color: var(--muted); }

.rooms { background: var(--paper); }
.cabin-exterior { position: relative; margin: 0 0 38px; overflow: hidden; background: var(--forest); }
.cabin-exterior picture { display: block; aspect-ratio: 4/3; }
.cabin-exterior img { height: 100%; object-fit: cover; object-position: center 48%; transition: transform .9s cubic-bezier(.2,.7,.2,1); }
.cabin-exterior:hover img { transform: scale(1.018); }
.cabin-exterior figcaption { position: absolute; right: clamp(20px, 4vw, 55px); bottom: clamp(20px, 4vw, 55px); width: min(440px, calc(100% - 40px)); padding: clamp(27px, 4vw, 43px); color: white; background: rgba(20,31,25,.91); box-shadow: 0 18px 55px rgba(0,0,0,.25); backdrop-filter: blur(10px); }
.cabin-exterior figcaption .eyebrow { margin-bottom: 13px; }
.cabin-exterior h3 { margin: 0 0 17px; font-family: var(--serif); font-size: clamp(30px, 4vw, 45px); font-weight: 500; line-height: 1.22; }
.cabin-exterior figcaption > p:not(.eyebrow) { margin: 0; color: rgba(255,255,255,.72); }
.cabin-exterior ul { display: grid; gap: 8px; margin: 22px 0 0; padding: 18px 0 0; border-top: 1px solid rgba(255,255,255,.16); list-style: none; font-size: 13px; }
.cabin-exterior li::before { content: "—"; margin-right: 9px; color: var(--gold); }
.room-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 25px; }
.room-card { overflow: hidden; background: white; border: 1px solid rgba(23,33,28,.1); box-shadow: 0 18px 45px rgba(32,42,35,.06); }
.room-card picture { display: block; overflow: hidden; aspect-ratio: 3/2; }
.room-card picture img { height: 100%; object-fit: cover; transition: transform .7s cubic-bezier(.2,.7,.2,1); }
.room-card:hover picture img { transform: scale(1.035); }
.room-body { padding: clamp(26px, 4vw, 42px); }
.room-type { margin: 0 0 8px; color: #a06032; font-size: 11px; font-weight: 700; letter-spacing: .18em; }
.room-body h3 { margin: 0 0 12px; font-family: var(--serif); font-size: 31px; font-weight: 500; }
.room-body > p:not(.room-type) { min-height: 58px; color: var(--muted); }
.room-price { display: flex; align-items: baseline; justify-content: space-between; margin: 25px 0; padding: 20px 0; border-block: 1px solid var(--line); }
.room-price span { color: var(--muted); font-size: 13px; }
.room-price b { font-family: var(--serif); font-size: 25px; font-weight: 500; }
.room-body > a { display: flex; justify-content: space-between; color: #a15e30; font-size: 14px; font-weight: 700; }
.price-note { display: flex; flex-wrap: wrap; justify-content: center; gap: 7px 30px; margin-top: 30px; color: var(--muted); font-size: 13px; }
.price-note a { color: #9a5c30; text-decoration: underline; text-underline-offset: 4px; }

.coffee-story { color: white; background: var(--forest); overflow: hidden; }
.story-grid { display: grid; grid-template-columns: 1.05fr .95fr; align-items: center; gap: clamp(55px, 9vw, 125px); }
.story-visual { position: relative; padding: 0 12% 16% 0; }
.story-main { display: block; }
.story-main img { aspect-ratio: 3/2; object-fit: cover; }
.story-small { position: absolute; right: 0; bottom: 0; width: 43%; padding: 8px; background: var(--forest); }
.story-small img { aspect-ratio: 3/2; object-fit: cover; }
.story-copy > p:not(.eyebrow) { color: rgba(255,255,255,.72); }
.feature-list { margin: 35px 0 0; padding: 0; list-style: none; }
.feature-list li { display: flex; gap: 22px; padding: 18px 0; border-top: 1px solid rgba(255,255,255,.14); }
.feature-list li > span { color: var(--gold); font-family: var(--serif); font-size: 18px; }
.feature-list div { display: grid; gap: 2px; }
.feature-list small { color: rgba(255,255,255,.55); }

.view-section { color: white; background: #1d2d38; }
.section-heading.light { max-width: 700px; margin-bottom: 48px; }
.gallery { display: grid; grid-template-columns: 1.4fr 1fr; gap: 18px; }
.gallery picture { display: block; overflow: hidden; }
.gallery img { height: 100%; object-fit: cover; transition: transform .7s; }
.gallery picture:hover img { transform: scale(1.025); }
.gallery-large { grid-row: span 2; min-height: 620px; }

.seasons { background: var(--paper); overflow: hidden; }
.seasons-heading { display: grid; grid-template-columns: 1fr .85fr; align-items: end; gap: 60px; margin-bottom: 50px; }
.seasons-heading > p { max-width: 570px; margin: 0 0 8px; color: var(--muted); font-size: 17px; }
.cloud-panorama { position: relative; margin: 0 0 22px; overflow: hidden; background: #cbd8dd; }
.cloud-panorama picture { display: block; aspect-ratio: 14/5; }
.cloud-panorama img { height: 100%; object-fit: cover; transition: transform .8s cubic-bezier(.2,.7,.2,1); }
.cloud-panorama:hover img { transform: scale(1.015); }
.cloud-panorama figcaption { position: absolute; inset: auto 0 0; display: grid; gap: 5px; padding: 80px 35px 29px; color: white; background: linear-gradient(transparent, rgba(12,24,23,.8)); }
.cloud-panorama small, .season-card small { color: #edc982; font-size: 10px; font-weight: 800; letter-spacing: .2em; }
.cloud-panorama b { max-width: 670px; font-family: var(--serif); font-size: clamp(20px, 3vw, 32px); font-weight: 500; }
.season-grid { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-flow: dense; gap: 22px; }
.season-card { position: relative; min-height: 360px; margin: 0; overflow: hidden; color: white; background: var(--forest); }
.season-card-tall { grid-row: span 2; min-height: 742px; }
.season-card picture, .season-card img { position: absolute; inset: 0; width: 100%; height: 100%; }
.season-card img { object-fit: cover; transition: transform .7s cubic-bezier(.2,.7,.2,1); }
.season-card:hover img { transform: scale(1.035); }
.season-card figcaption { position: absolute; z-index: 1; inset: auto 0 0; display: grid; gap: 3px; padding: 65px 25px 24px; background: linear-gradient(transparent, rgba(5,13,8,.88)); }
.season-card b { font-family: var(--serif); font-size: 25px; font-weight: 600; }
.season-card span { color: rgba(255,255,255,.7); font-size: 13px; }
.season-note { margin: 25px 0 0; color: var(--muted); font-size: 13px; text-align: center; }

.guide { background: var(--cream); }
.guide-grid { display: grid; grid-template-columns: .78fr 1.22fr; gap: clamp(50px, 10vw, 150px); }
.guide-grid .section-heading { position: sticky; top: 120px; align-self: start; }
.text-link { display: inline-block; margin-top: 30px; color: #9a5c30; font-weight: 700; border-bottom: 1px solid currentColor; }
.guide-list { border-top: 1px solid var(--line); }
.guide-list details { border-bottom: 1px solid var(--line); }
.guide-list summary { display: flex; gap: 22px; align-items: center; padding: 25px 8px; cursor: pointer; font-family: var(--serif); font-size: 22px; list-style: none; }
.guide-list summary::-webkit-details-marker { display: none; }
.guide-list summary::after { content: "+"; margin-left: auto; color: #9a5c30; font-family: var(--sans); font-size: 24px; font-weight: 300; }
.guide-list details[open] summary::after { content: "−"; }
.guide-list summary span { color: #a06032; font-family: var(--sans); font-size: 12px; letter-spacing: .1em; }
.guide-list p { margin: -7px 45px 25px; color: var(--muted); }

.booking-band { position: relative; min-height: 590px; display: grid; place-items: center; color: white; text-align: center; overflow: hidden; background: var(--forest); }
.booking-band > picture, .booking-band > picture img, .booking-band-shade { position: absolute; inset: 0; width: 100%; height: 100%; }
.booking-band > picture img { object-fit: cover; }
.booking-band-shade { background: rgba(13,24,17,.7); }
.booking-band-content { position: relative; z-index: 1; max-width: 760px; }
.booking-band h2 { font-size: clamp(39px, 6vw, 72px); }
.booking-band-content > p:not(.eyebrow) { max-width: 580px; margin: 22px auto 30px; color: rgba(255,255,255,.75); }

.contact { background: var(--paper); }
.contact-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(50px, 10vw, 140px); }
.navigation-alert { max-width: 460px; margin-top: 28px; padding-left: 18px; color: #8c4b27; border-left: 3px solid var(--terracotta); }
.contact-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.contact-cards a { min-height: 190px; display: flex; flex-direction: column; padding: 25px; background: var(--cream); border: 1px solid transparent; transition: border .2s, transform .2s; }
.contact-cards a:hover { border-color: #b67242; transform: translateY(-3px); }
.contact-cards small { color: #9a5c30; letter-spacing: .1em; }
.contact-cards b { margin: auto 0; font-family: var(--serif); font-size: clamp(20px, 2.2vw, 27px); font-weight: 500; }
.contact-cards span { color: var(--muted); font-size: 13px; }

.faq { background: #ebe4d7; }
.faq-grid { display: grid; grid-template-columns: .78fr 1.22fr; gap: clamp(50px, 10vw, 150px); }
.faq-intro { max-width: 450px; margin-top: 25px; color: var(--muted); }
.faq-list { border-top: 1px solid var(--line); }
.faq-list article { padding: 27px 4px; border-bottom: 1px solid var(--line); }
.faq-list h3 { margin: 0 0 8px; font-family: var(--serif); font-size: 23px; font-weight: 600; }
.faq-list p { margin: 0; color: var(--muted); }
.faq-list a { color: #96572d; font-weight: 700; text-decoration: underline; text-underline-offset: 4px; }

.site-footer { padding: 75px 0 24px; color: rgba(255,255,255,.72); background: #111a15; }
.footer-grid { display: grid; grid-template-columns: 1.5fr .6fr .7fr; gap: 60px; }
.footer-brand { color: white; }
.footer-grid > div:first-child p { margin-top: 24px; font-size: 13px; }
.footer-links { display: grid; align-content: start; gap: 9px; font-size: 13px; }
.footer-links b { margin-bottom: 11px; color: white; letter-spacing: .12em; }
.footer-links a:hover { color: white; }
.footer-bottom { display: flex; justify-content: space-between; margin-top: 55px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.12); font-size: 11px; letter-spacing: .08em; }
.mobile-book { display: none; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

@media (max-width: 900px) {
  :root { --wrap: min(100% - 34px, 720px); }
  .nav-shell { width: calc(100% - 28px); }
  .menu-toggle { display: block; z-index: 2; }
  .site-nav { position: fixed; inset: 0; display: grid; align-content: center; justify-items: center; gap: 23px; color: white; background: rgba(17,27,21,.985); font-family: var(--serif); font-size: 27px; opacity: 0; visibility: hidden; transform: translateY(-10px); transition: .25s; }
  .site-nav.is-open { opacity: 1; visibility: visible; transform: none; }
  .nav-book { margin-top: 12px; font-family: var(--sans); font-size: 15px; }
  .menu-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .menu-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .intro-grid, .story-grid, .guide-grid, .contact-grid, .faq-grid, .seasons-heading { grid-template-columns: 1fr; }
  .intro-grid, .story-grid { gap: 55px; }
  .seasons-heading { gap: 22px; }
  .season-grid { grid-template-columns: repeat(2, 1fr); }
  .season-card-tall { grid-row: span 2; }
  .room-grid { gap: 17px; }
  .guide-grid .section-heading { position: static; }
  .gallery-large { min-height: 480px; }
  .scroll-cue { display: none; }
}

@media (max-width: 640px) {
  :root { --wrap: calc(100% - 28px); }
  html { scroll-padding-top: 75px; }
  body { padding-bottom: calc(58px + env(safe-area-inset-bottom)); }
  .section { padding: 82px 0; }
  .nav-shell { height: 72px; }
  .brand img { width: 40px; height: 40px; }
  .brand b { font-size: 20px; letter-spacing: .05em; }
  .brand small { font-size: 9px; letter-spacing: .18em; }
  .hero { min-height: 710px; height: 100svh; }
  .hero-media img { object-position: 57% center; }
  .hero-shade { background: linear-gradient(0deg, rgba(10,18,13,.84) 0%, rgba(10,18,13,.44) 73%, rgba(10,18,13,.2)); }
  .hero-content { padding-top: 90px; padding-bottom: calc(78px + env(safe-area-inset-bottom)); align-self: end; }
  .hero h1 { font-size: clamp(45px, 13vw, 62px); }
  .hero-copy { margin-block: 18px 25px; font-size: 16px; }
  .hero-actions .button { width: 100%; }
  .button-ghost { display: none; }
  .hero-facts { gap: 19px; margin-top: 31px; }
  .hero-facts li { flex: 1; }
  .hero-facts b { font-size: 20px; }
  .hero-facts span { font-size: 10px; line-height: 1.4; }
  .section-heading h2, .story-copy h2 { font-size: 39px; }
  .intro-copy { padding-top: 20px; }
  .room-grid { grid-template-columns: 1fr; }
  .cabin-exterior { overflow: visible; background: transparent; }
  .cabin-exterior picture { aspect-ratio: 4/3; overflow: hidden; }
  .cabin-exterior figcaption { position: relative; right: auto; bottom: auto; width: calc(100% - 22px); margin: -42px 11px 0; }
  .room-body > p:not(.room-type) { min-height: 0; }
  .price-note { display: grid; justify-content: start; }
  .story-visual { padding-right: 8%; }
  .gallery { grid-template-columns: 1fr 1fr; gap: 8px; }
  .gallery-large { grid-column: span 2; grid-row: auto; min-height: auto; aspect-ratio: 3/2; }
  .gallery picture:not(.gallery-large) { aspect-ratio: 1/1; }
  .cloud-panorama picture { aspect-ratio: 16/9; }
  .cloud-panorama figcaption { padding: 70px 20px 20px; }
  .season-grid { grid-template-columns: 1fr; gap: 10px; }
  .season-card, .season-card-tall { min-height: 0; aspect-ratio: 3/2; grid-row: auto; }
  .season-card-tall { aspect-ratio: 4/5; }
  .guide-list summary { gap: 14px; padding-inline: 0; font-size: 18px; }
  .guide-list p { margin-left: 34px; margin-right: 10px; }
  .booking-band { min-height: 520px; }
  .contact-cards { grid-template-columns: 1fr; }
  .contact-cards a { min-height: 145px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 45px 30px; }
  .footer-grid > div:first-child { grid-column: span 2; }
  .footer-bottom { margin-top: 45px; }
  .mobile-book { position: fixed; z-index: 90; inset: auto 0 0; height: calc(58px + env(safe-area-inset-bottom)); display: grid; place-items: center; padding-bottom: env(safe-area-inset-bottom); color: white; background: var(--terracotta); font-size: 15px; font-weight: 800; letter-spacing: .05em; box-shadow: 0 -8px 25px rgba(0,0,0,.15); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
