/* Search page */
:root{--bg:#ffffff;--card:#ffffff;--accent:#0066d6;--muted:#6b7280;--muted-2:#9aa6b2;--accent-2:#0b84ff;--radius:12px;--max-width:1500px;--gap:18px;--touch:48px;font-family:'Inter',system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}*{box-sizing:border-box}.modify{display:none}.container{max-width:var(--max-width);margin:28px auto;padding:20px}.results-top{display:flex;gap:12px;align-items:center;justify-content:space-between;margin-bottom:18px}.results-list{min-height:60vh}.results-left{display:flex;flex-direction:column;gap:6px}.results-left h1{margin:0;font-size:20px;color:#2d5f7a}.results-left .sub{color:var(--muted);font-size:13px}.results-actions{display:flex;gap:8px;align-items:center}.btn{padding:8px 12px;border-radius:10px;border:1px solid #e6e9ee;background:#fff;cursor:pointer;font-weight:600}.btn.ghost{background:#fff0;transition:all 0.3s ease}.btn.primary{background:#2d5f7a;color:#fff;border:0}.controls{display:flex;gap:8px;align-items:center}.btn.ghost:hover{background:#transparent;transform:scale(1.05)}.results-grid{gap:var(--gap);align-items:start}.filters{background:var(--card);padding:14px;border-radius:12px;border:1px solid #eef3f8;margin-bottom:1em}.filters h4{margin:0 0 10px 0;font-size:15px}.filter-group{margin-bottom:12px}.filter-group label{display:block;font-size:13px;color:var(--muted);margin-bottom:8px}.filter-group input[type="text"],.filter-group select{width:100%;padding:8px;border-radius:8px;border:1px solid #e6e9ee}.result-actions{display:flex;gap:8px}.result-item .ymt-btn{padding:8px 10px;border-radius:8px;font-size:14px}.map-card{background:linear-gradient(180deg,#fff,#fbfdff);padding:12px;border-radius:12px;border:1px solid #eef3f8;min-height:220px;display:flex;align-items:center;justify-content:center;color:var(--muted-2)}.empty{background:var(--card);padding:28px;border-radius:12px;border:1px dashed #e6eef8;text-align:center;color:var(--muted)}@media (max-width:1000px){.results-grid{grid-template-columns:1fr;align-items:stretch}.filters{order:2}.map-card{min-height:160px}}@media (max-width:520px){.container{padding:12px;margin:12px auto}.results-top{flex-direction:column;align-items:stretch;gap:10px}.controls{justify-content:space-between}.filters{padding:12px;border-radius:10px}.results-list{order:1}.result-item{grid-template-columns:120px 1fr;grid-template-areas:"img main" "img side";align-items:start}.result-side{grid-area:side;text-align:left;align-items:flex-start}.result-item img{width:120px;height:90px}.btn{width:100%}.controls .btn{width:auto}}.muted{color:var(--muted)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.results-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;margin-bottom:12px;padding:8px 12px;background:#fff0;min-width:0}.results-count{color:#6b7280;font-size:13px;font-weight:600}.sort-controls{display:flex;gap:10px;align-items:center;min-width:0}.sort-group{display:flex;gap:8px;align-items:center;background:#fff0}.sort-btn,.sort-default-btn{--bg:#fff;--fg:#2d5f7a;--border:#e6eef7;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--bg);color:var(--fg);font-weight:700;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;min-width:64px;justify-content:center;transition:all 160ms ease;box-shadow:0 1px 0 rgb(15 23 42 / .03)}.sort-btn[aria-pressed="false"]{opacity:.95}.sort-btn[aria-pressed="true"]{background:#2d5f7a;color:#fff;border-color:#fff;box-shadow:0 8px 20px rgb(3 44 100 / .12)}.sort-btn[data-sort-dir="asc"]::after{content:"▲";font-size:11px;opacity:.95;margin-left:6px}.sort-btn[data-sort-dir="desc"]::after{content:"▼";font-size:11px;opacity:.95;margin-left:6px}.sort-default-btn{background:#fff0;border:1px dashed #e6eef7;color:#2d5f7a;font-weight:600}.sort-default-btn:hover{background:#fbfdff}.sort-btn:focus,.sort-default-btn:focus{outline:3px solid rgb(11 132 255 / .14);outline-offset:2px}@media (max-width:520px){.results-toolbar{flex-direction:column;align-items:flex-start;gap:8px;padding:6px 10px}.sort-controls{width:100%;justify-content:space-between}.sort-group{flex-wrap:wrap;gap:6px}.sort-btn{padding:8px 10px;font-size:13px;min-width:96px}}.visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap;border:0;padding:0;margin:-1px}.sort-mobile{display:none}.sort-group{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.sort-btn{min-width:84px;padding:8px 12px;height:40px}@media (max-width:900px){.sort-btn{min-width:72px;padding:7px 10px;font-size:13px}.results-toolbar{padding:8px 10px;gap:10px}}@media (max-width:520px){.results-toolbar{flex-direction:column;align-items:stretch;gap:8px;padding:8px 10px}.sort-controls{display:flex;gap:8px;align-items:center;justify-content:space-between;width:100%}.sort-group{display:none}.sort-mobile{display:block;width:100%}#sort-mobile-select{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e6eef7;background:#fff;font-weight:700;color:#0f172a;box-shadow:0 1px 0 rgb(15 23 42 / .03)}.sort-extra{margin-left:0;display:flex;gap:8px;align-items:center}.sort-default-btn{padding:8px 10px;height:40px}}.hidden{display:none!important}.image-popup-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgb(0 0 0 / .8);justify-content:center;align-items:center;z-index:9999}.image-popup-overlay img{max-width:90%;max-height:90%;border-radius:8px;box-shadow:0 0 20px rgb(0 0 0 / .6)}#popupImg{max-width:40%;max-height:40%;width:auto;height:auto;object-fit:contain;border-radius:12px;box-shadow:0 4px 12px rgb(0 0 0 / .3)}@media (max-width:520px){#popupImg{max-width:80%;max-height:80%}}.popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgb(0 0 0 / .5);display:none;align-items:center;justify-content:center;z-index:9999}.popup-content{background:#fff;padding:20px;border-radius:12px;box-shadow:0 4px 12px rgb(0 0 0 / .3);width:300px;text-align:center}.popup-content input{width:100%;padding:10px;margin-bottom:12px;border:1px solid #ccc;border-radius:8px;box-sizing:border-box}.loading-bar-wrap{width:100%;box-sizing:border-box;display:flex;flex-direction:column;gap:8px;align-items:stretch;padding:6px 0}.loading-bar-track{position:relative;height:10px;background:linear-gradient(90deg,#f3f7ff,#eef6ff);border-radius:999px;overflow:hidden;border:1px solid rgb(14 39 77 / .04)}.loading-bar-fill{position:absolute;left:0;top:0;bottom:0;width:0%;background:linear-gradient(90deg,#0b84ff,#0052b4);border-radius:999px;transition:width 420ms cubic-bezier(.2,.9,.2,1);box-shadow:0 6px 18px rgb(6 60 130 / .08)}.loading-bar-indeterminate{position:absolute;left:-40%;top:0;bottom:0;width:40%;background:linear-gradient(90deg,rgb(255 255 255 / .06),#fff0);pointer-events:none;transform:skewX(-12deg);opacity:0}@keyframes indeterminate-move{0%{left:-40%;opacity:1}50%{left:40%;opacity:1}100%{left:110%;opacity:0}}.loading-bar-label{font-size:13px;color:#0b2340;font-weight:700;opacity:.95;line-height:1}.loading-bar-wrap.indeterminate .loading-bar-indeterminate{animation:indeterminate-move 1.1s linear infinite;opacity:1}.loading-bar-wrap.indeterminate .loading-bar-fill{transition:none;width:0%;opacity:0}.sort-controls{display:flex;flex-direction:row;align-items:center;gap:8px}.sort-group{order:1;width:auto}.sort-extra{order:2;width:auto;margin-top:0}@media(max-width:520px){.sort-controls{display:flex;flex-direction:row;align-items:center;gap:8px}.sort-group{order:1;width:auto}.sort-extra{order:2;width:auto;margin-top:0}}

/* Route div */ 
.result-item.timeline-5row{display:grid;grid-template-columns:92px 1fr 200px;gap:16px;align-items:start;padding:12px;border-radius:12px;background:#fff;border:1px solid #eef3f7;margin-bottom:12px;width:100%;box-shadow:0 4px 8px rgb(0 0 0 / .3)}.result-logo{width:92px;height:72px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:1px solid #eef3f7;overflow:hidden;background:#f5f5f5}.result-logo img{max-width:78%;max-height:78%;object-fit:contain;display:block}.result-main{display:flex;flex-direction:column;gap:10px;min-width:70%}.route-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.route-title{font-weight:700;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-meta{color:#6b7280;font-size:13px}.timeline-5{display:flex;flex-direction:column;gap:6px}.tl-row{align-items:center;gap:8px;min-width:0}.tl-left{display:flex;align-items:center;gap:8px;min-width:0}.tl-dot{width:10px;height:10px;border-radius:50%;background:#0b84ff;box-shadow:0 0 0 4px rgb(11 132 255 / .07);flex-shrink:0}.tl-time{font-weight:700;font-size:14px;white-space:nowrap}.tl-connector{display:flex;align-items:center;justify-content:center}.v-line{width:2px;background:linear-gradient(#e6eef8,#dfeaf7);border-radius:2px;margin:0 auto;margin-left:4px}.v-line.short{height:8px}.v-line.long{height:36px}.tl-right{min-width:0}.tl-station{color:#6b7280;font-size:13px;white-space:nowrap}.tl-row-1 .tl-station{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.duration{font-size:13px;color:#6b7280;background:#f8fafc;padding:4px 8px;border-radius:8px;display:inline-block}.extras{color:#6b7280;font-size:13px}.child-price{font-size:.8em}.result-side{display:flex;flex-direction:column;align-items:flex-end;gap:8px;min-width:0}.price-row{display:flex;gap:8px;align-items:center}.price{font-weight:800;color:#2d5f7a;font-size:16px;white-space:nowrap}.result-actions{display:flex;gap:8px;margin-top:6px}.btn{padding:8px 12px;border-radius:10px;border:1px solid #e6e9ee;background:#fff;font-weight:600;cursor:pointer;text-decoration:none;color:inherit;display:inline-flex;align-items:center;justify-content:center}.btn.primary{background:#2d5f7a;color:#fff;border:0;transition:all 0.3s ease}.btn.select{background:#37b004;color:#fff;border:0;transition:all 0.3s ease}.btn.sold-out{background-color:#ff4d4d;color:#FFF;pointer-events:none;opacity:.6;pointer-events:none}.btn.not-available{background-color:gray;color:#FFF;pointer-events:none;opacity:.6;pointer-events:none}.btn.not-open{background-color:#FFAC1C;color:#FFF;opacity:.6}.btn.primary:hover{background:#1f4d66;transform:scale(1.05)}.btn.select:hover{background:#37b004;transform:scale(1.05)}.sold-out{background-color:#ff4d4d;color:#000;pointer-events:none;opacity:.6;cursor:}.not-available{background-color:gray;color:#000;pointer-events:none;opacity:.6;pointer-events:none}.no-online-sale{background-color:gray;pointer-events:none;color:#FFF;opacity:.6;cursor:}.sale-close{background-color:gray;color:#000;pointer-events:none;opacity:.6;cursor:}.result-expand{grid-column:1/-1;margin-top:12px;padding:12px;border-radius:10px;border:1px solid #eef3f7;background:linear-gradient(180deg,#fff,#fbfdff);display:none}.result-expand.open{display:block}.result-expand{grid-column:1 / -1;margin-top:12px;padding:12px;border-radius:10px;border:1px solid #eef3f7;display:none;box-sizing:border-box;min-width:0}.result-expand.open{display:block}.fares-list{display:flex;flex-direction:column;gap:10px}.fare{display:flex;gap:12px;align-items:center;padding:10px;border-radius:8px;background:#fff;border:1px solid #eef3f7;box-sizing:border-box;min-width:0;box-shadow:0 4px 8px rgb(0 0 0 / .3)}.fare-img{width:94px;height:70px;object-fit:cover;border-radius:6px;flex:0 0 64px;cursor:pointer}.fare-main{display:flex;flex-direction:column;gap:4px;flex:1 1 auto;min-width:0}.fare-name{font-weight:700;font-size:14px;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fare-meta{color:#6b7280;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fare-side{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex:0 0 200px;min-width:0}.fare-price{font-weight:800;color:#2d5f7a;font-size:15px;white-space:nowrap}.fare .btn{padding:8px 12px;border-radius:8px;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.policy-row{display:flex;gap:12px;align-items:center;color:#6b7280;font-size:13px}.policy.ok{color:#16a34a;font-weight:700}.policy.no{color:#ef4444;font-weight:700}@media (max-width:520px){.result-expand{padding:10px}.fare{flex-direction:column;align-items:stretch;gap:8px}.fare-img{width:100%;height:120px;flex:0 0 auto}.fare-main{order:2}.fare-side{order:3;flex-direction:column;width:100%;align-items:stretch}.fare-price{width:100%;font-size:16px;margin-bottom:4px}.child-price{font-size:12px;margin-left:auto}.fare .btn{width:100%}}.result-expand[aria-hidden="true"]{visibility:hidden;height:0;padding:0;border:0;overflow:hidden}.result-expand[aria-hidden="false"]{visibility:visible;height:auto}.result-expand.route-details{display:none;padding:14px;border-radius:10px;background:#fff;border:1px solid #e8eef6;box-shadow:0 6px 18px rgb(9 20 40 / .04);box-sizing:border-box;color:#0f172a;font-size:14px;line-height:1.4}.result-expand.route-details.open{display:block}.result-expand.route-details .expand-title{font-weight:700;font-size:15px;margin-bottom:10px;color:#0b2340}.route-details-grid{display:grid;grid-template-columns:1fr 320px;gap:14px;align-items:start;min-width:0;overflow:visible;white-space:normal}.route-details-info{display:flex;flex-direction:column;gap:12px;min-width:0}.detail-row{display:flex;flex-direction:column;gap:6px}.detail-label{font-size:12px;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.detail-value{width:100%;font-size:14px;color:#0f172a;display:block;max-width:100%;white-space:normal;overflow:visible;text-overflow:unset;word-break:break-word}.long-value{white-space:normal!important}.detail-value[title]{cursor:default}.detail-value[title]:hover::after{content:attr(title);position:absolute;background:#fff;border:1px solid #e6eef7;padding:8px 10px;border-radius:8px;box-shadow:0 6px 18px rgb(9 20 40 / .06);white-space:normal;max-width:320px;z-index:120}.detail-actions{display:flex;gap:8px;margin-top:6px;flex-wrap:wrap}.detail-actions .btn{padding:8px 12px;border-radius:8px;font-weight:600}.route-details-map{display:flex;flex-direction:column;gap:8px;min-width:0}.route-details-map iframe{width:100%;height:220px;border:0;border-radius:8px;background:#f4f7fb;display:block}.route-details-map .map-caption{font-size:12px;color:#6b7280;text-align:center}@media (max-width:900px){.route-details-grid{grid-template-columns:1fr}.route-details-map iframe{height:200px}.detail-value{white-space:normal}}.result-expand.route-details{display:none;padding:16px;border-radius:10px;background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid #eef3f7}.route-details-grid{display:grid;grid-template-columns:1fr 320px;gap:16px;align-items:start;min-width:0}.route-details-info{min-width:0;display:flex;flex-direction:column;gap:12px}.detail-row{display:flex;flex-direction:column;gap:6px}.detail-label{font-size:12px;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.detail-value{font-size:14px;color:#0f172a;line-height:1.35;overflow:hidden}.detail-value{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-actions{display:flex;gap:8px;margin-top:6px}.detail-actions .btn{padding:8px 12px;border-radius:8px}.route-details-map{display:flex;flex-direction:column;gap:8px}.map-caption{font-size:12px;color:#6b7280}@media (max-width:900px){.route-details-grid{grid-template-columns:1fr}.route-details-map iframe{height:200px}}@media (max-width:520px){.result-item.timeline-5row{grid-template-columns:1fr;min-width:0}.result-logo{width:44px;height:44px}.route-row{display:flex;gap:8px;align-items:center}.route-title{font-size:15px;white-space:normal}.result-side{order:3;align-items:stretch;text-align:left}.tl-row{grid-template-columns:56px 20px 1fr;gap:6px}.v-line.long{height:30px}.v-line.short{height:6px}.tl-left .tl-time{font-size:14px}.tl-station{font-size:13px}.result-actions{flex-direction:column;width:100%}.btn{width:100%}.btn.sold-out{background-color:#ff4d4d;color:#FFF;pointer-events:none;opacity:.6;cursor:}.btn.not-available{background-color:gray;color:#FFF;pointer-events:none;opacity:.6;pointer-events:none}.btn.sale-close{background-color:gray;color:#000;pointer-events:none;opacity:.6;cursor:}.btn.no-online-sale{background-color:gray;pointer-events:none;color:#000;opacity:.6;cursor:}.btn.not-open{background-color:#FFAC1C;color:#FFF;opacity:.6}}.fare{display:flex;gap:12px;align-items:center;padding:10px;border-radius:8px;background:#fff;border:1px solid #eef3f7;box-sizing:border-box;min-width:0;transition:all 0.3s ease}.fare-content{display:flex;flex:1 1 auto;flex-direction:row;align-items:flex-start;justify-content:space-between}@media (max-width:520px){.fare{flex-direction:row;flex-wrap:wrap}.fare-img{width:64px;height:48px;object-fit:cover;border-radius:6px;flex:0 0 auto;margin-right:10px}.fare-content{display:flex;flex-direction:column;width:100%}.fare-side{width:100%;flex:0 0 auto;margin-top:8px;align-items:stretch}.fare-price{display:none}.fare .btn.primary{width:100%;padding:12px;font-size:15px}.fare .btn.select{width:100%;padding:12px;font-size:15px}.policy-row{width:100%}}.route-title img{width:.9em;height:1em;vertical-align:middle}.result-actions{width:100%}.result-actions .btn{display:block;width:100%;text-align:center}.route-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center;width:100%}.route-title{flex:1;display:flex;align-items:center}.route-meta.muted{flex-shrink:0;margin-left:10px}@media (max-width:768px){.route-row{flex-direction:column;align-items:flex-start}.route-title,.route-meta.muted{width:100%;margin-left:0}.route-meta.muted{margin-top:8px}}@media (max-width:520px){.fare-img{max-width: 90px; max-height: 70px;}.result-logo{display:none}.result-item.timeline-5row{display:block}.route-meta{padding-top:.25em;padding-bottom:.25em}.result-main{min-width:0!important;width:100%!important;flex:1 1 auto}.child-price{margin-left:auto}.price-row{margin-left:auto}.result-side{margin-top:1em}}.result-item.loading::after{content:'';position:absolute;top:50%;left:50%;width:40px;height:40px;margin:-20px;border:4px solid #ccc;border-top-color:#007bff;border-radius:50%;animation:spin 0.8s linear infinite;z-index:10}.result-item.loading{position:relative;opacity:.6;pointer-events:none}@keyframes spin{to{transform:rotate(360deg)}}.route-maps-row{display:flex;flex-direction:row;gap:14px;width:100%;flex-wrap:nowrap}.route-details-map{flex:1 1 0%;min-width:0;display:flex;flex-direction:column;gap:8px}.route-details-map iframe{width:100%;height:220px;border:0;border-radius:8px;background:#f4f7fb;display:block}.map-caption{font-size:12px;color:#6b7280}@media (max-width:600px){.route-maps-row{flex-direction:column}}@media (max-width:520px){.fare{display:flex;align-items:center}.fare-img{margin-right:10px;max-width:75px;max-height:70px}.fare-main{flex:1}.fare-name{font-size:14px}}.no-online-sale{background-color:#F2F2F2;color:#000;pointer-events:none;opacity:.6;cursor:}btn.no-online-sale{background-color:#000;color:#FFF;pointer-events:none;opacity:.6;cursor:}