@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}.graph-page{min-height:100vh;padding:48px clamp(16px,4vw,48px) 64px;background:radial-gradient(circle at top,#f7f3ec,#e8e0d4 45%,#d9cdbb);color:#1a2b3f;font-family:Space Grotesk,Segoe UI,system-ui,-apple-system,sans-serif}.graph-header{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:32px}.graph-actions{display:flex;align-items:center;gap:16px}.graph-nav{display:flex;align-items:center;gap:12px;background:#1a2b3f14;padding:8px 12px;border-radius:999px}.graph-id{display:flex;flex-direction:column;font-size:12px;gap:4px}.graph-id input{width:90px;border-radius:999px;border:1px solid rgba(26,43,63,.2);padding:6px 10px;font-size:14px;font-family:inherit}.graph-header h1{font-size:clamp(2rem,4vw,3.25rem);margin:6px 0 0}.graph-shell{background:#fdfbf7;border-radius:28px;padding:24px;box-shadow:0 20px 50px #1a2b3f26;min-height:min(70vh,640px);position:relative}.graph-shell-actions{position:absolute;top:18px;right:18px;z-index:1}.graph-shell-actions .ghost{padding:8px 14px;border-radius:999px;border:1px solid rgba(26,43,63,.25);background:#ffffffd9;color:#1a2b3f;font-weight:600;cursor:pointer}.graph-content{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:stretch}.save-shell{margin-bottom:24px;background:#ffffffb3;border-radius:20px;padding:16px 20px;box-shadow:0 12px 30px #1a2b3f14;display:flex;flex-direction:column;gap:12px}.save-row{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.graph-name{display:flex;flex-direction:column;gap:6px;font-size:12px}.graph-name input{min-width:240px;border-radius:999px;border:1px solid rgba(26,43,63,.2);padding:8px 14px;font-size:14px;font-family:inherit}.save-actions{display:flex;gap:10px}.save-actions button{border-radius:999px;border:none;padding:10px 16px;background:#1a2b3f;color:#f7f3ec;font-weight:600;cursor:pointer}.save-actions .ghost{background:transparent;border:1px solid rgba(26,43,63,.3);color:#1a2b3f}.graph-list{display:flex;align-items:center;gap:12px;font-size:12px}.graph-list select{border-radius:999px;border:1px solid rgba(26,43,63,.2);padding:6px 12px;font-size:14px;font-family:inherit}.chat-shell{background:#fff8ee;border-radius:24px;padding:20px;box-shadow:0 16px 40px #1a2b3f1f;height:min(70vh,640px);display:flex;flex-direction:column}.chat-log{display:flex;flex-direction:column;gap:12px;flex:1;overflow-y:auto;margin-bottom:16px}.chat-bubble{padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.4;max-width:90%}.chat-bubble.user{align-self:flex-end;background:#1a2b3f;color:#f7f3ec}.chat-bubble.assistant{align-self:flex-start;background:#e1d7c7;color:#1a2b3f}.chat-form{display:flex;gap:12px}.chat-form input{flex:1;border-radius:999px;border:1px solid rgba(26,43,63,.2);padding:10px 16px;font-size:14px;font-family:inherit}.chat-form button{border-radius:999px;border:none;padding:10px 18px;background:#1a2b3f;color:#f7f3ec;font-weight:600;cursor:pointer}.chat-form button:disabled{opacity:.6;cursor:not-allowed}.error-text{color:#9e2f2f}@media(max-width:640px){.graph-header{flex-direction:column;align-items:flex-start}.graph-actions{width:100%;flex-direction:column;align-items:flex-start}.graph-nav{width:100%;justify-content:space-between}.graph-shell{height:60vh}.graph-content{grid-template-columns:1fr}.chat-shell{height:auto}.save-row,.graph-name input{width:100%}.save-actions{width:100%;flex-direction:column}.save-actions button{width:100%}.chat-form{flex-direction:column}.chat-form button{width:100%}}#root{max-width:1200px;margin:0 auto;padding:48px 20px 64px;color:#0e1116}.page{display:flex;flex-direction:column;gap:28px}.top-nav{background:linear-gradient(120deg,#f2f7ff,#f5faff 55%,#fff5ea);border:1px solid rgba(14,17,22,.08);padding:16px 22px;border-radius:16px;box-shadow:0 18px 40px #0e111614}.nav-row{display:flex;align-items:center;justify-content:space-between;gap:20px}.brand{display:flex;flex-direction:column;gap:4px}.brand-eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:10px;font-weight:700;color:#4d6a90}.brand-title{font-size:18px;font-weight:650;letter-spacing:-.01em;color:#0f1d2f}.nav-actions{display:flex;align-items:center;gap:14px}.auth-status{display:flex;align-items:center;gap:12px}.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:700;color:#415f8b;margin:0 0 6px}.primary{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:999px;background:#0f1d2f;color:#f5f8ff;text-decoration:none;font-weight:600;border:1px solid rgba(15,29,47,.25);transition:transform .2s ease,box-shadow .2s ease}.primary:hover{transform:translateY(-1px);box-shadow:0 12px 24px #0f1d2f2e}.primary:active{transform:translateY(0)}.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}.sandbox-note{grid-column:1 / -1;padding:12px 14px;border-radius:12px;border:1px solid rgba(14,17,22,.08);background:linear-gradient(120deg,#fff7ed,#fffdf8);color:#3a2d1b;display:flex;flex-direction:column;gap:6px}.sandbox-note p{margin:0}.saved-list{grid-column:1 / -1;display:flex;flex-direction:column;gap:6px}.marketing-panel h3{margin:0 0 6px;font-size:16px}.marketing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.marketing-card{padding:14px;border-radius:14px;border:1px solid rgba(14,17,22,.08);background:#f8fbff;box-shadow:inset 0 0 0 1px #ffffff59}.marketing-card p{margin:0;color:#2a3647}.marketing-footer{display:flex;flex-wrap:wrap;gap:10px}.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}.nav-row{flex-direction:column}.nav-actions{width:100%;flex-direction:column;align-items:flex-start}.primary{width:100%}.panel-heading{flex-direction:column}.stop-row{flex-direction:column;align-items:flex-start}.stop-meta{width:100%;justify-content:space-between}}
