:root{--teal-50:#f6ecff;--teal-100:#e4ccff;--teal-500:#a63afa;--teal-600:#920bfa;--teal-700:#7409c7;--brand-50:#f6ecff;--brand-100:#e4ccff;--brand-500:#a63afa;--brand-600:#920bfa;--brand-700:#7409c7;--ink-900:#0f1b2d;--ink-700:#334155;--ink-500:#64748b;--ink-300:#cbd5e1;--amber-500:#f59e0b;--rose-500:#e11d48;--surface:#fff;--bg:#f6f8fb}*{-webkit-font-smoothing:antialiased}html,body{height:100%;color:var(--ink-900);background:var(--bg);margin:0;font-family:Roboto,system-ui,-apple-system,Segoe UI,sans-serif}.nav-currency{color:var(--ink-700);background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:.82rem;display:inline-flex}.nav-currency i{color:var(--teal-600);font-size:.8rem}.nav-currency-select{font:inherit;color:inherit;cursor:pointer;appearance:none;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23475569'><path d='M7 10l5 5 5-5z'/></svg>") 100%/14px 14px no-repeat;border:none;outline:none;padding:0 16px 0 0;font-weight:500}.nav-currency-select:focus{outline:none}.nav-currency-slot{display:inline-flex}.text-teal{color:var(--teal-600)!important}.bg-teal{background-color:var(--teal-600)!important}.btn-teal{background-color:var(--teal-600);color:#fff;border:none}.btn-teal:hover{background-color:var(--teal-700);color:#fff}.brand-text{letter-spacing:-.02em;color:var(--ink-900);font-size:1.2rem}.app-main{grid-template-columns:1fr;height:calc(100vh - 57px);display:grid;overflow:hidden}@media (width>=768px){.app-main{grid-template-columns:1fr 1fr}}.hotels-pane{background:var(--bg);border-right:1px solid #e5e7eb;flex-direction:column;min-height:0;display:flex}.hotel-list{scroll-behavior:smooth;flex:1;min-height:0;overflow-y:auto}.map-pane{height:100%;min-height:400px;position:relative}#map{width:100%;height:100%}#map .leaflet-tile-pane{filter:hue-rotate(235deg)saturate(.9)brightness(.98)}.poi-marker{background:0 0;border:none}.poi-dot{background:var(--brand-600);border:2px solid #fff;border-radius:50%;width:10px;height:10px;box-shadow:0 2px 4px #00000040}.leaflet-tooltip.poi-tooltip{color:#fff;background:#0f1b2deb;border:none;border-radius:6px;padding:3px 8px;font-family:Roboto,sans-serif;font-size:.72rem;font-weight:600;box-shadow:0 2px 6px #0003}.leaflet-tooltip.poi-tooltip:before{display:none}.hotel-card{background:var(--surface);cursor:pointer;border:1px solid #0000;border-radius:16px;grid-template-columns:180px 1fr;height:200px;margin-bottom:14px;transition:transform .18s,box-shadow .18s,border-color .18s;display:grid;overflow:hidden;box-shadow:0 1px 2px #0f1b2d0a,0 4px 12px #0f1b2d0a}.hotel-card:hover,.hotel-card.is-active{border-color:var(--teal-500);transform:translateY(-2px);box-shadow:0 8px 24px #0f1b2d1a}.hotel-card .thumb{background-color:#e5e7eb;background-position:50%;background-size:cover;position:relative}.hotel-card .thumb .fav{width:32px;height:32px;color:var(--rose-500);cursor:pointer;background:#fffffff2;border-radius:50%;justify-content:center;align-items:center;transition:transform .15s;display:flex;position:absolute;top:10px;right:10px;box-shadow:0 2px 6px #00000026}.hotel-card .thumb .fav:hover{transform:scale(1.1)}.hotel-card .thumb .fav.active i{font-weight:900}.hotel-card .body{grid-template-rows:auto auto 1fr auto;gap:4px;min-width:0;padding:14px 16px;display:grid}.hotel-card h6{color:var(--ink-900);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1rem;font-weight:700;overflow:hidden}.hotel-card .location{color:var(--ink-500);align-items:center;gap:4px;font-size:.8rem;display:flex}.hotel-card .stars{color:var(--amber-500);letter-spacing:1px;font-size:.75rem}.hotel-card .score-chip{background:var(--teal-50);color:var(--teal-700);border-radius:8px;align-items:center;gap:6px;padding:2px 8px;font-size:.78rem;font-weight:700;display:inline-flex}.hotel-card .score-chip .num{background:var(--teal-600);color:#fff;border-radius:6px;padding:1px 6px;font-size:.72rem}.pills{flex-wrap:wrap;gap:4px;max-height:48px;margin-top:4px;display:flex;overflow:hidden}.pill{color:var(--ink-700);white-space:nowrap;background:#f1f5f9;border-radius:999px;align-items:center;gap:4px;padding:3px 8px;font-size:.7rem;display:inline-flex}.pill.policy{color:#047857;background:#ecfdf5}.pill.amenity{color:#1d4ed8;background:#eff6ff}.price-row{justify-content:space-between;align-items:end;margin-top:auto;display:flex}.price-row .meta{color:var(--ink-500);font-size:.7rem}.price-row .price{color:var(--ink-900);letter-spacing:-.02em;font-size:1.15rem;font-weight:800;line-height:1}.price-row .price-sub{color:var(--ink-500);font-size:.7rem;font-weight:500}.search-area-btn{z-index:500;border-radius:999px;padding:10px 20px;font-size:.9rem;font-weight:600;position:absolute;top:16px;left:50%;transform:translate(-50%)}.price-marker-wrap{background:0 0;border:none}.price-marker{border:1.5px solid var(--ink-900);color:var(--ink-900);white-space:nowrap;background:#fff;border-radius:999px;padding:5px 10px;font-family:Roboto,sans-serif;font-size:.8rem;font-weight:700;transition:all .15s;display:inline-block;box-shadow:0 2px 6px #0000002e}.price-marker:hover,.price-marker.active{background:var(--ink-900);color:#fff;transform:scale(1.08)}.leaflet-popup-content-wrapper{border-radius:12px;padding:0;overflow:hidden}.leaflet-popup-content{margin:0;font-family:Roboto,sans-serif;width:240px!important}.popup-card img{object-fit:cover;width:100%;height:120px;display:block}.popup-card .pc-body{padding:10px 12px}.popup-card h6{margin:0 0 2px;font-size:.9rem;font-weight:700}.popup-card .pc-price{font-size:1rem;font-weight:800}.hotel-list::-webkit-scrollbar{width:8px}.hotel-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:10px}.empty-state{text-align:center;color:var(--ink-500);padding:48px 16px}.empty-state i{color:var(--ink-300);margin-bottom:8px;font-size:2.5rem}.search-card{z-index:20;background:#fff;border-bottom:1px solid #e5e7eb;padding:12px 16px;position:relative}.search-card-inner{background:#f6f8fb;border:1px solid #e5e7eb;border-radius:14px;grid-template-columns:1.5fr 1fr 1fr 1.1fr auto;align-items:stretch;gap:8px;padding:6px;display:grid}.sc-field{background:#fff;border:1px solid #0000;border-radius:10px;min-width:0;padding:8px 12px;transition:border-color .15s,box-shadow .15s;position:relative}.sc-field:focus-within{border-color:var(--teal-500);box-shadow:0 0 0 3px #0ea5a01f}.sc-field label{color:var(--ink-500);text-transform:uppercase;letter-spacing:.03em;align-items:center;gap:6px;margin-bottom:2px;font-size:.7rem;font-weight:600;display:flex}.sc-field input,.sc-guests-btn{width:100%;color:var(--ink-900);text-align:left;background:0 0;border:none;outline:none;justify-content:space-between;align-items:center;padding:0;font-size:.9rem;font-weight:600;display:flex}.sc-field input::placeholder{color:var(--ink-500);font-weight:500}.sc-suggest{z-index:60;background:#fff;border:1px solid #e5e7eb;border-radius:12px;max-height:220px;margin-top:6px;display:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 12px 28px #0f1b2d24}.sc-suggest.show{display:block}.sc-suggest-item{cursor:pointer;color:var(--ink-900);align-items:center;gap:8px;padding:10px 14px;font-size:.88rem;display:flex}.sc-suggest-item:hover,.sc-suggest-item.active{background:var(--teal-50)}.sc-guests-pop{z-index:60;background:#fff;border:1px solid #e5e7eb;border-radius:12px;width:260px;margin-top:6px;padding:14px;display:none;position:absolute;top:100%;right:0;box-shadow:0 12px 28px #0f1b2d24}.sc-guests-pop.show{display:block}.gr-row{justify-content:space-between;align-items:center;padding:8px 0;display:flex}.stepper{align-items:center;gap:10px;display:inline-flex}.stepper button{border:1px solid var(--ink-300);width:28px;height:28px;color:var(--ink-700);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:.7rem;display:inline-flex}.stepper button:hover:not(:disabled){border-color:var(--teal-500);color:var(--teal-600)}.stepper button:disabled{opacity:.4;cursor:not-allowed}.stepper span{text-align:center;min-width:20px;font-weight:700}.sc-daterange{cursor:pointer}.sc-daterange input{cursor:pointer;font-weight:600}.calendar-pop{z-index:70;background:#fff;border:1px solid #e5e7eb;border-radius:16px;width:340px;max-width:calc(100vw - 24px);margin-top:10px;padding:18px 20px;font-family:Roboto,sans-serif;display:none;position:absolute;top:100%;left:50%;transform:translate(-50%);box-shadow:0 20px 40px #0f1b2d2e}.calendar-pop.show{display:block}.cal-header{margin-bottom:12px}.cal-legs{background:#f8fafc;border-radius:12px;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;padding:6px;display:grid}.cal-leg{cursor:pointer;background:0 0;border-radius:10px;padding:8px 12px;transition:background .15s}.cal-leg.active{background:#fff;box-shadow:0 2px 8px #0f1b2d14}.cal-leg-label{color:var(--ink-500);text-transform:uppercase;letter-spacing:.04em;font-size:.65rem;font-weight:600}.cal-leg-val{color:var(--ink-900);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:700;overflow:hidden}.cal-arrow{color:var(--ink-300);font-size:.75rem}.cal-nav{justify-content:space-between;align-items:center;padding:0 6px 10px;display:flex}.cal-nav-btn{width:32px;height:32px;color:var(--ink-700);cursor:pointer;background:#f1f5f9;border:none;border-radius:50%;transition:background .15s}.cal-nav-btn:hover{background:var(--teal-50);color:var(--teal-700)}.cal-title{color:var(--ink-900);letter-spacing:-.01em;font-size:.95rem;font-weight:700}.cal-dow{grid-template-columns:repeat(7,1fr);gap:2px;padding:0 2px 6px;display:grid}.cal-dow span{text-align:center;color:var(--ink-500);text-transform:uppercase;letter-spacing:.05em;padding:4px 0;font-size:.68rem;font-weight:700}.cal-grid{background:#f8fafc;border-radius:10px;grid-template-columns:repeat(7,1fr);gap:2px;padding:6px;display:grid}.cal-day{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:8px;height:38px;padding:0;font-family:inherit;font-size:.85rem;font-weight:600;transition:background .12s,color .12s;position:relative}.cal-day:hover:not(:disabled):not(.muted){background:var(--teal-50);color:var(--teal-700)}.cal-day.muted{color:#e2e8f0;pointer-events:none}.cal-day.past{color:#e2e8f0;cursor:not-allowed;text-decoration:line-through}.cal-day.today{color:var(--teal-700)}.cal-day.today:after{content:"";background:var(--teal-600);border-radius:50%;width:4px;height:4px;position:absolute;bottom:6px;left:50%;transform:translate(-50%)}.cal-day.in-range{background:var(--teal-50);color:var(--teal-700);border-radius:0}.cal-day.range-start,.cal-day.range-end{background:var(--teal-600);color:#fff!important}.cal-day.range-start{border-radius:8px 0 0 8px}.cal-day.range-end{border-radius:0 8px 8px 0}.cal-day.range-start.single,.cal-day.range-end.single{border-radius:8px}.cal-day.today:after,.cal-day.range-start:after,.cal-day.range-end:after{background:#fff}.cal-footer{border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;margin-top:10px;padding-top:14px;display:flex}.cal-clear{color:var(--ink-700);cursor:pointer;background:0 0;border:none;padding:4px 2px;font-size:.85rem;font-weight:600;text-decoration:underline}.cal-clear:hover{color:var(--ink-900)}.cal-apply{background:var(--ink-900);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 18px;font-size:.85rem;font-weight:700}.cal-apply:hover{background:#000}.search-card-peek{width:calc(100% - 16px);color:var(--ink-900);cursor:pointer;text-align:left;background:#fff;border:1px solid #e5e7eb;border-radius:999px;align-items:center;gap:10px;margin:8px;padding:10px 16px;font-size:.85rem;font-weight:600;display:none;box-shadow:0 6px 16px #0f1b2d1f}.search-card-peek i.fa-magnifying-glass{color:var(--teal-600)}.search-card-peek span{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.sc-search-btn{background:var(--teal-600);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:0 18px;font-size:.9rem;font-weight:700;transition:background .15s}.sc-search-btn:hover{background:var(--teal-700)}@media (width<=991.98px){.search-card-inner{grid-template-columns:1fr 1fr;grid-auto-rows:auto}.sc-location{grid-column:1/-1}.sc-search-btn{grid-column:1/-1;padding:10px}}.reset-view-btn{z-index:1100;background:var(--ink-900);color:#fff;border:none;border-radius:999px;align-items:center;gap:6px;padding:8px 16px;font-size:.82rem;font-weight:600;display:none;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 6px 18px #0f1b2d4d}.reset-view-btn.show{display:inline-flex}.reset-view-btn.top{top:72px}.reset-view-btn.bottom{bottom:20px}@media (width<=767.98px){.hotel-card{grid-template-columns:120px 1fr;height:160px}body.sheet-not-full .search-card{z-index:1200;border:1px solid #e5e7eb;border-radius:14px;padding:8px;position:fixed;top:65px;left:8px;right:8px;box-shadow:0 10px 24px #0f1b2d29}body.card-minimized .search-card{display:none}body.card-minimized.sheet-not-full .search-card-peek{z-index:1200;width:auto;margin:0;animation:.22s peekSlide;display:flex;position:fixed;top:65px;left:8px;right:8px}body.card-minimized:not(.sheet-not-full) .search-card-peek{z-index:15;width:calc(100% - 16px);margin:8px;animation:.22s peekSlide;display:flex;position:sticky;top:0}body.card-minimized:not(.sheet-not-full) .search-card{display:none}@keyframes peekSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}body.sheet-not-full #hotelsPane .sheet-handle,body.sheet-not-full #hotelsPane .hotels-pane-header{position:relative}.search-card-inner{gap:4px;padding:4px}.sc-field{padding:6px 10px}.sc-field label{font-size:.62rem}.sc-field input,.sc-guests-btn{font-size:.8rem}.app-main{height:calc(100vh - 57px);display:block;position:relative;overflow:hidden}.map-pane{height:100%;min-height:0;position:absolute;inset:0}.hotels-pane{background:var(--bg);z-index:1000;touch-action:none;border-top:1px solid #e5e7eb;border-right:none;border-radius:20px 20px 0 0;height:50%;transition:height .28s cubic-bezier(.22,.61,.36,1);position:absolute;bottom:0;left:0;right:0;box-shadow:0 -8px 24px #0f1b2d1f}.hotels-pane.dragging{transition:none}.hotels-pane.snap-full{height:100%}.hotels-pane.snap-collapsed{height:80px}.hotels-pane.snap-collapsed .hotel-list,.hotels-pane.snap-collapsed .hotels-pane-header>div>div:first-child small,.hotels-pane.snap-collapsed .dropdown{display:none}.hotels-pane.snap-collapsed .hotels-pane-header{background:0 0;border-bottom:none;padding:10px 16px!important}.sheet-handle{cursor:grab;touch-action:none;justify-content:center;align-items:center;padding:8px 0 4px;display:flex}.sheet-handle:before{content:"";background:#cbd5e1;border-radius:999px;width:44px;height:5px}.sheet-handle:active{cursor:grabbing}}@media (width>=768px){.sheet-handle{display:none}}.view-rooms-btn{background:var(--teal-600);color:#fff;cursor:pointer;border:none;border-radius:10px;width:calc(100% - 16px);margin:10px 8px 4px;padding:8px 14px;font-size:.9rem;font-weight:600;transition:background .15s,transform .15s}.view-rooms-btn:hover{background:var(--teal-700);transform:translateY(-1px)}.popup-view-btn{background:var(--teal-600);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:8px;padding:6px 10px;font-size:.8rem;font-weight:600}.popup-view-btn:hover{background:var(--teal-700)}.pagination-wrap{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;padding:16px 4px 24px;display:flex}.pagination-wrap .page-btn{min-width:36px;height:36px;color:var(--ink-700);cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;padding:0 10px;font-size:.85rem;font-weight:600;transition:background .15s,border-color .15s,color .15s,transform .15s;display:inline-flex}.pagination-wrap .page-btn:hover:not(:disabled):not(.active){background:var(--bg);border-color:var(--ink-300)}.pagination-wrap .page-btn.active{background:var(--teal-600);border-color:var(--teal-600);color:#fff}.pagination-wrap .page-btn:disabled{opacity:.45;cursor:not-allowed}.pagination-wrap .page-btn i{font-size:.75rem}
