*{margin:0;padding:0;box-sizing:border-box;font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif}body{height:100vh;overflow:hidden;background-color:#f5f7fa}.container{display:flex;flex-direction:column;height:100%}.sidebar{width:100%;background:#fff;box-shadow:0 2px 10px rgba(0,0,0,.1);z-index:10;display:flex;flex-direction:column;max-height:40vh;overflow:hidden;border-right:1px solid #e0e0e0}.sidebar-header{padding:10px;border-bottom:1px solid #eee;background:linear-gradient(135deg,#1a73e8,#4285f4);color:#fff}.sidebar-header h1{font-size:1.05rem;margin-bottom:6px;font-weight:600}.search-container{position:relative}.search-container>input{width:100%}.search-input{width:100%;padding:12px 15px 12px 45px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;transition:.3s;background-color:rgba(255,255,255,.9);height:auto}.search-input:focus{outline:0;border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.2)}.selected-ports-block{display:flex;flex-direction:row;justify-content:space-between}.search-icon{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:#5f6368;font-size:1rem}.location-search-container{display:flex;margin-bottom:10px}.location-search-input{flex:1;padding:12px 15px 12px 45px;border:1px solid #ddd;border-radius:88px;font-size:.95rem;transition:.3s;background-color:rgba(255,255,255,.9);height:auto}.location-search-btn{background:#34a853;color:#fff;border:none;border-radius:0 8px 8px 0;cursor:pointer;transition:background .3s;font-weight:500;height:auto;font-size:.95rem}.location-search-btn:hover{background:#2e8b47}.category-buttons{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}.category-btn{flex:1;min-width:60px;padding:5px 3px;border:1px solid rgba(255,255,255,.3);border-radius:5px;background:rgba(255,255,255,.2);color:#fff;cursor:pointer;transition:.3s;font-size:.7rem;display:flex;align-items:center;justify-content:center;gap:3px;font-weight:500}.category-btn:hover{background:rgba(255,255,255,.3);transform:translateY(-1px)}.category-btn.active{background:rgba(255,255,255,.9);color:#4285f4;border-color:#4285f4;box-shadow:0 2px 8px rgba(0,0,0,.2)}.port-list-container{flex:1;overflow-y:auto;padding:10px;background-color:#f8f9fa;display:flex;flex-direction:column}.port-count{color:#5f6368;font-size:.85rem;margin-bottom:10px;padding-left:5px;font-weight:500}.port-list{list-style:none;flex:1;overflow-y:auto}.port-item{padding:8px 10px;border-radius:6px;background:#fff;margin-bottom:6px;cursor:pointer;transition:.2s;border:1px solid #e0e0e0;box-shadow:0 2px 4px rgba(0,0,0,.05);position:relative}.port-item:hover{background:#f1f8ff;border-color:#d2e3fc;box-shadow:0 4px 8px rgba(0,0,0,.1)}.route-list-container{flex:1;overflow-y:auto;padding:10px;background-color:#f8f9fa;display:flex;flex-direction:column}.route-list-header{padding:15px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border-radius:8px;margin-bottom:15px}.route-list-header h3{margin:0 0 8px;font-size:1.2rem;font-weight:600;display:flex;align-items:center;gap:8px}.route-count{font-weight:500}.route-search-filter{display:flex;gap:10px;margin-bottom:15px;align-items:center}.route-search-input-wrapper{position:relative;flex:1;min-width:0}.route-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9aa0a6;font-size:14px;pointer-events:none}.route-search-input{width:100%;padding:10px 15px 10px 40px;border:1px solid #ddd;border-radius:8px;font-size:14px;transition:.3s;background:#fff}.route-search-input:focus{outline:0;border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}.route-type-select{padding:10px 15px;border:1px solid #ddd;border-radius:8px;font-size:14px;background:#fff;color:#202124;cursor:pointer;transition:.3s;min-width:120px}.route-type-select:focus{outline:0;border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}.route-search-btn{padding:10px 20px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:.3s;display:flex;align-items:center;gap:6px;white-space:nowrap}.route-search-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgba(66,133,244,.3)}.route-search-btn:active{transform:translateY(0)}.route-list{list-style:none;flex:1;overflow-y:auto}.route-item{padding:10px 15px;border-radius:8px;background:#fff;margin-bottom:8px;cursor:pointer;transition:.2s;border:1px solid #e0e0e0;box-shadow:0 1px 3px rgba(0,0,0,.05);position:relative}.route-item:hover{background:#f1f8ff;border-color:#4285f4;box-shadow:0 4px 8px rgba(66,133,244,.15);transform:translateY(-2px)}.route-item-content{display:flex;align-items:center;justify-content:space-between;gap:15px;flex-wrap:wrap}.route-item-title{display:flex;align-items:center;gap:6px;flex:1;min-width:150px}.route-item-title i{color:#4285f4;font-size:14px}.route-name{font-size:.95rem;font-weight:600;color:#202124}.route-item-meta{display:flex;align-items:center;gap:15px;flex-shrink:0}.route-count,.route-type{display:flex;align-items:center;gap:4px;font-size:.85rem;color:#5f6368}.route-count i,.route-type i{color:#9aa0a6;font-size:12px}.route-item-description{margin-top:6px;padding-top:6px;border-top:1px solid #f0f0f0;display:flex;align-items:flex-start;gap:6px;font-size:.8rem;color:#5f6368}.route-item-description i{color:#9aa0a6;font-size:12px;margin-top:2px}.route-item-status{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap}.route-item-status.active{background:#e8f5e9;color:#2e7d32}.route-item-status.inactive{background:#ffebee;color:#c62828}.port-item.active-start{border-color:#4285f4;background:#e8f0fe;box-shadow:0 0 0 2px rgba(66,133,244,.2)}.port-item.active-end{border-color:#fbbc05;background:#fef7e0;box-shadow:0 0 0 2px rgba(251,188,5,.2)}.port-name{font-weight:600;color:#202124;margin-bottom:4px;font-size:.85rem;display:flex;justify-content:space-between;align-items:center}.port-route-btn{background:0 0;border:none;color:#4285f4;cursor:pointer;font-size:1.1rem;padding:5px;border-radius:4px;transition:.2s;width:36px;height:36px}.port-route-btn:hover{background:rgba(66,133,244,.1);transform:scale(1.1)}.port-code{background:#4285f4;color:#fff;padding:3px 8px;border-radius:4px;font-size:.8rem;font-weight:500}.port-details{font-size:.72rem!important;line-height:1.3!important;margin-bottom:6px!important;display:flex;flex-direction:row;justify-content:space-between;font-weight:500;color:#838282}.port-details span:first-child{max-width:220px}.port-fee{background-color:#a8a8a8;padding:8px;color:#fff;border-radius:5px;cursor:pointer;transition:background-color .2s;max-height:34px}.port-fee:hover{background-color:#8a8a8a}.port-distance{background-color:#ffebee;padding:8px;color:#ea4335;border-radius:5px;cursor:pointer;transition:background-color .2s;max-height:34px;font-weight:700;border:1px solid #ffcdd2;white-space:nowrap;line-height:18px}.port-distance:hover{background-color:#ffcdd2}.route-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.port-detail-btn{background:#fff!important;color:#2f80ed!important;border:1px solid #2f80ed!important}.port-detail-btn:hover{background:#eaf3ff!important}.port-company-detail-panel{margin-top:8px;padding:10px;border:1px solid #e8eaed;border-radius:8px;background:#fafbfc;width:100%;box-sizing:border-box}.route-btn{padding:8px 12px;border:none;border-radius:5px;font-size:.8rem;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center;white-space:nowrap;font-weight:500;height:auto}.route-btn i{margin-right:5px}.set-start{background:#4285f4;color:#fff}.set-start:hover{background:#3367d6}.set-end{background:#fbbc05;color:#fff}.set-end:hover{background:#e6a800}#map{flex:1;height:60vh;width:100%}.route-status{position:fixed;top:220px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.8);color:#fff;padding:12px 24px;border-radius:24px;font-size:.9rem;z-index:99999999;display:none;max-width:90%;text-align:center;box-shadow:0 4px 12px rgba(0,0,0,.15)}.clear-route-btn{background:#ea4335;color:#fff;border:none;white-space:nowrap;padding:0 15px;height:40px;border-radius:4px;font-size:.9rem;font-weight:500;cursor:pointer;display:none;flex-direction:row;align-items:center;gap:5px;transition:.3s;box-shadow:0 2px 4px rgba(234,67,53,.2);pointer-events:auto!important;z-index:1000;position:relative}.clear-route-btn:hover{background:#d33b2c;box-shadow:0 4px 8px rgba(234,67,53,.3);transform:translateY(-1px)}.clear-route-btn:active{transform:translateY(0)}.error-message{position:fixed;top:20px;left:50%;transform:translateX(-50%);background:#ea4335;color:#fff;padding:12px 24px;border-radius:6px;z-index:99999999;display:none;max-width:90%;text-align:center;box-shadow:0 4px 12px rgba(0,0,0,.15);font-weight:500}.pagination-container{margin-top:15px;padding:10px;background:#fff;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.1);min-height:56px;display:flex;align-items:center}.pagination{display:flex;align-items:center;justify-content:center;gap:15px;width:100%}.pagination-btn{width:36px;height:36px;border:1px solid #ddd;background:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;color:#5f6368;flex-shrink:0}.pagination-btn:hover:not(:disabled){border-color:#4285f4;color:#4285f4}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:.9rem;color:#5f6368;font-weight:500;white-space:nowrap;flex-shrink:0}.custom-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;display:flex;align-items:center;justify-content:center}.modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5)}.modal-content{position:relative;background:#fff;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.3);width:90%;max-width:400px;max-height:90vh;overflow:hidden;animation:.3s ease-out modalSlideIn}@keyframes modalSlideIn{from{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background:#f8f9fa}.modal-header h3{margin:0;color:#202124;font-size:1.2rem}.modal-close{background:0 0;border:none;font-size:1.2rem;color:#5f6368;cursor:pointer;padding:5px;border-radius:4px;transition:.2s}.modal-close:hover{background:#e0e0e0;color:#202124}.modal-body{padding:20px}.modal-port-info{margin-bottom:20px}.modal-port-info h4{margin:0 0 10px;color:#202124;font-size:1.1rem}.modal-port-info p{margin:0;color:#5f6368;font-size:.9rem;line-height:1.4}.modal-actions{display:flex;flex-direction:column;gap:10px}.modal-btn{padding:12px 20px;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center;gap:8px;font-weight:500}.modal-btn.set-start-btn{background:#4285f4;color:#fff}.modal-btn.set-start-btn:hover{background:#3367d6}.modal-btn.set-end-btn{background:#fbbc05;color:#fff}.modal-btn.set-end-btn:hover{background:#e6a800}.mapboxgl-popup{z-index:100}.mapboxgl-popup-content{border-radius:10px;box-shadow:0 4px 16px rgba(0,0,0,.14);padding:0;overflow:hidden}.mapboxgl-popup-close-button{right:3px;top:3px;font-size:9px;color:#5f6368;background:rgba(255,255,255,.9);width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center}.mapboxgl-popup-close-button:hover{background:#e0e0e0;color:#202124}.custom-popup{min-width:140px;max-width:min(210px,85vw);font-size:9px}.custom-popup [style*=font-size]{font-size:11px!important}.incident-popup .mapboxgl-popup-content{padding:0;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.15)}.incident-popup-inner{padding:16px 20px;min-width:300px}.incident-popup-row{display:flex;flex-direction:column;gap:4px;padding:8px 0;border-bottom:1px solid #f0f0f0;min-height:28px}.incident-popup-row:last-child{border-bottom:none}.incident-popup-label{color:#909399;font-size:13px;line-height:1.4}.incident-popup-value{color:#303133;font-size:14px;line-height:1.5}.incident-popup-desc{white-space:pre-wrap;word-break:break-word}.incident-category-icon{vertical-align:middle}.popup-title{font-size:10px;color:#202124;font-weight:700;border-bottom:1px solid #e8eaed;padding:3px 5px;text-align:left;background:#f8f9fa}.popup-title-head-row{display:flex;flex-direction:row;align-items:center;gap:2px;margin-bottom:1px}.popup-category-corner{font-size:8px;font-weight:600;line-height:1.2}.popup-title-names-block{font-size:10px;font-weight:700;line-height:1.2;word-break:break-word;display:flex;flex-direction:column;align-items:center}.popup-title-name-cn,.popup-title-name-en,.popup-title-name-single{color:#202124}.popup-title-name-en{margin-bottom:1px}.popup-title-name-cn{font-weight:700}.popup-content{padding:3px 5px}.popup-table{width:100%;border-collapse:collapse;margin-bottom:2px;font-size:.6rem}.popup-table td,.popup-table th{padding:0;text-align:left;border-bottom:1px solid #f0f0f0;font-weight:600;line-height:1.4}.popup-table th{width:30%;color:#5f6368;font-weight:400}.popup-table td{color:#202124}.popup-footer{text-align:center;margin-top:12px}.popup-button{display:inline-block;padding:4px 8px;background-color:#4264fb;color:#fff;text-decoration:none;border-radius:3px;font-size:9px;transition:background-color .2s;width:100%}.popup-button:hover{background-color:#3151d6}.mobile-controls{position:absolute;bottom:80px;right:15px;z-index:10;display:flex;flex-direction:column;gap:10px}.mobile-control-btn{width:50px;height:50px;border-radius:50%;background:#fff;border:none;box-shadow:0 4px 12px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;color:#5f6368;transition:.2s}.mobile-control-btn:hover{background:#f8f9fa;transform:scale(1.05)}#mobileClearRouteBtn{background:#ea4335;color:#fff}#mobileClearRouteBtn:hover{background:#d33b2c;transform:scale(1.05)}.main-calculate-btn{padding:12px;background:#4285f4;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;z-index:10;box-shadow:0 4px 12px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;margin:10px 0;width:100%;font-weight:600;transition:.2s;height:auto}.port-name i{font-size:1rem;margin-right:8px;width:16px;text-align:center}.main-calculate-btn:hover{background:#3367d6;transform:translateY(-2px)}.main-calculate-btn i{margin-right:8px}.selected-ports{background:#fff;padding:15px;border-radius:10px;margin-bottom:15px;box-shadow:0 2px 8px rgba(0,0,0,.1);border:1px solid #e0e0e0}.selected-ports-title{font-size:.9rem;color:#5f6368;margin-bottom:10px;font-weight:500}.selected-port-info{font-size:.85rem;margin-bottom:8px;display:flex;align-items:center}.selected-port-info i{margin-right:8px;font-size:1rem}.location-marker{font-size:24px;color:#ea4335;text-shadow:0 2px 4px rgba(0,0,0,.3)}.loading{display:inline-block;width:20px;height:20px;border:3px solid #f3f3f3;border-top:3px solid #4285f4;border-radius:50%;animation:1s linear infinite spin;margin-right:10px}.admin-edit-controls button:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.2)}.admin-edit-controls button:active{transform:translateY(0)}@media (min-width:768px){.container{flex-direction:row}#map{height:100%}.mobile-controls{display:none}}.web-category-buttons{display:flex;flex-wrap:wrap;gap:8px}.web-category-buttons .category-btn{flex:0 0 auto;width:calc(33.333% - 6px);white-space:nowrap;min-width:0}.mobile-category-buttons{display:none;margin-top:10px;flex-wrap:wrap;gap:8px}.mobile-category-buttons .category-btn{flex:0 0 auto;width:calc(33.333% - 6px);white-space:nowrap;min-width:0}@media (max-width:767px){.web-category-buttons{display:none}.mobile-category-buttons{display:flex;flex-wrap:wrap;gap:4px}.location-search-input,.search-input{padding:6px 12px 6px 35px!important;height:36px!important;font-size:.85rem!important}.location-search-container .search-icon,.search-icon{left:12px!important;font-size:.9rem!important}.search-container{width:100%}.search-container>input{border-radius:6px 0 0 6px}.location-search-btn{padding:0 12px!important;height:36px!important;font-size:.85rem!important;min-width:40px!important}.category-buttons{gap:4px;margin-top:8px}.category-btn{padding:6px 8px!important;font-size:.7rem!important;min-width:50px}.mobile-category-buttons .category-btn{flex:0 0 auto;width:calc(33.333% - 3px);white-space:nowrap;min-width:0}.sidebar-header h1{font-size:1.1rem!important;margin-bottom:8px!important}.port-item{padding:6px 8px!important;margin-bottom:4px!important}.port-name{font-size:.8rem!important;margin-bottom:4px!important}.port-details{font-size:.7rem!important;line-height:1.3!important;margin-bottom:6px!important;display:flex;flex-direction:row;justify-content:space-between;color:#838282;font-weight:500}.port-fee{background-color:#a8a8a8;padding:8px;color:#fff;border-radius:5px}.route-actions{margin-top:8px!important;gap:6px!important}.route-btn{padding:4px 8px!important;height:30px!important;font-size:.75rem!important}.route-btn i{margin-right:3px!important;font-size:.8rem!important}.port-route-btn{font-size:1rem!important;padding:3px!important}.main-calculate-btn{padding:8px!important;height:36px!important;font-size:.9rem!important;margin:8px 0!important}.main-calculate-btn i{margin-right:6px!important;font-size:.9rem!important}.selected-ports{padding:10px!important;margin-bottom:10px!important}.selected-ports-title{font-size:.8rem!important;margin-bottom:8px!important}.selected-port-info{font-size:.75rem!important;margin-bottom:6px!important}.selected-port-info i{margin-right:6px!important;font-size:.9rem!important}.port-count{font-size:.75rem!important;margin-bottom:8px!important}.sidebar-header{padding:10px!important}.mobile-controls{bottom:60px!important;right:8px!important;gap:6px!important}.mobile-control-btn{width:36px!important;height:36px!important;font-size:1rem!important}.error-message,.route-status{padding:8px 16px!important;font-size:.8rem!important}.mapboxgl-popup-content{transform:scale(.8)}.custom-popup{min-width:160px!important}.popup-title{font-size:13px!important;padding:6px 10px!important}.popup-content{padding:6px 10px!important}.popup-table{font-size:.72rem!important}.popup-table td,.popup-table th{padding:2px 0!important}.popup-button{padding:5px 10px!important;font-size:.72rem!important}.pagination-container{margin-top:8px!important;padding:6px 8px!important;min-height:44px!important}.pagination{gap:8px!important}.pagination-btn{width:28px!important;height:28px!important;font-size:.8rem!important}.pagination-info{font-size:.75rem!important;padding:0 4px!important}.modal-content{width:95%!important;margin:10px!important}.modal-body,.modal-header{padding:15px!important}.modal-btn{padding:10px 15px!important;font-size:.9rem!important}#map{height:100vh!important;flex:1}.container{height:100vh}.port-list-container{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -4px 20px rgba(0,0,0,.15);z-index:1000;max-height:70vh;transform:translateY(100%);transition:transform .3s;overflow:hidden;display:block!important}.port-list-container.show{transform:translateY(0);display:block!important}.port-list-handle{width:40px;height:4px;background:#ddd;border-radius:2px;margin:10px auto;cursor:pointer}.mobile-route-panel{position:fixed;bottom:0;left:0;right:0;background:#fff;box-shadow:0 -4px 20px rgba(0,0,0,.15);z-index:9999999;max-height:80vh;transform:translateY(100%);transition:transform .3s;overflow-y:auto;display:none}.mobile-route-panel.active{transform:translateY(0);display:block}.mobile-route-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 15px;border-bottom:1px solid #e0e0e0;background:#f8f9fa;border-radius:20px 20px 0 0}.mobile-route-title{font-size:1.2rem;font-weight:600;color:#202124;margin:0;display:flex;align-items:center;gap:10px}.mobile-route-close{background:0 0;border:none;font-size:1.2rem;color:#5f6368;cursor:pointer;padding:8px;border-radius:50%;transition:.2s}.mobile-route-close:hover{background:#e0e0e0;color:#202124}.mobile-route-content{padding:10px;gap:10px;display:flex;flex-direction:column}.mobile-route-inputs{display:flex;flex-direction:row;gap:10px;max-height:40px}.mobile-route-input-group{position:relative}.route-input-wrapper{position:relative;display:flex;align-items:center}.route-input-wrapper .end-icon,.route-input-wrapper .start-icon{position:absolute;left:12px;z-index:2;font-size:1rem}.route-input-wrapper .start-icon{color:#4285f4}.route-input-wrapper .end-icon{color:#fbbc05}.route-input{width:100%;padding:8px 35px 8px 8px;border:2px solid #e8eaed;border-radius:8px;font-size:1rem;transition:border-color .3s;outline:0;background:#fff;text-indent:2em;text-overflow:ellipsis}.route-input:focus{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}.route-location-btn{position:absolute;right:8px;background:0 0;border:none;padding:6px;cursor:pointer;color:#5f6368;transition:.3s;border-radius:4px;font-size:.9rem}.route-location-btn:hover{background:#f8f9fa;color:#4285f4}.route-swap-btn-container{display:flex;justify-content:center;margin:15px 0}.route-swap-btn{width:40px;height:40px;border:2px solid #e8eaed;background:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.3s;color:#5f6368}.route-swap-btn:hover{border-color:#4285f4;color:#4285f4;transform:rotate(180deg)}.mobile-route-actions{display:flex;gap:10px}.route-calculate-btn{flex:2;height:36px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:.3s;display:flex;align-items:center;justify-content:center;gap:8px;font-size:.8rem}.route-calculate-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(66,133,244,.4)}.route-clear-btn{flex:1;height:36px;background:#f8f9fa;color:#5f6368;border:1px solid #e8eaed;border-radius:8px;font-weight:600;cursor:pointer;transition:.3s;display:flex;align-items:center;justify-content:center;gap:8px;font-size:.8rem}.route-clear-btn:hover{background:#e8eaed;color:#202124}.mobile-controls-container{position:fixed;bottom:20px;right:15px;z-index:1000;display:flex;flex-direction:column;gap:10px}.mobile-control-btn{border-radius:50%;background:#fff;border:none;box-shadow:0 4px 12px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#5f6368;transition:.2s}.mobile-control-btn:hover{background:#f8f9fa;transform:scale(1.05)}.route-planning-panel,.top-controls{display:none!important}.mobile-location-search{display:block!important}.web-port-list{display:none!important}}.port-list-container::-webkit-scrollbar{width:6px}.port-list-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.port-list-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.port-list::-webkit-scrollbar{width:4px}.port-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.port-list::-webkit-scrollbar-thumb{background:#d1d1d1;border-radius:2px}.port-list::-webkit-scrollbar-thumb:hover{background:#b8b8b8}.search-mode-switcher{position:fixed;top:10px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:1001;background:#fff;padding:6px;border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.search-mode-btn{padding:10px 20px;border:none;border-radius:8px;background:0 0;color:#5f6368;font-size:14px;font-weight:500;cursor:pointer;transition:.3s;display:flex;align-items:center;gap:6px;white-space:nowrap;position:relative;z-index:1;pointer-events:auto;user-select:none;-webkit-user-select:none}.search-mode-btn:hover{background:#f1f3f4;color:#202124}.search-mode-btn.active{background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;box-shadow:0 2px 6px rgba(66,133,244,.3)}.search-mode-btn i{font-size:14px}.top-controls{position:fixed;top:70px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:15px;border-radius:12px;z-index:1000;max-width:600px;width:90%;transition:.3s}.route-list-panel{position:fixed;top:130px;left:50%;transform:translateX(-50%);width:90%;max-width:800px;background:#fff;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.15);z-index:999;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.route-list-panel .route-list-header{padding:10px 20px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border-radius:12px 12px 0 0;margin:0;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.route-list-panel .route-list-header h3{margin:0;font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:8px}.route-list-panel .route-count{color:rgba(255,255,255,.9);font-size:.9rem;font-weight:500}.route-list-panel .route-search-filter{padding:10px 20px;border-bottom:1px solid #e0e0e0;flex-shrink:0;margin:0}.route-list-panel .route-list{height:340px;flex:1;overflow-y:auto;overflow-x:hidden;padding:10px 20px;margin:0;list-style:none;min-height:0;box-sizing:border-box}.route-list-panel .pagination-container{padding:6px 20px;border-top:1px solid #e0e0e0;flex-shrink:0;display:block;background:#f8f9fa;margin-top:0;box-sizing:border-box;min-height:auto;height:auto}.route-list-panel .pagination-container .pagination{display:flex;align-items:center;justify-content:center;gap:15px;width:100%;margin:0;padding:0;min-height:auto;height:auto}.route-list-panel .pagination-container .pagination-btn{width:32px;height:32px;font-size:.85rem}.route-list-panel .pagination-container .pagination-info{font-size:.85rem;padding:0 8px}.route-list-panel .route-list::-webkit-scrollbar{width:6px}.route-list-panel .route-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.route-list-panel .route-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.route-list-panel .route-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.articles-drawer{position:fixed;top:0;left:0;width:100%;max-width:420px;height:100%;background:#fff;box-shadow:4px 0 20px rgba(0,0,0,.15);display:flex;flex-direction:column;transform:translateX(-100%);transition:transform .3s;overflow:hidden;z-index:1000}.articles-drawer.open{transform:translateX(0)}.articles-drawer-header{padding:12px 20px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.articles-drawer-header h3{margin:0;font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:8px}.articles-drawer-close{background:rgba(255,255,255,.2);border:none;color:#fff;width:36px;height:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.articles-drawer-close:hover{background:rgba(255,255,255,.3)}.articles-drawer-tabs{display:flex;gap:0;padding:10px 15px;border-bottom:1px solid #e0e0e0;background:#f8f9fa;flex-shrink:0}.articles-tab{flex:1;padding:10px 12px;border:1px solid #e0e0e0;background:#fff;color:#5f6368;font-size:.9rem;cursor:pointer;transition:.2s;border-radius:6px;margin:0 2px}.articles-tab:first-child{margin-left:0}.articles-tab:last-child{margin-right:0}.articles-tab:hover{background:#f1f8ff;color:#4285f4;border-color:#d2e3fc}.articles-tab.active{background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border-color:transparent}.articles-drawer-filter{padding:12px 15px;border-bottom:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;flex-shrink:0}.articles-date-group{display:flex;flex-direction:column;gap:4px}.articles-date-group label{font-size:.8rem;color:#5f6368}.articles-date-input{padding:8px 12px;border:1px solid #ddd;border-radius:8px;font-size:.9rem;min-width:130px}.articles-date-input:focus{outline:0;border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.2)}.articles-filter-btn{padding:8px 16px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border:none;border-radius:8px;font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:6px;transition:.2s}.articles-filter-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgba(66,133,244,.3)}.articles-drawer-list{list-style:none;margin:0;padding:10px 15px;flex:1;overflow-y:auto;min-height:0}.articles-drawer-item{padding:10px 14px;border-radius:8px;background:#fff;margin-bottom:8px;cursor:pointer;border:1px solid #e0e0e0;transition:.2s}.articles-drawer-item:hover{background:#f1f8ff;border-color:#d2e3fc;box-shadow:0 2px 6px rgba(0,0,0,.06)}.articles-drawer-item-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.articles-drawer-item-title{font-size:.95rem;color:#202124;font-weight:500;line-height:1.4;flex:1;min-width:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.articles-drawer-item-date{font-size:.8rem;color:#5f6368;flex-shrink:0}.articles-drawer-empty,.articles-drawer-error,.articles-drawer-loading{padding:20px;text-align:center;color:#5f6368;font-size:.95rem}.articles-drawer-error{color:#d93025}.articles-drawer-pagination{padding:10px 15px;border-top:1px solid #e0e0e0;background:#f8f9fa;flex-shrink:0}.articles-drawer-pagination .pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin:0}.articles-drawer-pagination .pagination-btn{width:32px;height:32px;font-size:.85rem}.articles-drawer-pagination .pagination-info{font-size:.85rem;padding:0 8px;color:#5f6368}.articles-drawer-list::-webkit-scrollbar{width:6px}.articles-drawer-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.articles-drawer-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.articles-drawer-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.article-detail-card{position:fixed;bottom:20px;right:20px;width:450px;max-width:calc(100vw - 40px);max-height:600px;background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15);display:flex;flex-direction:column;z-index:999;animation:.3s slideInUp}.article-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;background:rgba(66,133,244,.9);border:none;border-radius:50%;color:#fff;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:.3s;box-shadow:0 2px 8px rgba(0,0,0,.2)}.article-nav-btn:hover{background:#4285f4;transform:translateY(-50%) scale(1.1)}.article-nav-btn:disabled{background:rgba(0,0,0,.2);cursor:not-allowed;opacity:.5}.article-nav-btn:disabled:hover{transform:translateY(-50%)}.article-nav-prev{left:8px}.article-nav-next{right:8px}.article-toast{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-100px);background:rgba(0,0,0,.8);color:#fff;padding:12px 24px;border-radius:8px;font-size:.9rem;z-index:10000;opacity:0;transition:.3s;pointer-events:none}.article-toast.show{transform:translateX(-50%) translateY(0);opacity:1}@keyframes slideInUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.article-detail-header{padding:10px 20px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;display:flex;justify-content:space-between;align-items:flex-start;gap:12px;border-radius:12px 12px 0 0}.article-detail-title{margin:0;font-size:1rem;font-weight:600;line-height:1.4;flex:1}.article-detail-close{background:rgba(255,255,255,.2);border:none;color:#fff;width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0}.article-detail-close:hover{background:rgba(255,255,255,.3)}.article-detail-body{padding:10px 20px;overflow-y:auto;flex:1;min-height:0;height:400px}.article-detail-loading{text-align:center;padding:40px 20px;color:#666}.loading-spinner{border:3px solid #f3f3f3;border-top:3px solid #4285f4;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin;margin:0 auto 12px}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.article-detail-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e8e8e8;font-size:.85rem;color:#666}.article-detail-meta-item{display:flex;align-items:center;gap:6px}.article-detail-meta-item i{color:#4285f4}.article-detail-category{background:#4285f4;color:#fff;padding:3px 10px;border-radius:4px;font-size:.75rem;font-weight:500}.article-detail-weekly-info{margin-top:16px;padding:16px;background:linear-gradient(135deg,#f0f9ff 0,#e0f2fe 100%);border-radius:8px;border:1px solid #bae6fd}.weekly-info-item{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:.9rem}.weekly-info-item:last-child{margin-bottom:0}.weekly-info-item>i{color:#0284c7;font-size:1rem;width:20px;text-align:center}.weekly-label{color:#0369a1;font-weight:500}.weekly-value{color:#0c4a6e;font-weight:600}.route-value{background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;padding:4px 12px;border-radius:6px;font-size:.85rem}.trend-value{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:rgba(255,255,255,.7);border-radius:6px;font-size:.85rem}.article-detail-content{font-size:.9rem;line-height:1.7;color:#333;max-height:300px;overflow:hidden;position:relative}.article-detail-content.truncated::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to bottom,transparent,#fff)}.article-detail-content p{min-height:230px;max-height:230px;margin:12px 0}.article-detail-content h1,.article-detail-content h2,.article-detail-content h3,.article-detail-content h4{margin:16px 0 8px;font-weight:600}.article-detail-content img{max-width:100%;height:auto;border-radius:6px;margin:12px 0}.article-detail-footer{padding:10px;border-top:1px solid #e8e8e8;display:flex;justify-content:space-between;align-items:center;gap:12px}.article-detail-link{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;text-decoration:none;border-radius:6px;font-size:.9rem;font-weight:500;transition:.2s}.article-detail-link:hover{box-shadow:0 4px 12px rgba(66,133,244,.3);transform:translateY(-1px)}.article-detail-body::-webkit-scrollbar{width:6px}.article-detail-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.article-detail-body::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.article-detail-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.route-planning-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:.3s;white-space:nowrap;flex-shrink:0}.route-planning-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(66,133,244,.4)}.route-planning-btn i{font-size:16px}.top-search-container{flex:1;min-width:0}.top-search-input-container{position:relative;display:flex;align-items:center;background:#fff;border-radius:8px;border:1px solid rgba(66,133,244,.2);transition:.3s}.top-search-input-container:focus-within{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}.top-search-input{flex:1;border:none;background:0 0;padding:12px 15px;font-size:14px;outline:0;color:#202124;text-indent:2em}.top-search-input::placeholder{color:#9aa0a6}.top-search-btn{padding:13px 15px;background:#4285f4;color:#fff;border:none;cursor:pointer;transition:background .3s;border-radius:0 5px 5px 0}.top-search-btn:hover{background:#3367d6}#routePlanningBtn{color:#4285f4;background-color:#fff;border-radius:unset}#routePlanningBtn:hover{background-color:#3367d6;color:#fff}.route-planning-toggle-btn{display:flex;align-items:center;background:#f5f4f4;color:#0c7be4;border:none;cursor:pointer;transition:.3s;white-space:nowrap;padding:13px;font-size:18px}.route-planning-toggle-btn:hover{background:#d1d1d1}.route-planning-panel{margin-top:5px;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-radius:12px;padding:15px;box-shadow:0 4px 20px rgba(0,0,0,.1);border:1px solid rgba(255,255,255,.2)}.route-inputs-container{display:flex;align-items:center;gap:10px}.route-inputs-container>.router-panel{display:flex;gap:10px;width:100%}.route-input-group{flex:1}.route-input-wrapper{position:relative;display:flex;align-items:center}.route-input-wrapper .end-icon,.route-input-wrapper .start-icon{position:absolute;left:12px;z-index:2}.route-input-wrapper .start-icon{color:#4285f4}.route-input-wrapper .end-icon{color:#fbbc05}.route-input{width:100%;padding:8px 35px 8px 8px;border:2px solid #e8eaed;border-radius:8px;font-size:14px;transition:border-color .3s;outline:0;text-indent:2em;text-overflow:ellipsis}.route-input:focus{border-color:#4285f4}.route-location-btn{position:absolute;right:8px;background:0 0;border:none;padding:6px;cursor:pointer;color:#5f6368;transition:.3s;border-radius:4px}.route-location-btn:hover{background:#f8f9fa;color:#4285f4}.route-swap-btn-container{display:flex;align-items:center;justify-content:center}.route-swap-btn{width:36px;height:36px;border:2px solid #e8eaed;background:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.3s;color:#5f6368}.route-swap-btn:hover{border-color:#4285f4;color:#4285f4;transform:rotate(180deg)}.route-actions{display:flex;gap:10px;margin-top:10px}.route-calculate-btn{flex:2;padding:10px 16px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:.3s;display:flex;align-items:center;justify-content:center;gap:8px}.route-calculate-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(66,133,244,.4)}.route-clear-btn{flex:1;padding:10px 16px;background:#f8f9fa;color:#5f6368;border:1px solid #e8eaed;border-radius:8px;font-weight:600;cursor:pointer;transition:.3s;display:flex;align-items:center;justify-content:center;gap:8px}.route-clear-btn:hover{background:#e8eaed;color:#202124}.route-suggestions-container{position:relative}.route-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e8eaed;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.1);max-height:300px;overflow-y:auto;z-index:9999;display:none;margin-top:5px}@media (max-width:768px){.route-suggestions{left:-200px;right:0;min-width:200px;max-height:250px}.mobile-articles-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999}.mobile-articles-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5)}.mobile-articles-container{position:absolute;bottom:0;left:0;right:0;height:70vh;background:#fff;border-radius:20px 20px 0 0;display:flex;flex-direction:column;animation:.3s slideUpMobile}@keyframes slideUpMobile{from{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-articles-header{padding:16px 20px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;display:flex;justify-content:space-between;align-items:center;border-radius:20px 20px 0 0;flex-shrink:0}.mobile-articles-header h3{margin:0;font-size:1.1rem;font-weight:600}.mobile-articles-close{background:rgba(255,255,255,.2);border:none;color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.mobile-articles-tabs{display:flex;gap:0;padding:12px 15px;border-bottom:1px solid #e0e0e0;background:#f8f9fa;flex-shrink:0}.mobile-articles-tab{flex:1;padding:10px 16px;border:1px solid #d0d7de;background:#fff;color:#57606a;font-size:.9rem;font-weight:500;cursor:pointer;transition:.2s}.mobile-articles-tab:first-child{border-radius:6px 0 0 6px}.mobile-articles-tab:last-child{border-radius:0 6px 6px 0}.mobile-articles-tab.active{background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border-color:transparent}.mobile-articles-filter{padding:12px 15px;border-bottom:1px solid #e0e0e0;background:#fafbfc;display:flex;flex-wrap:wrap;gap:10px;flex-shrink:0}.mobile-articles-date-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:140px}.mobile-articles-date-group label{font-size:.8rem;color:#57606a;font-weight:500}.mobile-articles-date-input{padding:8px 10px;border:1px solid #d0d7de;border-radius:6px;font-size:.85rem}.mobile-articles-filter-btn{padding:8px 20px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;align-self:flex-end}.mobile-articles-list{list-style:none;margin:0;padding:12px 15px;overflow-y:auto;flex:1;min-height:0}.mobile-articles-list .articles-drawer-item{padding:12px;background:#fff;margin-bottom:10px;border-radius:8px;border:1px solid #e0e0e0;cursor:pointer}.mobile-articles-pagination{padding:12px 15px;border-top:1px solid #e0e0e0;background:#f8f9fa;flex-shrink:0}.mobile-article-detail-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000}.mobile-article-detail-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5)}.mobile-article-detail-container{position:absolute;bottom:0;left:0;right:0;height:55vh;background:#fff;border-radius:20px 20px 0 0;display:flex;flex-direction:column;animation:.3s slideUpMobile}.mobile-article-detail-header{padding:16px 20px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;display:flex;justify-content:space-between;align-items:flex-start;gap:12px;border-radius:20px 20px 0 0;flex-shrink:0}.mobile-article-detail-header h3{margin:0;font-size:1rem;font-weight:600;line-height:1.4;flex:1}.mobile-article-detail-close{background:rgba(255,255,255,.2);border:none;color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.mobile-article-detail-body{padding:15px 20px;overflow-y:auto;flex:1;min-height:0}.mobile-article-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;background:rgba(66,133,244,.9);border:none;border-radius:50%;color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:.3s;box-shadow:0 4px 12px rgba(0,0,0,.3)}.mobile-article-nav-btn:active{background:#4285f4;transform:translateY(-50%) scale(.95)}.mobile-article-nav-btn:disabled{background:rgba(0,0,0,.2);cursor:not-allowed;opacity:.5}.mobile-article-nav-btn:disabled:active{transform:translateY(-50%)}.mobile-article-nav-prev{left:8px}.mobile-article-nav-next{right:8px}}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e8eaed;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.1);max-height:min(320px,55vh);overflow-y:auto;z-index:1000;display:none}.suggestion-item{padding:14px 16px;cursor:pointer;border-bottom:1px solid #f8f9fa;transition:background .2s;display:flex;align-items:center;gap:12px}.suggestion-item:hover{background:#f8f9fa}.suggestion-item:last-child{border-bottom:none}.suggestion-icon{width:36px;height:36px;border-radius:50%;background:#f8f9fa;display:flex;align-items:center;justify-content:center;color:#4285f4;flex-shrink:0;font-size:16px}.suggestion-content{flex:1;min-width:0;overflow:hidden}.suggestion-name-row{display:flex;align-items:center;gap:8px;margin-bottom:4px;min-width:0}.suggestion-name{font-weight:600;color:#202124;margin-bottom:0;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.suggestion-tag{flex-shrink:0;font-size:11px;font-weight:600;padding:2px 6px;border-radius:4px;line-height:1.2}.suggestion-tag-promo{background:#fff3e0;color:#c2410c;border:1px solid #fdba74}.suggestion-details{display:flex;gap:8px;margin-bottom:2px;flex-wrap:wrap}.suggestion-type{background:#e8f0fe;color:#4285f4;padding:3px 8px;border-radius:4px;font-size:12px;font-weight:600}.suggestion-code{color:#5f6368;font-size:12px;font-weight:600}.suggestion-address{color:#9aa0a6;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.no-suggestions{color:#9aa0a6;text-align:center;font-style:italic}.popup-actions{display:flex;gap:3px;margin-top:3px;flex-direction:column}.popup-action-btn{border:none;border-radius:3px;cursor:pointer;font-weight:600;font-size:8px!important;transition:.3s;display:flex;align-items:center;justify-content:center;gap:3px;text-align:center}.popup-action-btn.set-start-btn{background:#4285f4;color:#fff;height:20px;font-size:1em!important}.popup-action-btn.set-start-btn:hover{background:#3367d6}.popup-action-btn.set-end-btn{background:#fbbc05;color:#fff;height:20px;font-size:1em!important}.popup-action-btn.set-end-btn:hover{background:#e6a800}.custom-marker{width:24px;height:24px;border-radius:50%;background-size:contain;background-repeat:no-repeat;cursor:pointer;position:absolute;pointer-events:auto;transition:transform .2s;z-index:1000;box-shadow:0 2px 4px rgba(0,0,0,.3)}.custom-marker:hover{transform:scale(1.2);z-index:1001}.mapboxgl-marker{pointer-events:auto!important}.mobile-search-header{display:flex;align-items:center;margin-bottom:10px}.mobile-route-toggle{background:#4285f4;color:#fff;border:none;padding:10px 15px;font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:5px;white-space:nowrap}.mobile-search-input-container{flex:1;position:relative}.mobile-search-input{width:100%;padding:8px;border:1px solid #ddd;border-radius:8px 0 0 8px;font-size:.9rem;text-indent:1.5em}.mobile-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#5f6368}@media (max-width:767px){.container{flex-direction:column;height:100vh}.sidebar{max-height:40vh;position:absolute;z-index:9999999;overflow:visible}.port-list-container:not(.show){display:none}.mapboxgl-control-container{display:none!important}}@media (min-width:768px){.sidebar{width:300px;max-height:100vh;position:relative;display:flex;flex-direction:column}.port-list-container{display:block!important;position:relative!important;transform:none!important;border-radius:0!important;max-height:none!important;box-shadow:none!important;background:#f8f9fa}.mobile-controls-container,.mobile-location-search,.mobile-route-panel{display:none!important}.top-controls{display:flex!important}#map{height:100vh;flex:1}.container{flex-direction:row;height:100vh}}.web-only{display:flex}.mobile-only{display:none}.web-port-list{display:block;position:relative;transform:none}@media (max-width:767px){.web-only{display:none!important}.mobile-only{display:block}.web-port-list{display:none}.mobile-controls-container{position:fixed;bottom:20px;right:15px;z-index:1000;display:flex;flex-direction:column;gap:10px}.mobile-control-btn{width:50px;height:50px;border-radius:50%;background:#fff;border:none;box-shadow:0 4px 12px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;color:#5f6368;transition:.2s}.mobile-control-btn:hover{background:#f8f9fa;transform:scale(1.05)}.mobile-route-panel{position:fixed;bottom:0;left:0;right:0;background:#fff;box-shadow:0 -4px 20px rgba(0,0,0,.15);z-index:9999999;max-height:80vh;transform:translateY(100%);transition:transform .3s;overflow-y:auto}.mobile-route-panel.active{transform:translateY(0)!important;display:block!important;position:relative}.mobile-route-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #e0e0e0}.mobile-route-title{font-size:1.2rem;font-weight:600;color:#202124;margin:0}.mobile-route-close{background:0 0;border:none;font-size:1.2rem;color:#5f6368;cursor:pointer;padding:5px;border-radius:4px;transition:.2s}.mobile-route-close:hover{background:#e0e0e0;color:#202124}.mobile-route-inputs{display:flex;flex-direction:row;gap:10px;max-height:40px}.mobile-route-input-group{position:relative;display:flex;align-items:center}.mobile-route-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:1rem;z-index:2}.mobile-route-input{width:100%;padding:12px 15px 12px 40px;border:2px solid #e8eaed;border-radius:8px;font-size:1rem;transition:border-color .3s;outline:0}.mobile-route-input:focus{border-color:#4285f4}.mobile-route-actions{display:flex;gap:10px}.mobile-route-btn{flex:1;padding:12px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:.3s}.mobile-route-calculate{background:linear-gradient(135deg,#4285f4,#34a853);color:#fff}.mobile-route-calculate:active{transform:translateY(1px)}.mobile-route-clear{background:#f8f9fa;color:#5f6368;border:1px solid #e8eaed}.port-list-container{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -4px 20px rgba(0,0,0,.15);z-index:1000;max-height:70vh;transform:translateY(100%);transition:transform .3s;overflow:hidden;display:block!important}.port-list-container.show{transform:translateY(0)!important;display:block!important}.port-list-handle{width:40px;height:4px;background:#ddd;border-radius:2px;margin:10px auto;cursor:pointer}.route-list-container.mobile-only{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -4px 20px rgba(0,0,0,.15);z-index:1001;max-height:70vh;transform:translateY(100%);transition:transform .3s;overflow:hidden;display:flex!important;flex-direction:column}.route-list-container.mobile-only.show{transform:translateY(0)!important;display:flex!important}.route-list-container.mobile-only .route-list-handle{width:40px;height:4px;background:#ddd;border-radius:2px;margin:10px auto;cursor:pointer;flex-shrink:0}.route-list-container.mobile-only .route-list-header{padding:15px;margin:0;border-radius:0;flex-shrink:0}.route-list-container.mobile-only .route-search-filter{padding:10px 15px;flex-shrink:0;display:flex;flex-direction:row;align-items:center;gap:8px}.route-list-container.mobile-only .route-search-input-wrapper,.route-list-container.mobile-only .route-type-select{flex:1;min-width:0}.route-list-container.mobile-only .route-search-btn{flex-shrink:0;width:auto;min-width:60px;padding:8px 12px;font-size:.85rem}.route-list-container.mobile-only .route-list{flex:1;overflow-y:auto;padding:10px 15px;margin:0;list-style:none;min-height:0}.route-list-container.mobile-only .route-item{padding:10px 15px;border-radius:8px;background:#fff;margin-bottom:8px;cursor:pointer;transition:.2s;border:1px solid #e0e0e0;box-shadow:0 1px 3px rgba(0,0,0,.05);position:relative}.route-list-container.mobile-only .route-item:hover{background:#f1f8ff;border-color:#4285f4;box-shadow:0 4px 8px rgba(66,133,244,.15)}.route-list-container.mobile-only .route-item-content{display:flex;align-items:center;justify-content:space-between;gap:15px;flex-wrap:wrap}.route-list-container.mobile-only .route-item-title{display:flex;align-items:center;gap:6px;flex:1;min-width:150px}.route-list-container.mobile-only .route-item-title i{color:#4285f4;font-size:14px}.route-list-container.mobile-only .route-name{font-size:.95rem;font-weight:600;color:#202124}.route-list-container.mobile-only .route-item-meta{display:flex;align-items:center;gap:15px;flex-shrink:0}.route-list-container.mobile-only .route-count,.route-list-container.mobile-only .route-type{display:flex;align-items:center;gap:4px;font-size:.85rem;color:#5f6368}.route-list-container.mobile-only .route-count i,.route-list-container.mobile-only .route-type i{color:#9aa0a6;font-size:12px}.route-list-container.mobile-only .route-item-description{margin-top:6px;padding-top:6px;border-top:1px solid #f0f0f0;display:flex;align-items:flex-start;gap:6px;font-size:.8rem;color:#5f6368}.route-list-container.mobile-only .route-item-description i{color:#9aa0a6;font-size:12px;margin-top:2px}.route-list-container.mobile-only .pagination-container{padding:10px 15px;flex-shrink:0;border-top:1px solid #e0e0e0}.port-list{max-height:calc(70vh - 100px);overflow-y:auto}.route-status{top:290px;bottom:auto}}.route-point-popup{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;min-width:200px}.route-point-popup h4{color:#2c3e50;font-size:14px;margin:0 0 8px;font-weight:600;display:flex;align-items:center;gap:6px}.route-point-popup h4 i{color:#3498db;font-size:13px}.route-point-popup .popup-content{font-size:13px}.route-point-popup .popup-row{display:flex;margin-bottom:4px}.route-point-popup .popup-row:last-child{margin-bottom:0}.route-point-popup .label{color:#666;font-weight:500;min-width:70px;margin-right:8px}.route-point-popup .value{color:#333;flex:1;word-break:break-word}.route-controls{position:absolute;top:120px;right:20px;background:#fff;border-radius:8px;padding:15px;box-shadow:0 2px 10px rgba(0,0,0,.1);z-index:1000;min-width:200px;max-width:280px}.route-controls h3{font-size:14px;color:#2c3e50;margin:0 0 12px;font-weight:600;display:flex;align-items:center;gap:6px}.route-controls h3 i{color:#3498db}.route-toggle{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.route-toggle label{font-size:13px;color:#333;cursor:pointer;display:flex;align-items:center;gap:8px}.route-toggle input[type=checkbox]{width:16px;height:16px;accent-color:#3498db}.wechat-community-control{margin:10px 10px 0 0}.wechat-community-wrapper{position:relative}.wechat-community-btn{background:#fff;border:none;border-radius:4px;box-shadow:0 0 0 2px rgba(0,0,0,.1);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 10px;width:50px;transition:.3s}.wechat-community-btn:hover{background:#f5f5f5;box-shadow:0 0 0 2px rgba(0,0,0,.15)}.wechat-community-btn i{font-size:20px;color:#07c160;margin-bottom:2px}.wechat-community-label{font-size:11px;color:#333;font-weight:500}.wechat-qrcode-popup{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);padding:12px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:.3s;z-index:1000;pointer-events:none}.wechat-qrcode-popup::before{content:'';position:absolute;bottom:100%;right:20px;border:6px solid transparent;border-bottom-color:#fff}.wechat-community-wrapper:hover .wechat-qrcode-popup{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.wechat-qrcode-popup img{width:200px;height:200px;display:block}.map-brand-info{position:fixed;bottom:10px;right:10px;background:#fff;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.15);padding:4px;display:flex;align-items:center;gap:12px;z-index:10;transition:bottom .3s}.map-brand-info.move-up{bottom:180px}.map-brand-logo{height:30px;width:auto;flex-shrink:0}.map-brand-text{display:flex;flex-direction:row;gap:4px;font-size:13px;color:#2c3e50;line-height:1.4}.map-brand-text .brand-title{font-weight:600;font-size:14px}.map-brand-text .brand-features{font-size:14px;font-weight:600}@media (max-width:767px){.map-brand-info{bottom:10px;right:10px;padding:4px;max-width:calc(100% - 20px)}.map-brand-info.move-up{bottom:210px}.map-brand-logo{height:24px}.map-brand-text{font-size:11px}.map-brand-text .brand-title{font-size:12px}.map-brand-text .brand-features{font-size:11px}}.article-tooltip{position:absolute;right:75px;top:50%;transform:translateY(-50%);background:#fff;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);padding:12px 16px;min-width:200px;max-width:300px;z-index:1000;animation:.3s tooltipFadeIn;pointer-events:auto}.article-tooltip-close{position:absolute;top:4px;right:4px;width:20px;height:20px;border:none;background:rgba(255,255,255,.9);color:#999;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:.2s;padding:0;font-size:12px;z-index:1002!important;line-height:1;pointer-events:auto!important;box-shadow:0 1px 3px rgba(0,0,0,.1)}.article-tooltip-close:hover{background:#f5f5f5;color:#666;transform:scale(1.1)}.article-tooltip-close:active{transform:scale(.95)}.article-tooltip-mobile{right:50px;min-width:180px;max-width:250px;font-size:12px;padding:10px 14px}.article-tooltip-mobile .article-tooltip-title{font-size:12px}.article-tooltip-mobile .article-tooltip-close{top:3px;right:3px;width:16px;height:16px;font-size:10px}@keyframes tooltipFadeIn{from{opacity:0;transform:translateY(-50%) translateX(-10px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}.article-tooltip-arrow{position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-left:8px solid #fff}.article-tooltip-content{position:relative}.article-tooltip-loading{color:#666;font-size:13px;text-align:center}.article-tooltip-title{color:#2c3e50;font-size:14px;font-weight:500;line-height:1.5;word-wrap:break-word;word-break:break-all}.el-select-wrapper{position:relative;width:100%}.el-select{position:relative;display:block}.el-select__wrapper{position:relative;background-color:#fff;border:1px solid #dcdfe6;border-radius:4px;padding:0 30px 0 15px;cursor:pointer;transition:border-color .2s cubic-bezier(.645, .045, .355, 1);min-height:32px;display:flex;align-items:center;flex-wrap:wrap;gap:4px}.el-select__wrapper:hover{border-color:#c0c4cc}.el-select__wrapper.is-focused{border-color:#409eff}.el-select__tags{flex:1;display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:2px 0;min-height:28px}.el-select__tags-text{color:#909399;font-size:14px;line-height:28px}.el-tag{background-color:#f0f2f5;color:#606266;display:inline-flex;align-items:center;justify-content:center;padding:0 8px;height:24px;font-size:12px;border-radius:4px;box-sizing:border-box;white-space:nowrap;border:1px solid #e4e7ed;line-height:22px;max-width:100%;overflow:hidden;text-overflow:ellipsis}.el-tag__close{color:#909399;cursor:pointer;font-size:12px;margin-left:4px;transition:.2s;width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;line-height:1;flex-shrink:0}.el-tag__close:hover{color:#606266;background-color:#c0c4cc}.el-select__input{border:none;outline:0;padding:0;margin:0;height:28px;line-height:28px;font-size:14px;color:#606266;background-color:transparent;flex:1;min-width:11px;width:11px}.el-select__input::placeholder{color:#c0c4cc}.el-select__caret{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:#c0c4cc;font-size:12px;transition:transform .3s;pointer-events:none}.el-select.is-opened .el-select__caret{transform:translateY(-50%) rotate(180deg)}.el-select__dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:2000;background-color:#fff;border:1px solid #e4e7ed;border-radius:4px;box-shadow:0 2px 12px 0 rgba(0,0,0,.1);max-height:274px;overflow-y:auto;display:none}.el-select__dropdown.is-show{display:block}.el-select__search{padding:8px;border-bottom:1px solid #e4e7ed}.el-select__search-input{width:100%;padding:8px 12px;border:1px solid #dcdfe6;border-radius:4px;font-size:14px;outline:0;transition:border-color .2s}.el-select__search-input:focus{border-color:#409eff}.el-select__options{padding:6px 0;margin:0;list-style:none;max-height:200px;overflow-y:auto}.el-select__option{padding:8px 20px;font-size:14px;color:#606266;cursor:pointer;transition:background-color .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.el-select__option:hover{background-color:#f5f7fa}.el-select__option.is-selected{color:#409eff;font-weight:500;background-color:#ecf5ff}.el-select__option.is-disabled{color:#c0c4cc;cursor:not-allowed}.el-select__empty{padding:10px 0;margin:0;text-align:center;color:#999;font-size:14px}.el-select__dropdown::-webkit-scrollbar,.el-select__options::-webkit-scrollbar{width:6px}.el-select__dropdown::-webkit-scrollbar-track,.el-select__options::-webkit-scrollbar-track{background:#f5f7fa;border-radius:3px}.el-select__dropdown::-webkit-scrollbar-thumb,.el-select__options::-webkit-scrollbar-thumb{background:#c0c4cc;border-radius:3px}.el-select__dropdown::-webkit-scrollbar-thumb:hover,.el-select__options::-webkit-scrollbar-thumb:hover{background:#a8abb2}