*{box-sizing:border-box}html,body{height:100%;margin:0;font-family:system-ui,-apple-system,"Segoe UI",sans-serif;color:#162033;background:#f5f7fb}.app-shell{height:100vh;display:grid;grid-template-columns:minmax(0,1fr) 430px}.map-pane{position:relative;min-width:0;height:100vh;background:#e8eef7}#map{position:absolute;inset:0;width:100%;height:100%;z-index:0}.map-status{position:absolute;left:16px;top:16px;z-index:500;background:rgba(255,255,255,.94);box-shadow:0 8px 24px rgba(0,0,0,.14);border-radius:14px;padding:10px 14px;max-width:min(640px,calc(100% - 32px));font-size:14px}.sidebar{height:100vh;display:grid;grid-template-rows:auto minmax(150px,34%) 1fr;border-left:1px solid #d8dfec;background:#fff;min-width:0}.sidebar-header{padding:18px 18px 12px;border-bottom:1px solid #e7ebf2}.sidebar-header h1{margin:0 0 6px;font-size:20px}.sidebar-header p{margin:0 0 12px;color:#5a6475;font-size:13px;line-height:1.45}#routeSearch{width:100%;padding:12px 13px;border:1px solid #cfd7e6;border-radius:12px;font-size:15px;outline:none}#routeSearch:focus{border-color:#3887ff;box-shadow:0 0 0 3px rgba(56,135,255,.15)}.counts{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.counts span{font-size:12px;border:1px solid #dfe5ef;background:#f7f9fc;border-radius:999px;padding:4px 9px;color:#445064}.route-list{overflow:auto;padding:10px;border-bottom:1px solid #e7ebf2;background:#fbfcff}.route-card{width:100%;border:1px solid #e2e7f0;border-radius:12px;background:#fff;padding:9px 10px;margin-bottom:8px;display:flex;align-items:center;gap:10px;text-align:left;cursor:pointer}.route-card:hover{border-color:#aebbd0;background:#f8fbff}.route-card.active{border-color:#2b7cff;box-shadow:0 0 0 3px rgba(43,124,255,.12)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:76px;min-height:30px;border-radius:8px;padding:5px 8px;font-weight:700;line-height:1.1;font-size:13px;white-space:nowrap}.route-card .info{min-width:0;display:flex;flex-direction:column;gap:2px}.route-card .name{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-card .sub{font-size:12px;color:#687487}.detail{overflow:auto;padding:14px 16px 20px}.empty{border:1px dashed #cfd7e6;border-radius:14px;padding:18px;color:#69758a;background:#fbfcff;line-height:1.6}.detail-title{display:flex;align-items:center;gap:10px;margin-bottom:10px}.detail-title h2{font-size:20px;margin:0}.pattern-tabs{display:flex;flex-direction:column;gap:8px;margin:12px 0}.pattern-tab{border:1px solid #dce3ee;background:#fff;border-radius:12px;padding:10px;text-align:left;cursor:pointer}.pattern-tab:hover{background:#f8fbff}.pattern-tab.active{color:#fff;border-color:transparent}.pattern-tab strong{display:block;font-size:14px;margin-bottom:4px}.pattern-tab span{display:block;font-size:12px;opacity:.82}.detail-grid{display:grid;grid-template-columns:92px 1fr;gap:8px 10px;margin:14px 0;padding:12px;border-radius:14px;background:#f7f9fc;border:1px solid #e2e8f2}.detail-grid dt{color:#69758a;font-size:13px}.detail-grid dd{margin:0;font-size:13px;word-break:break-all}.stop-list{list-style:none;margin:10px 0 0;padding:0;border-top:1px solid #e8edf5}.stop-list li{display:grid;grid-template-columns:42px 1fr auto;gap:8px;align-items:center;padding:9px 2px;border-bottom:1px solid #edf1f7;cursor:pointer}.stop-list li:hover{background:#f8fbff}.seq{font-variant-numeric:tabular-nums;color:#6a7587;font-size:12px}.stop-name{font-weight:600}.stop-time{color:#6a7587;font-size:12px}.leaflet-container{font-family:system-ui,-apple-system,"Segoe UI",sans-serif}.leaflet-control-attribution{font-size:10px}@media (max-width:900px){.app-shell{grid-template-columns:1fr;grid-template-rows:55vh 45vh}.map-pane{height:55vh}.sidebar{height:45vh;border-left:none;border-top:1px solid #d8dfec;grid-template-rows:auto 42% 1fr}.sidebar-header{padding:12px}.sidebar-header p{display:none}.detail{padding:12px}.badge{min-width:64px}}
.leaflet-tile{filter:saturate(.55) brightness(1.08) contrast(.88);opacity:.78}
.stop-list li{grid-template-columns:42px 1fr}.stop-time{display:none}
.sidebar{grid-template-rows:auto minmax(150px,34%) minmax(0,1fr) auto}.data-notice{align-self:end;margin:0;padding:10px 14px 12px;border-top:1px solid #e7ebf2;background:#fbfcff;color:#7a8494;font-size:10px;line-height:1.5;white-space:pre-line}@media (max-width:900px){.sidebar{grid-template-rows:auto 34% minmax(0,1fr) auto}.data-notice{padding:8px 12px;font-size:9px}}
@media (max-width:700px){html,body{height:100%;overflow:hidden}.app-shell{height:100svh;display:grid;grid-template-columns:1fr;grid-template-rows:minmax(260px,42svh) minmax(0,1fr)}.map-pane{height:100%;min-height:0}.sidebar{height:auto;min-height:0;border-left:none;border-top:1px solid #d8dfec;grid-template-rows:auto minmax(96px,28%) minmax(0,1fr) auto}.sidebar-header{padding:10px 12px 9px}.sidebar-header h1{font-size:18px;margin-bottom:8px}.sidebar-header p{display:none}#routeSearch{padding:10px 11px;border-radius:10px;font-size:16px}.counts{margin-top:8px}.route-list{padding:8px;min-height:0}.route-card{margin-bottom:6px;padding:8px;border-radius:10px;gap:8px}.badge{min-width:58px;min-height:28px;border-radius:7px;font-size:12px}.route-card .sub{font-size:11px}.detail{min-height:0;padding:10px 12px 12px}.detail-title{margin-bottom:8px}.detail-title h2{font-size:17px;line-height:1.25;overflow-wrap:anywhere}.pattern-tabs{gap:6px;margin:8px 0}.pattern-tab{border-radius:10px;padding:8px}.pattern-tab strong{font-size:13px;line-height:1.35;overflow-wrap:anywhere}.pattern-tab span{font-size:11px;line-height:1.35}.stop-list{margin-top:8px}.stop-list li{grid-template-columns:34px 1fr;padding:8px 0}.stop-name{font-size:14px;line-height:1.35}.map-status{left:10px;top:10px;max-width:calc(100% - 20px);padding:8px 10px;border-radius:10px;font-size:12px}.data-notice{padding:7px 10px calc(7px + env(safe-area-inset-bottom));font-size:8.5px;line-height:1.45}}
@media (max-width:380px){.app-shell{grid-template-rows:minmax(230px,39svh) minmax(0,1fr)}.sidebar-header h1{font-size:17px}.counts span{font-size:11px;padding:3px 7px}.data-notice{font-size:8px}}
