.city-input{display:flex;flex-direction:column;gap:12px}.ci-title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text)}.ci-subtitle{color:var(--muted);font-size:13px;margin-top:-8px}.ci-list{display:flex;flex-direction:column;gap:10px}.ci-row{display:flex;align-items:center;gap:10px}.ci-num{width:28px;height:28px;border-radius:50%;background:color-mix(in srgb,var(--color) 20%,transparent);border:1.5px solid color-mix(in srgb,var(--color) 60%,transparent);color:var(--color);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-display)}.ci-input{flex:1;background:var(--surface2);border:1.5px solid var(--border);border-radius:10px;padding:10px 14px;color:var(--text);font-family:var(--font-body);font-size:14px;transition:border-color .2s,box-shadow .2s;outline:none}.ci-input:focus{border-color:var(--color, var(--accent));box-shadow:0 0 0 3px color-mix(in srgb,var(--color, var(--accent)) 15%,transparent)}.ci-input::placeholder{color:var(--muted)}.ci-remove{background:none;border:1px solid var(--border);color:var(--muted);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.ci-remove:hover{border-color:var(--accent2);color:var(--accent2);background:#ff6b6b14}.ci-add{background:none;border:1.5px dashed var(--border);color:var(--muted);padding:10px;border-radius:10px;cursor:pointer;font-size:13px;font-family:var(--font-body);transition:all .2s;width:100%}.ci-add:hover{border-color:var(--accent);color:var(--accent);background:#4fffb00a}.ci-filter{display:flex;flex-direction:column;gap:8px}.ci-filter-label{font-size:11px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}.ci-filter-options{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.ci-filter-btn{background:var(--surface2);border:1.5px solid var(--border);border-radius:10px;padding:8px 6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;transition:all .2s}.ci-filter-btn:hover{border-color:#4fffb066}.ci-filter-btn.active{border-color:var(--accent);background:#4fffb014}.cfb-label{font-family:var(--font-display);font-size:11px;font-weight:600;color:var(--text)}.cfb-desc{font-size:10px;color:var(--muted)}.ci-filter-btn.active .cfb-label{color:var(--accent)}.ci-search{background:var(--accent);border:none;color:var(--bg);padding:13px 20px;border-radius:12px;cursor:pointer;font-family:var(--font-display);font-size:14px;font-weight:700;letter-spacing:.3px;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;width:100%}.ci-search:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #4fffb059}.ci-search:disabled{opacity:.4;cursor:not-allowed}.ci-spinner{width:16px;height:16px;border:2.5px solid rgba(0,0,0,.2);border-top-color:var(--bg);border-radius:50%;animation:spin .7s linear infinite}.ci-mode-btn{width:32px;height:32px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface2);cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.ci-mode-btn.train{border-color:#4fffb080;background:#4fffb014}.ci-mode-btn.car{border-color:#ffa50080;background:#ffa5000f}.ci-mode-btn:hover{transform:scale(1.1)}.map-wrapper{position:relative;width:100%;height:100%}.leaflet-map{width:100%;height:100%}.map-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0a0fb3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center}.map-loader{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--text);font-size:14px;font-family:var(--font-display)}.loader-ring{width:48px;height:48px;border:3px solid rgba(79,255,176,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.map-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:500;pointer-events:none;background:#0a0a0f99}.placeholder-icon{font-size:48px;opacity:.5}.map-placeholder p{color:var(--muted);font-size:14px}.mp-marker-wrap{background:transparent!important;border:none!important}.mp-marker-inner{width:20px;height:20px;border-radius:50%;background:#4fffb0;border:3px solid #0a0a0f;box-shadow:0 0 #4fffb099;animation:mp-pulse 2s ease-out infinite}@keyframes mp-pulse{0%{box-shadow:0 0 #4fffb099}70%{box-shadow:0 0 0 14px #4fffb000}to{box-shadow:0 0 #4fffb000}}.result-cards{display:flex;flex-direction:column;gap:14px;animation:fadeUp .4s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.proposals-label{font-size:11px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}.proposal-tabs{display:flex;flex-direction:column;gap:6px}.proposal-tab{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1.5px solid var(--border);border-radius:10px;padding:10px 14px;cursor:pointer;transition:all .2s;text-align:left}.proposal-tab:hover{border-color:#4fffb059}.proposal-tab.active{border-color:var(--accent);background:#4fffb00f}.pt-rank{font-family:var(--font-display);font-size:11px;font-weight:700;color:var(--muted);min-width:22px}.proposal-tab.active .pt-rank{color:var(--accent)}.pt-city{font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--text);flex:1}.pt-duration{font-size:12px;color:var(--muted);background:var(--surface);padding:2px 8px;border-radius:6px;border:1px solid var(--border)}.proposal-tab.active .pt-duration{color:var(--accent);border-color:#4fffb04d;background:#4fffb00f}.meeting-banner{display:flex;align-items:flex-start;gap:14px;background:linear-gradient(135deg,#4fffb01a,#4fffb00a);border:1.5px solid rgba(79,255,176,.25);border-radius:var(--radius);padding:16px 18px}.meeting-icon{font-size:24px;flex-shrink:0;margin-top:2px}.meeting-label{font-size:11px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:2px}.meeting-city{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text);line-height:1.2}.meeting-sub{font-size:12px;color:var(--muted);margin-top:2px}.meeting-stats{display:flex;gap:12px;margin-top:8px}.meeting-stats span{font-size:12px;color:var(--accent);background:#4fffb01a;padding:2px 8px;border-radius:5px}.distances-title{font-size:12px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}.distances-list{display:flex;flex-direction:column;gap:10px}.distance-card{background:var(--surface2);border:1px solid var(--border);border-left:3px solid var(--color);border-radius:var(--radius);padding:14px 16px}.dc-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.dc-dot{width:8px;height:8px;border-radius:50%;background:var(--color);flex-shrink:0}.dc-city{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--text)}.dc-approx{font-size:11px;color:var(--muted);background:var(--surface);padding:1px 6px;border-radius:4px;border:1px solid var(--border)}.dc-modes{display:flex;align-items:center;gap:12px}.dc-mode{display:flex;align-items:center;gap:8px;flex:1}.dc-mode-icon{font-size:16px}.dc-mode-data{display:flex;flex-direction:column;gap:1px}.dc-val{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text)}.dc-dur{font-size:11px;color:var(--muted)}.dc-na{font-size:12px;color:var(--muted);font-style:italic}.dc-divider{width:1px;height:32px;background:var(--border)}.sort-bar{display:flex;align-items:center;gap:10px}.sort-label{font-size:11px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--muted);white-space:nowrap}.sort-toggle{display:flex;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:3px;gap:3px}.sort-btn{background:none;border:none;color:var(--muted);font-family:var(--font-display);font-size:12px;font-weight:600;padding:6px 12px;border-radius:7px;cursor:pointer;transition:all .2s;white-space:nowrap}.sort-btn:hover:not(:disabled){color:var(--text)}.sort-btn.active{background:var(--accent);color:var(--bg)}.sort-btn:disabled{opacity:.3;cursor:not-allowed}.distance-card.worst{border-left-color:var(--accent2);background:#ff6b6b0a}.dc-longest{font-size:10px;color:var(--accent2);background:#ff6b6b1f;padding:1px 7px;border-radius:5px;margin-left:auto}.sort-hint{font-size:11px;color:var(--muted);font-style:italic;margin-left:auto}.dc-mode.active-mode .dc-val{color:var(--text);font-weight:600}.dc-mode.active-mode .dc-mode-icon{opacity:1}.dc-mode:not(.active-mode){opacity:.45}.dc-mode-badge{font-size:13px;margin-left:2px}.dc-na-secondary{opacity:.3}.distance-card.worst{border-left-color:var(--color);background:rgba(from var(--color) r g b / .06)}.dc-longest{font-size:10px;color:var(--color);margin-left:auto}.search-progress{display:flex;flex-direction:column;gap:16px;padding:20px;background:var(--card-bg);border-radius:12px;border:1px solid var(--border);margin-top:12px}.sp-spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 4px}@keyframes spin{to{transform:rotate(360deg)}}.sp-steps{display:flex;flex-direction:column;gap:8px}.sp-step{display:flex;align-items:center;gap:10px;font-size:13px;transition:opacity .2s}.sp-step.pending{opacity:.35}.sp-step.done{opacity:.6}.sp-step.active{opacity:1}.sp-icon{width:22px;text-align:center;font-size:15px}.sp-step.done .sp-icon{color:var(--accent);font-style:normal;font-size:13px;font-weight:700}.sp-label{color:var(--text);flex:1}.sp-step.active .sp-label{font-weight:600}.sp-detail{font-size:11px;color:var(--muted);font-style:italic;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.header{display:flex;align-items:center;gap:20px;padding:16px 28px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.header-logo{display:flex;align-items:center;gap:10px}.logo-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.7}}.logo-text{font-family:var(--font-display);font-size:22px;font-weight:800;letter-spacing:-.5px;color:var(--text)}.header-tagline{color:var(--muted);font-size:13px;font-weight:300}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.main{display:grid;grid-template-columns:420px 1fr;flex:1;overflow:hidden}.left-panel{background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;padding:28px 24px;display:flex;flex-direction:column;gap:20px}.map-panel{position:relative;background:var(--bg)}.error-box{background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);color:var(--accent2);padding:14px 16px;border-radius:var(--radius);font-size:14px}@media (max-width: 768px){.app{overflow:auto}.main{grid-template-columns:1fr;grid-template-rows:auto 400px;overflow:visible}.map-panel{height:400px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0f;--surface: #12121a;--surface2: #1a1a26;--border: rgba(255,255,255,.08);--accent: #4fffb0;--accent2: #ff6b6b;--accent3: #6b8cff;--text: #f0f0f5;--muted: #6e6e8a;--radius: 16px;--font-display: "Syne", sans-serif;--font-body: "Inter", sans-serif}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.6}::selection{background:var(--accent);color:var(--bg)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.leaflet-container{background:#1a1a2e}.leaflet-tile{filter:brightness(.75) saturate(.8)}
