.hotels-page{min-height:100vh;background:#f8f3e6;color:var(--ink, #1a1a2e)}.hotels-hero{padding:132px 2rem 4rem;background:#163b46;color:#fff}.hotels-hero-inner{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:3rem;align-items:center}.hotel-kicker{display:inline-flex;align-items:center;gap:.45rem;color:#c9eadf;font-size:.75rem;font-weight:900;letter-spacing:.13em;text-transform:uppercase}.hotel-kicker .material-symbols-outlined{font-size:18px}.hotels-copy h1{max-width:760px;font-family:"Noto Serif TC",serif;font-size:clamp(2.3rem,5vw,4.4rem);line-height:1.06;margin:.8rem 0 1rem}.hotels-copy p{max-width:660px;color:#ffffffdb;font-size:1.05rem;line-height:1.8}.hotel-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.75rem}.hotel-data-prompt{max-width:660px;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.25rem;padding:.85rem;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff1a}.hotel-data-prompt strong{display:block;color:#f5c15c;font-size:.9rem;margin-bottom:.15rem}.hotel-data-prompt span{display:block;color:#ffffffd1;font-size:.82rem;line-height:1.45}.hotel-data-actions{display:flex;gap:.45rem;flex-shrink:0}.hotel-data-actions a{display:inline-flex;align-items:center;min-height:34px;border:1px solid rgba(255,255,255,.28);border-radius:999px;color:#fff;padding:.25rem .7rem;text-decoration:none;font-size:.8rem;font-weight:900}.hotel-data-actions a:hover{background:#ffffff1f}.hotel-primary,.hotel-secondary{display:inline-flex;align-items:center;gap:.45rem;border-radius:8px;padding:.78rem 1rem;text-decoration:none;font-weight:900}.hotel-primary{background:#f5c15c;color:#1f2d30}.hotel-secondary{border:1px solid rgba(255,255,255,.28);color:#fff}.hotel-primary .material-symbols-outlined,.hotel-secondary .material-symbols-outlined{font-size:18px}.stay-panel{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:1rem;box-shadow:0 28px 80px #00000038}.stay-map{position:relative;height:250px;overflow:hidden;border-radius:8px;background:linear-gradient(135deg,#eaf4ee,#f8efe0)}.stay-map:before{content:"";position:absolute;inset:22px;border:1px solid rgba(22,59,70,.15);background-image:linear-gradient(rgba(22,59,70,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(22,59,70,.08) 1px,transparent 1px);background-size:34px 34px}.map-line{position:absolute;height:7px;border-radius:999px;opacity:.9}.map-red{width:260px;left:54px;top:126px;background:#c0392b;transform:rotate(-16deg)}.map-blue{width:230px;left:78px;top:112px;background:#2e6da4;transform:rotate(35deg)}.station{position:absolute;z-index:2;background:#fff;border:2px solid #163b46;border-radius:999px;padding:.35rem .55rem;color:#163b46;font-size:.72rem;font-weight:900;box-shadow:0 8px 18px #163b4629}.station-main{left:132px;top:108px}.station-east{right:42px;top:78px}.station-north{left:72px;top:34px}.station-west{left:56px;bottom:42px}.stay-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.65rem;margin-top:.75rem}.stay-stats div{background:#ffffff1f;border-radius:8px;padding:.8rem}.stay-stats strong{display:block;font-size:1.35rem;line-height:1;color:#f5c15c}.stay-stats span{display:block;color:#ffffffc7;font-size:.76rem;line-height:1.35;margin-top:.35rem}.hotel-browser{max-width:1120px;margin:0 auto;padding:3rem 2rem 5rem}.browser-head{display:grid;grid-template-columns:1fr minmax(260px,380px);gap:1rem;align-items:end;margin-bottom:1rem}.section-label{color:#b8422e;font-size:.72rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.browser-head h2{font-family:"Noto Serif TC",serif;font-size:clamp(1.7rem,3vw,2.55rem);line-height:1.15;margin-top:.2rem}.hotel-search{min-height:48px;display:flex;align-items:center;gap:.45rem;background:#fff;border:1px solid rgba(22,59,70,.16);border-radius:8px;padding:0 .8rem}.hotel-search .material-symbols-outlined{color:#2e6da4;font-size:20px}.hotel-search input{width:100%;border:0;outline:0;background:transparent;font:inherit;color:#1a1a2e}.hotel-filter-panel{display:grid;gap:.85rem;margin-bottom:1rem}.district-filter{display:flex;gap:.5rem;overflow-x:auto;padding:.25rem 0}.district-chip{flex:0 0 auto;border:1px solid rgba(22,59,70,.18);background:#fff;color:#415157;border-radius:999px;min-height:36px;padding:.35rem .7rem;font:inherit;font-size:.82rem;font-weight:800;cursor:pointer}.district-chip.is-active{background:#163b46;color:#fff;border-color:#163b46}.hotel-select-filters{display:flex;flex-wrap:wrap;gap:.75rem}.hotel-select-filters label{display:grid;gap:.3rem;min-width:180px;color:#546066;font-size:.74rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.hotel-select-filters select{min-height:40px;border:1px solid rgba(22,59,70,.18);border-radius:8px;background:#fff;color:#1a1a2e;padding:0 2rem 0 .7rem;font:inherit;font-size:.86rem;font-weight:800}.hotel-count{color:#6b6256;font-size:.86rem;font-weight:800;margin-bottom:1rem}.hotel-pagination-row{display:flex;justify-content:center;align-items:center;gap:.75rem;padding:1.5rem 0 .5rem}.hotel-page-btn{display:inline-flex;align-items:center;justify-content:center;width:2.4rem;height:2.4rem;border-radius:50%;border:1.5px solid rgba(22,59,70,.3);background:#fff;color:#163b46;font-size:1.4rem;line-height:1;cursor:pointer;transition:all .18s}.hotel-page-btn:hover:not(:disabled){background:#163b46;color:#fff;border-color:#163b46}.hotel-page-btn:disabled{opacity:.3;cursor:default}.hotel-page-info{font-size:.88rem;font-weight:600;color:#1a1a2e8c;min-width:80px;text-align:center}.hotel-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.stay-card{min-height:278px}.stay-card.is-hidden{display:none}.stay-card-link{height:100%;display:flex;flex-direction:column;background:#fff;color:inherit;border:1px solid rgba(22,59,70,.13);border-radius:8px;padding:1rem;text-decoration:none;box-shadow:0 12px 30px #163b4612;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.stay-card-link:hover{transform:translateY(-3px);border-color:#2e6da46b;box-shadow:0 16px 34px #163b461f}.stay-card-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.9rem}.stay-icon{width:38px;height:38px;display:grid;place-items:center;border-radius:8px;background:#eaf3f6;color:#2e6da4}.verified-pill{display:inline-flex;align-items:center;gap:.2rem;color:#1e6b52;background:#edf8f1;border-radius:999px;padding:.26rem .5rem;font-size:.72rem;font-weight:900}.verified-pill .material-symbols-outlined{font-size:14px}.stay-card h3{font-size:1rem;line-height:1.28;margin:0 0 .45rem;color:#163b46}.stay-card p{color:#62584c;font-size:.84rem;line-height:1.55;margin-bottom:.75rem}.stay-meta{display:grid;gap:.35rem;color:#506065;font-size:.78rem}.stay-meta span{display:flex;align-items:center;gap:.3rem;min-width:0}.stay-meta .material-symbols-outlined{color:#2e6da4;font-size:15px;flex:0 0 auto}.stay-card-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:.75rem;border-top:1px solid rgba(22,59,70,.1);padding-top:.8rem;margin-top:auto}.stay-card-bottom strong{display:block;color:#b8422e;font-size:.9rem}.stay-card-bottom em{display:block;margin-top:.15rem;color:#7b7164;font-size:.68rem;font-style:normal;line-height:1.25}.stay-card-bottom span{color:#2e6da4;font-size:.78rem;font-weight:900;white-space:nowrap}@media(max-width:1024px){.hotel-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.hotels-hero-inner{gap:2rem}.hotel-select-filters label{min-width:140px}}@media(max-width:980px){.hotels-hero-inner{grid-template-columns:1fr}.stay-panel{max-width:100%}.hotel-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hotels-copy h1{font-size:clamp(1.8rem,5vw,3rem)}.hotel-actions{flex-wrap:wrap}.stay-map{height:160px}}@media(max-width:768px){.hotels-hero{padding:110px 1.5rem 3rem}.hotel-browser{padding:2rem 1.5rem 4rem}.browser-head{grid-template-columns:1fr;gap:.75rem}.hotel-select-filters{gap:.5rem}.hotel-select-filters label{min-width:calc(50% - .25rem);flex:1 1 calc(50% - .25rem)}.hotel-select-filters select{width:100%}.stay-stats{grid-template-columns:repeat(3,1fr);gap:.75rem}}@media(max-width:680px){.hotels-hero{padding:100px 1.25rem 2.5rem}.hotel-browser{padding:1.75rem 1.25rem 3.5rem}.browser-head,.hotel-grid{grid-template-columns:1fr}.hotel-data-prompt{align-items:flex-start;flex-direction:column}.stay-stats{grid-template-columns:1fr}.hotel-select-filters label{min-width:100%;flex:1 1 100%}.stay-card{min-height:unset}}@media(max-width:420px){.hotels-hero{padding:90px 1rem 2rem}.hotel-browser{padding:1.5rem 1rem 3rem}.district-filter{gap:.35rem}.district-chip{font-size:.75rem;padding:.28rem .55rem}.stay-card-link{padding:.85rem}.hotel-actions{flex-direction:column}.hotel-primary,.hotel-secondary{width:100%;justify-content:center}.hotel-page-btn{width:2.4rem}}
