@import "https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Manrope:wght@400;500;600;700;800&family=Noto+Sans+TC:wght@400;500;700;900&display=swap";:root{--bg:#f4efe7;--bg-strong:#e9e2d6;--surface:#fffcf6d1;--surface-strong:#fffdf8;--surface-soft:#ffffff8f;--text:#18130d;--muted:#655b50;--muted-strong:#473f37;--line:#18130d1a;--line-strong:#18130d29;--shadow-lg:0 28px 72px #2c1c0824;--shadow-md:0 16px 36px #2c1c081c;--shadow-sm:0 10px 20px #2c1c0814;--radius-xl:34px;--radius-lg:24px;--radius-md:18px;--radius-sm:14px;--container:min(1180px, calc(100vw - 40px));--font-display:"Fraunces", "Noto Sans TC", serif;--font-sans:"Manrope", "Noto Sans TC", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%}html{background:var(--bg)}body{color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 0 0,#ffffffd6,#0000 30%),linear-gradient(#f8f4ee 0%,#f4efe7 40%,#efe7dc 100%)}body:before{content:"";pointer-events:none;opacity:.55;background-image:linear-gradient(#5a462d06 1px,#0000 1px),linear-gradient(90deg,#5a462d06 1px,#0000 1px);background-size:32px 32px;position:fixed;inset:0}button,input,textarea,select{font:inherit}button{cursor:pointer;background:0 0;border:0}button:disabled{cursor:not-allowed}img{width:100%;display:block}a{color:inherit}.app-shell{min-height:100vh;position:relative}.app-shell--inner{flex-direction:column;display:flex}.inner-scroll{flex:1}.page-container{width:var(--container);margin:0 auto}.eyebrow{letter-spacing:.16em;text-transform:uppercase;font-size:.76rem;font-weight:800}.section-heading{max-width:720px}.section-heading h2,.landing-final-cta h2,.trip-overview__main h2{font-family:var(--font-display);letter-spacing:-.04em;margin-top:14px;font-size:clamp(2rem,3.4vw,3.2rem);line-height:.96}.section-heading p:last-child,.landing-final-cta p:last-child,.trip-overview__body,.cta-panel__body,.trip-hero__story,.destination-story__description,.destination-story__lead,.day-panel__heading p,.region-card p,.attraction-card__details p,.empty-block p,.state-screen__card p{color:var(--muted);line-height:1.72}.state-screen{place-items:center;min-height:100vh;padding:24px;display:grid}.state-screen__card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface-strong);width:min(100%,520px);box-shadow:var(--shadow-md);padding:28px}.state-screen__card h1{font-family:var(--font-display);margin-top:12px;font-size:clamp(2rem,5vw,3rem);line-height:.95}.state-screen__card p:last-child{margin-top:12px}.site-header{z-index:20;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#f4efe7b8;border-bottom:1px solid #18130d0f;position:sticky;top:0}.site-header__inner{width:var(--container);justify-content:space-between;align-items:center;gap:20px;min-height:74px;margin:0 auto;display:flex}.site-header__brand{align-items:center;gap:16px;min-width:0;display:flex}.site-header__seal{background:#18130d12;border-radius:999px;place-items:center;width:44px;height:44px;font-weight:800;display:inline-grid}.site-header__eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-size:.72rem;font-weight:800}.site-header__title{flex-wrap:wrap;align-items:center;gap:10px;min-width:0;font-size:.96rem;font-weight:700;display:flex}.site-header__dot{background:#18130d3d;border-radius:999px;width:4px;height:4px}.button-shell{display:inline-flex}.pill-button{border-radius:999px;align-items:center;gap:10px;padding:12px 18px;font-size:.94rem;font-weight:700;transition:transform .2s,background-color .2s,border-color .2s;display:inline-flex}.pill-button:hover,.day-panel__header:hover,.destination-story:hover,.attraction-card:hover{transform:translateY(-2px)}.pill-button--ghost{color:var(--text);background:#ffffff9e;border:1px solid #18130d14}.pill-button--accent{color:#f8fbfb;background:#204e53}.language-menu{position:relative}.language-menu__panel{background:var(--surface-strong);border:1px solid var(--line);width:180px;box-shadow:var(--shadow-sm);border-radius:18px;padding:8px;position:absolute;top:calc(100% + 10px);right:0}.language-menu__option{text-align:left;border-radius:12px;justify-content:space-between;align-items:center;width:100%;padding:11px 12px;display:flex}.language-menu__option:hover,.language-menu__option--active{background:#18130d0f}.language-menu__abbr{color:var(--muted);font-size:.82rem}.landing-page,.trip-page{z-index:1;position:relative}.landing-hero,.trip-hero{background:#17120d;position:relative;overflow:hidden}.landing-hero{min-height:calc(100svh - 74px)}.trip-hero{min-height:min(78svh,760px)}.landing-hero__backdrop,.trip-hero__media,.trip-hero__veil{position:absolute;inset:0}.landing-hero__backdrop,.trip-hero__media img{animation:16s ease-out both hero-zoom}.trip-hero__media img{object-fit:cover;height:100%}.landing-hero__backdrop{background:radial-gradient(circle at 18% 18%,#fff1d738,#0000 24%),radial-gradient(circle at 82% 22%,#5e89904d,#0000 26%),radial-gradient(circle at 50% 78%,#f4d4a533,#0000 30%),linear-gradient(140deg,#17120d 0%,#20353a 42%,#46655c 100%)}.trip-hero__veil{background:linear-gradient(#0d0a083d 0%,#0d0a08c7 100%),linear-gradient(90deg,#0d0a08ad 0%,#0d0a0833 48%,#0d0a088a 100%)}.landing-hero__content,.trip-hero__content{z-index:1;position:relative}.landing-hero__content{align-items:flex-end;min-height:calc(100svh - 74px);padding:104px 0 56px;animation:.9s both fade-up;display:flex}.trip-hero__content{grid-template-columns:minmax(0,1fr) minmax(280px,.46fr);align-items:end;gap:24px;min-height:min(78svh,760px);padding:120px 0 44px;display:grid}.landing-hero__copy,.trip-hero__copy{color:#fff8ee;max-width:48rem}.landing-hero__content--brand .landing-hero__copy{max-width:42rem}.landing-hero__eyebrow{color:#fff8eebd}.landing-hero__brand{letter-spacing:-.08em;font-size:clamp(3.6rem,10vw,7.5rem);line-height:.84;font-family:var(--font-display);margin-top:10px;font-weight:600}.landing-hero__copy h1,.trip-hero__copy h1{font-family:var(--font-display);letter-spacing:-.05em;text-wrap:balance;margin-top:18px;font-size:clamp(2.4rem,5vw,5rem);line-height:.9}.landing-hero__body{color:#fff7ecd1;max-width:34rem;margin-top:18px;font-size:clamp(1.02rem,1.8vw,1.2rem)}.trip-hero__story{color:#fff7ecd1;max-width:40ch;margin-top:18px}.landing-hero__actions{flex-wrap:wrap;gap:12px;margin-top:30px;display:flex}.trip-stats{gap:12px;display:grid}.trip-stat{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffcf61f;border:1px solid #fffcf626;border-radius:24px;gap:6px;padding:18px 20px;display:grid}.trip-stat__value{color:#fff7eb;letter-spacing:-.06em;font-size:2rem;font-weight:800;line-height:1}.trip-stat__value--date{letter-spacing:-.03em;font-size:1.2rem}.trip-stat__label{color:#fff7ecb8;font-size:.86rem}.landing-section{padding:88px 0 0}.destination-stories{gap:30px;margin-top:40px;display:grid}.destination-story{cursor:pointer;outline:none;grid-template-columns:minmax(0,1.02fr) minmax(340px,.98fr);align-items:stretch;gap:28px;display:grid}.destination-story--reverse{grid-template-columns:minmax(340px,.98fr) minmax(0,1.02fr)}.destination-story--reverse .destination-story__visual{order:2}.destination-story--reverse .destination-story__content{order:1}.destination-story:focus-visible{outline-offset:10px;outline:2px solid #204e5366}.destination-story__visual{border-radius:var(--radius-xl);min-height:420px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.destination-story__visual:after{content:"";background:linear-gradient(#0a08061a 0%,#0a080673 100%);position:absolute;inset:0}.destination-story__visual img{object-fit:cover;height:100%;transition:transform .35s}.destination-story:hover .destination-story__visual img{transform:scale(1.03)}.destination-story__badge{z-index:1;color:#fffaf2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#140f0b52;border-radius:999px;padding:10px 14px;font-size:.78rem;font-weight:700;position:absolute;top:18px;left:18px}.destination-story__content{border-radius:var(--radius-xl);background:linear-gradient(180deg, var(--story-soft) 0%, #fffcf6eb 100%);box-shadow:var(--shadow-md);border:1px solid #18130d14;gap:18px;padding:28px;display:grid}.destination-story__content h3{font-family:var(--font-display);letter-spacing:-.04em;font-size:clamp(1.95rem,3.5vw,3rem);line-height:.95}.destination-story__lead{color:var(--muted-strong);font-size:1.05rem}.destination-story__facts,.destination-story__tripline,.destination-story__footer,.site-footer__inner,.trip-overview__summary,.trip-overview__main,.cta-panel,.cta-panel__actions,.trip-footer-cta,.summary-chip,.day-panel__heading,.day-panel__header,.attraction-card__meta,.trip-overview,.cta-panel__actions,.landing-final-cta__actions{display:flex}.destination-story__facts,.attraction-card__meta{flex-wrap:wrap;gap:10px}.destination-story__facts span,.destination-story__tripline span{color:var(--muted-strong);background:#fff9;border-radius:999px;align-items:center;gap:6px;padding:8px 12px;font-size:.88rem;display:inline-flex}.destination-story__tripline{flex-wrap:wrap;align-items:center;gap:10px}.destination-story__tripline strong{font-size:1rem}.destination-story__footer{justify-content:space-between;align-items:center;margin-top:auto;padding-top:4px;font-weight:800}.destination-story__arrow{font-size:1.25rem}.landing-final-cta{border-radius:var(--radius-xl);background:linear-gradient(135deg, #1c4e531f, #ffffffc2), var(--surface-strong);box-shadow:var(--shadow-md);border:1px solid #18130d14;padding:34px}.landing-final-cta p:last-child{margin-top:16px}.landing-final-cta__actions{gap:12px;margin-top:26px}.trip-overview,.trip-footer-cta{padding-top:44px}.trip-overview{gap:28px;display:grid}.trip-overview__main{flex-direction:column;gap:16px}.trip-overview__summary{flex-wrap:wrap;gap:14px}.summary-chip{background:var(--surface);border:1px solid var(--line);min-height:112px;box-shadow:var(--shadow-sm);border-radius:20px;flex-direction:column;flex:220px;gap:8px;padding:18px}.summary-chip span{color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-size:.82rem;font-weight:800}.summary-chip strong{font-size:1rem;line-height:1.45}.route-flow{box-shadow:var(--shadow-md);background:radial-gradient(circle at 18% 18%,#fff8eee0,#0000 22%),radial-gradient(circle at 84% 24%,#4d7c8129,#0000 28%),linear-gradient(160deg,#204e531f,#ffffffe6 46%,#fffbf5fa 100%);border:1px solid #204e531a;border-radius:28px;padding:28px;position:relative;overflow:hidden}.route-flow__header{max-width:46rem}.route-flow__header h3{font-family:var(--font-display);letter-spacing:-.04em;margin-top:12px;font-size:clamp(1.8rem,3vw,2.6rem);line-height:.98}.route-flow__header p:last-child{color:var(--muted);margin-top:14px;line-height:1.72}.route-flow__canvas{background:radial-gradient(circle,#fff9,#0000 48%),linear-gradient(#ffffffb8,#f0eae2b8);border:1px solid #18130d14;border-radius:24px;min-height:520px;margin-top:26px;position:relative}.route-flow__glow{filter:blur(24px);opacity:.5;border-radius:999px;position:absolute}.route-flow__glow--one{background:#41767c33;width:180px;height:180px;top:14%;left:12%}.route-flow__glow--two{background:#d0ab742e;width:220px;height:220px;bottom:16%;right:10%}.route-flow__path{width:100%;height:100%;position:absolute;inset:0}.route-flow__path path{fill:none;stroke:#204e537a;stroke-width:1.15px;stroke-linecap:round;stroke-dasharray:6 4}.route-node{left:var(--node-x);top:var(--node-y);justify-items:center;gap:10px;min-width:140px;display:grid;position:absolute;transform:translate(-50%,-50%)}.route-node--above .route-node__label{order:-1}.route-node__dot{background:#204e53;border-radius:999px;width:16px;height:16px;transition:transform .18s,box-shadow .18s,background-color .18s;box-shadow:0 0 0 8px #204e531f}.route-node__label{box-shadow:var(--shadow-sm);background:#fffcf6e6;border:1px solid #18130d14;border-radius:18px;gap:4px;padding:10px 12px;display:grid}.route-node__label strong{font-size:.96rem;line-height:1.1}.route-node__label span{color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-size:.76rem;font-weight:800}.route-node:hover .route-node__dot,.route-node:focus-visible .route-node__dot,.route-node--active .route-node__dot{background:#17393d;transform:scale(1.14);box-shadow:0 0 0 12px #204e532e}.route-node:hover .route-node__label,.route-node:focus-visible .route-node__label,.route-node--active .route-node__label{background:#fffffffa;border-color:#204e5333}.route-flow__footer{gap:14px;margin-top:20px;display:grid}.route-flow__summary{background:#ffffffbd;border:1px solid #18130d14;border-radius:20px;gap:8px;padding:16px 18px;display:grid}.route-flow__summary span,.route-flow__legend{color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-size:.82rem;font-weight:800}.route-flow__summary strong{font-size:1.05rem;line-height:1.2}.route-flow__summary p{color:var(--muted);line-height:1.72}.cta-panel{box-shadow:var(--shadow-sm);background:linear-gradient(#204e5324,#ffffffdb);border:1px solid #204e531f;border-radius:24px;justify-content:space-between;align-items:center;gap:20px;padding:22px 24px}.cta-panel--compact{margin-bottom:32px}.cta-panel h2{font-family:var(--font-display);letter-spacing:-.04em;margin-top:10px;font-size:clamp(1.7rem,3vw,2.4rem);line-height:.98}.cta-panel__body{max-width:52ch;margin-top:10px}.cta-panel__actions{flex-shrink:0;align-items:center;gap:12px}.cta-panel__price{background:#18130d14;border-radius:999px;justify-content:center;align-items:center;min-width:72px;padding:12px 14px;font-weight:800;display:inline-flex}.cta-button{color:#f8fbfb;background:#204e53;border-radius:999px;justify-content:center;align-items:center;min-height:48px;padding:0 18px;font-weight:800;display:inline-flex}.cta-button:disabled{opacity:.86}.day-list{padding-top:54px}.day-list__items{gap:18px;margin-top:32px;display:grid}.day-panel{background:var(--surface-strong);box-shadow:var(--shadow-sm);border:1px solid #18130d14;border-radius:26px;overflow:hidden}.day-panel--open{box-shadow:var(--shadow-md)}.day-panel--highlighted{border-color:#204e533d;box-shadow:0 18px 36px #204e531f}.day-panel__header{text-align:left;justify-content:space-between;align-items:flex-start;gap:16px;width:100%;padding:24px}.day-panel__heading{align-items:flex-start;gap:18px}.day-panel__index{background:#18130d0f;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;min-width:78px;padding:10px 12px;font-weight:800;display:inline-flex}.day-panel__heading h3{font-family:var(--font-display);letter-spacing:-.03em;font-size:clamp(1.65rem,3vw,2.2rem);line-height:.98}.day-panel__heading p{max-width:64ch;margin-top:10px}.day-panel__toggle{background:#18130d0f;border-radius:999px;flex-shrink:0;place-items:center;width:42px;height:42px;font-size:1.5rem;line-height:1;display:inline-grid}.day-panel__content{padding:0 24px 24px}.day-section+.day-section{margin-top:26px}.region-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.region-card{background:#18130d08;border:1px solid #18130d14;border-radius:20px;padding:18px}.region-card h4,.attraction-card h4{font-size:1.05rem}.region-card h4,.region-card p:last-child{margin-top:10px}.attraction-list{gap:14px;display:grid}.attraction-card{background:#ffffffb8;border:1px solid #18130d14;border-radius:20px;grid-template-columns:minmax(220px,280px) minmax(0,1fr);transition:transform .2s,box-shadow .2s;display:grid;overflow:hidden}.attraction-card__media{background:linear-gradient(#18130d14,#18130d29);min-height:220px;position:relative}.attraction-card__media img,.attraction-card__placeholder{width:100%;height:100%}.attraction-card__media img{object-fit:cover}.attraction-card__placeholder{background:radial-gradient(circle at 30% 24%,#ffffff5c,#0000 18%),linear-gradient(160deg,#204e5347,#18130d29);place-items:center;display:grid}.attraction-card__placeholder span{font-size:2.3rem}.attraction-card__content{gap:16px;padding:20px;display:grid}.attraction-card__headline{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.attraction-card__title{align-items:flex-start;gap:14px;display:flex}.attraction-card__emoji{flex-shrink:0;margin-top:2px;font-size:1.35rem;line-height:1}.attraction-card__title h4{font-family:var(--font-display);letter-spacing:-.02em;font-size:clamp(1.15rem,2vw,1.45rem);line-height:1}.attraction-card__meta{color:var(--muted);font-size:.88rem}.attraction-tag{border-radius:999px;align-items:center;padding:7px 10px;font-weight:800;display:inline-flex}.attraction-tag--fee{color:var(--muted-strong);background:#18130d14}.attraction-tag--fee-free{color:#1a4c34;background:#23543b1f}.attraction-tag--fee-paid{color:#76421b;background:#74421b1f}.attraction-card__details{gap:16px;display:grid}.attraction-card__note{color:var(--muted-strong);background:#18130d0a;border:1px solid #18130d0f;border-radius:16px;padding:13px 14px}.detail-label{color:var(--muted);letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px;font-size:.76rem;font-weight:800}.empty-block{background:#18130d0a;border:1px dashed #18130d24;border-radius:20px;padding:20px}.site-footer{padding:18px 0 40px}.site-footer__inner{color:var(--muted);justify-content:space-between;align-items:center;gap:16px;font-size:.92rem}@keyframes fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes hero-zoom{0%{transform:scale(1.06)}to{transform:scale(1)}}@media (width<=980px){.landing-hero__content,.trip-hero__content,.destination-story,.destination-story--reverse{grid-template-columns:1fr}.destination-story--reverse .destination-story__visual,.destination-story--reverse .destination-story__content{order:initial}.trip-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.region-grid{grid-template-columns:1fr}.route-flow{padding:22px}.route-flow__canvas{min-height:620px}.route-node{min-width:116px}.route-node__label{padding:9px 10px}.cta-panel{flex-direction:column;align-items:flex-start}.cta-panel__actions{justify-content:space-between;width:100%}.attraction-card{grid-template-columns:1fr}.attraction-card__media{min-height:240px}}@media (width<=720px){:root{--container:min(100vw - 24px, 1000px)}.site-header__inner{min-height:68px}.landing-hero,.landing-hero__content{min-height:calc(100svh - 68px)}.landing-hero__content,.trip-hero__content{padding-top:88px}.landing-hero__brand{font-size:clamp(3rem,14vw,5rem)}.landing-hero__copy h1,.trip-hero__copy h1{font-size:clamp(2rem,9vw,3.6rem)}.route-flow__canvas{min-height:740px}.route-node{min-width:102px}.route-node__label strong{font-size:.88rem}.day-panel__header{padding:18px}.day-panel__heading{flex-direction:column;gap:12px}.attraction-card__content{padding:18px}.attraction-card__media{min-height:220px}.site-footer__inner{flex-direction:column;align-items:flex-start}}
