@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{font-family:Space Grotesk,Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.6;font-weight:500;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at 15% 30%,#f6fbff,#edf4ff 35%,#e8f5ff 45%,#fef8f3);min-height:100vh}a{color:inherit;text-decoration:none}#root{max-width:1200px;margin:0 auto;padding:48px 20px 64px;color:#0e1116}.page{display:flex;flex-direction:column;gap:28px}.hero{background:linear-gradient(135deg,#f2f7ff,#eaf5ff 55%,#fff7ed);border:1px solid rgba(14,17,22,.06);padding:28px 24px;border-radius:20px;box-shadow:0 30px 70px #0e111614}.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:700;color:#415f8b;margin:0 0 6px}.hero h1{margin:0;font-size:clamp(28px,4vw,38px);letter-spacing:-.01em}.lede{margin:8px 0 16px;color:#2a3647;max-width:780px}.hero-pills{display:flex;flex-wrap:wrap;gap:10px}.hero-pills span{background:#0f1d2f;color:#f5f8ff;padding:8px 12px;border-radius:999px;font-size:13px;border:1px solid rgba(255,255,255,.22)}.layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.panel{background:#fff;border-radius:18px;padding:20px;border:1px solid rgba(14,17,22,.06);box-shadow:0 20px 50px #0e11160a;display:flex;flex-direction:column;gap:14px}.panel.wide{grid-column:1 / -1}.panel-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.panel h2{margin:0;letter-spacing:-.01em}.hint{margin:0;color:#5c6471;font-size:14px}.status{margin-top:8px;font-style:italic}.field-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.field{display:flex;flex-direction:column;gap:6px;font-size:14px;color:#1a2738}.field input{border-radius:12px;border:1px solid rgba(14,17,22,.12);padding:12px;font-size:15px;font-family:inherit;background:#fbfdff;transition:border-color .2s ease,box-shadow .2s ease}.field input:focus{outline:none;border-color:#2a7df7;box-shadow:0 0 0 3px #2a7df726}.stop-form{display:flex;flex-direction:column;gap:12px}button{border-radius:12px;border:1px solid rgba(14,17,22,.1);padding:11px 14px;font-size:15px;font-weight:600;font-family:inherit;background-color:#0f1d2f;color:#f6fbff;cursor:pointer;transition:transform .1s ease,box-shadow .2s ease,opacity .2s ease}button:hover{transform:translateY(-1px);box-shadow:0 10px 20px #0e111629}button:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}button.primary{align-self:flex-start;background:linear-gradient(120deg,#0f7cf7,#0f5ad7);border-color:transparent}.stop-list{display:flex;flex-direction:column;gap:10px}.stop-row{padding:12px;border-radius:14px;border:1px solid rgba(14,17,22,.08);background:#f8fbff;display:flex;align-items:center;justify-content:space-between;gap:12px}.stop-main{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:flex-start}.select-box input{width:16px;height:16px}.stop-name{margin:0 0 4px;font-weight:700}.stop-note{margin:0;color:#4c5360;font-size:14px}.stop-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.pill{padding:6px 10px;border-radius:999px;background:#0f7df71a;color:#0f5ad7;font-weight:700;font-size:13px}.row-actions{display:flex;gap:6px}.row-actions button{padding:8px 10px;background:#0e1116;color:#f8fbff;border-radius:10px;min-width:36px}.join-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;margin:6px 0 10px}.join-row select{border-radius:10px;padding:10px;border:1px solid rgba(14,17,22,.12);background:#fbfdff;font-size:14px}.tiny-grid{display:grid;grid-template-columns:repeat(2,minmax(70px,1fr));gap:6px;font-size:12px}.tiny-grid label{display:flex;flex-direction:column;gap:4px;color:#2a3647}.tiny-grid input{border-radius:8px;border:1px solid rgba(14,17,22,.12);padding:8px;font-size:13px;background:#fbfdff}.controls-row{margin-top:10px}.live-map{height:380px;border-radius:14px;overflow:hidden;border:1px solid rgba(14,17,22,.06)}.leaflet-container{height:100%;width:100%}.map-shell{border-radius:16px;background:linear-gradient(180deg,#0b1a2e,#13243a);padding:16px}.canvas-shell{position:relative;border-radius:16px;overflow:hidden;border:1px solid rgba(14,17,22,.06);background:#0c1a2c;min-height:360px;cursor:crosshair}.route-canvas{width:100%;height:420px;display:block}.canvas-hint{position:absolute;bottom:10px;right:14px;margin:0;padding:6px 10px;border-radius:10px;background:#ffffff14;color:#f7fbff;font-size:13px}.link-legend{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:10px 0}.chip{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;background:#0f7df71f;color:#0f5ad7;font-weight:700;font-size:13px}.chip.live{background:#ffc14f29;color:#a45b00}.arrow-editor{display:inline-flex;gap:6px;align-items:center}.arrow-editor select{border-radius:8px;padding:6px 8px;border:1px solid rgba(14,17,22,.12);background:#fbfdff}.text-link{background:none;border:none;padding:0;color:#0f5ad7;text-decoration:underline;cursor:pointer;font-weight:600}.text-link.node-label{font-size:14px;text-align:left;display:inline}.ghost{background:#fff;color:#0f1d2f;border:1px dashed rgba(14,17,22,.2)}.rename-bar{margin:10px 0 14px;padding:12px;border-radius:12px;border:1px dashed rgba(14,17,22,.1);background:#f8fbff;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.rename-bar input{width:240px;max-width:100%;padding:10px 12px;border-radius:10px;border:1px solid rgba(14,17,22,.12);background:#fff}.rename-actions{display:flex;gap:8px}.model-bar{margin:12px 0 16px;padding:12px;border-radius:12px;border:1px solid rgba(14,17,22,.08);background:#fff;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;align-items:end}.saved-list{grid-column:1 / -1;display:flex;flex-direction:column;gap:6px}.saved-row{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border:1px solid rgba(14,17,22,.08);border-radius:10px;background:#f8fbff}.map-bg{position:relative;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.08),transparent 45%),radial-gradient(circle at 80% 50%,rgba(255,255,255,.08),transparent 40%),#0c1a2c;border-radius:12px;min-height:360px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.path{position:absolute;left:32px;top:16px;bottom:16px;width:4px;background:linear-gradient(180deg,#5fd8ff,#2fb3ff,#2b71ff);border-radius:999px;box-shadow:0 0 18px #5fd8ff73}.node{position:absolute;left:20px;display:flex;align-items:center;gap:12px}.node-dot{width:14px;height:14px;border-radius:50%;border:3px solid #0c1a2c;background:#87f0ff;box-shadow:0 6px 14px #00000059}.node-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.12);padding:10px 12px;border-radius:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);min-width:240px}.node-label{margin:0;color:#f7fbff;font-weight:700}.node-note{margin:4px 0 0;color:#c7d9ff;font-size:13px}.node.start .node-dot{background:#7af37a}.node.end .node-dot{background:#ffc773}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.stat{font-size:20px;margin:2px 0 0;font-weight:700;color:#0f1d2f}@media(max-width:640px){#root{padding:32px 16px 48px}.panel-heading{flex-direction:column}.stop-row{flex-direction:column;align-items:flex-start}.stop-meta{width:100%;justify-content:space-between}}
