:root{color-scheme:dark;--bg: #0b0f1a;--panel: rgba(17, 23, 39, .88);--panel-strong: rgba(17, 23, 39, .95);--accent: #47f3ff;--accent-dark: #1fb7c5;--accent-soft: rgba(71, 243, 255, .12);--accent-glow: rgba(71, 243, 255, .4);--ink: #e7edf5;--ink-secondary: #c5d1e3;--muted: #93a0b5;--stroke: rgba(255, 255, 255, .08);--shadow: 0 35px 90px rgba(5, 10, 20, .65);--shadow-sm: 0 8px 24px rgba(5, 10, 20, .45);--shadow-lg: 0 50px 120px rgba(5, 10, 20, .75);--glow: 0 0 0 1px rgba(255, 255, 255, .08) inset;--grid: rgba(71, 243, 255, .06);font-family:Sora,system-ui,sans-serif}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at 12% 12%,rgba(71,243,255,.2),transparent 42%),radial-gradient(circle at 88% 18%,rgba(142,126,255,.18),transparent 48%),radial-gradient(circle at 50% 100%,rgba(71,243,255,.08),transparent 35%),linear-gradient(135deg,#0b0f1a,#0e1425 45%,#0a1220);background-attachment:fixed;color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#070c1899;border-radius:10px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#47f3ff66,#47f3ff33);border-radius:10px;border:2px solid rgba(7,12,24,.6);transition:background .3s ease}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#47f3ff99,#47f3ff4d)}::selection{background:#47f3ff4d;color:var(--ink)}.app{min-height:100vh;display:flex;flex-direction:column;gap:2rem;padding:2rem clamp(1.5rem,4vw,4.5rem) 2.5rem;position:relative}.app:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-size:120px 120px;opacity:.35;pointer-events:none}.app__header{display:grid;gap:1.5rem;grid-template-columns:minmax(260px,1fr) auto;align-items:center;position:relative;z-index:1}.app__header h1{font-size:clamp(2.6rem,4.5vw,4.2rem);margin:0;letter-spacing:-.03em;background:linear-gradient(135deg,var(--ink) 0%,rgba(255,255,255,.85) 50%,rgba(71,243,255,.9) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;animation:glow-pulse 3s ease-in-out infinite}@keyframes glow-pulse{0%,to{filter:drop-shadow(0 0 20px rgba(71,243,255,.3))}50%{filter:drop-shadow(0 0 30px rgba(71,243,255,.5))}}.hero{display:grid;gap:.6rem}.subtitle{margin:0;font-size:1.05rem;color:var(--ink-secondary);max-width:520px;line-height:1.7;font-weight:400}.eyebrow{font-family:Space Mono,monospace;text-transform:uppercase;letter-spacing:.32em;font-size:.65rem;color:var(--accent);margin:0;text-shadow:0 0 10px rgba(71,243,255,.5);animation:flicker 4s ease-in-out infinite}@keyframes flicker{0%,to{opacity:1}50%{opacity:.9}}.status{display:flex;align-items:center;gap:1rem;font-weight:600;color:var(--muted);z-index:1}.stat{display:grid;gap:.2rem;padding:.85rem 1.2rem;border-radius:18px;background:linear-gradient(135deg,#0e1424d9,#111727bf);border:1px solid rgba(71,243,255,.25);box-shadow:var(--shadow-sm),var(--glow);transition:all .3s ease}.stat:hover{border-color:#47f3ff66;box-shadow:0 12px 32px #050a1499,var(--glow),0 0 30px #47f3ff1a;transform:translateY(-2px)}.stat__label{font-size:.7rem;text-transform:uppercase;letter-spacing:.2em}.stat__value{font-size:1.2rem;color:var(--ink)}.pill{padding:.75rem 1.1rem;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-weight:700;border:1px solid rgba(71,243,255,.3)}.spinner{width:1.6rem;height:1.6rem;border-radius:999px;border:3px solid rgba(71,243,255,.15);border-top-color:var(--accent);animation:spin .8s cubic-bezier(.4,0,.2,1) infinite;box-shadow:0 0 20px #47f3ff4d;filter:drop-shadow(0 0 8px rgba(71,243,255,.4))}@keyframes spin{to{transform:rotate(360deg)}}.app__content{display:grid;gap:1.8rem;grid-template-columns:minmax(300px,380px) 1fr;align-items:start;position:relative;z-index:1}.panel{background:var(--panel);padding:1.8rem;border-radius:28px;box-shadow:var(--shadow),var(--glow);display:flex;flex-direction:column;gap:1.8rem;border:1px solid rgba(71,243,255,.12);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);position:relative;overflow:hidden}.panel:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(71,243,255,.3) 50%,transparent);opacity:.6}.label{font-weight:700;margin:0 0 .5rem}.search input,select,button,input[type=number]{font-family:inherit;font-size:.95rem}.search__row{display:grid;grid-template-columns:1fr auto;gap:.75rem}input,select{padding:.85rem 1rem;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#070c18bf;color:var(--ink);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--glow);font-size:.95rem}input::placeholder{color:var(--muted);opacity:.6}input:hover,select:hover{border-color:#fff3}input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #47f3ff33,0 0 20px #47f3ff1a;background:#070c18e6}button{border:none;padding:.85rem 1.35rem;border-radius:16px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:#061018;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 12px 32px #47f3ff4d,0 4px 12px #47f3ff33;position:relative;overflow:hidden}button:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.2),transparent);opacity:0;transition:opacity .3s ease}button:hover{transform:translateY(-2px);box-shadow:0 16px 40px #47f3ff66,0 6px 16px #47f3ff4d}button:hover:before{opacity:1}button:active{transform:translateY(0);transition-duration:.1s}button:disabled{background:#47f3ff40;cursor:not-allowed;transform:none;opacity:.5;box-shadow:none}button.ghost{background:#11172799;color:var(--ink);border:1px solid rgba(255,255,255,.15);box-shadow:var(--shadow-sm),var(--glow)}button.ghost:hover{background:#111727cc;border-color:#47f3ff4d}.controls{display:grid;gap:1.4rem}.controls__section,.controls__actions{display:grid;gap:.75rem}.list{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}.list li{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1rem;border-radius:16px;background:#090e1ae6;border:1px solid rgba(255,255,255,.1);transition:all .3s ease;box-shadow:var(--glow)}.list li:hover{border-color:#47f3ff33;background:#0e1424f2;transform:translate(4px)}.list button{background:transparent;color:#ff6b6b;padding:.4rem .7rem;box-shadow:none;font-size:.9rem;border-radius:12px}.list button:hover{background:#ff6b6b33;color:#ff8f8f;transform:translateY(0)}.field{display:grid;gap:.4rem}.field--inline{grid-auto-flow:column;align-items:center;justify-content:space-between}input[type=checkbox]{width:1.05rem;height:1.05rem;accent-color:var(--accent)}.map{min-height:700px}.map__wrapper{width:100%;height:100%;border-radius:28px;overflow:hidden;border:1px solid rgba(71,243,255,.15);box-shadow:0 30px 70px #060a148c;background:#0c101c;position:relative}.map__canvas{width:100%;height:100%;min-height:750px}.error{color:#ff8f8f;font-weight:600;padding:.85rem 1.2rem;border-radius:16px;background:linear-gradient(135deg,#ff475726,#ff475714);border:1px solid rgba(255,71,87,.3);box-shadow:0 8px 24px #ff475726}.hint{color:var(--muted);font-size:.85rem}.empty{color:var(--muted);font-size:.9rem}.panel,.map__wrapper{animation:rise .5s ease}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.path-summary{position:relative;z-index:1;margin-top:1rem}.path-summary__title{font-size:1.7rem;margin:0 0 1.5rem;letter-spacing:-.02em;background:linear-gradient(135deg,var(--ink) 0%,rgba(255,255,255,.8) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;padding-bottom:1rem}.path-summary__title:after{content:"";position:absolute;bottom:0;left:0;width:80px;height:3px;background:linear-gradient(90deg,var(--accent),transparent);border-radius:2px;box-shadow:0 0 10px #47f3ff80}.path-list{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.path-list>*{animation:fadeInUp .6s ease backwards}.path-list>*:nth-child(1){animation-delay:.1s}.path-list>*:nth-child(2){animation-delay:.2s}.path-list>*:nth-child(3){animation-delay:.3s}.path-list>*:nth-child(4){animation-delay:.4s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.path-item{background:linear-gradient(135deg,#0e1424e6,#111727d9);padding:1.4rem;border-radius:20px;border:1px solid rgba(255,71,87,.3);box-shadow:var(--shadow-sm),0 0 30px #ff475714;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.path-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,71,87,.08),transparent);transition:left .6s ease}.path-item:hover:before{left:100%}.path-item:hover{border-color:#ff475780;box-shadow:0 16px 48px #050a14a6,0 0 50px #ff475726;transform:translateY(-4px)}.path-item--optimal{background:linear-gradient(135deg,#0e1424f2,#111727e6);border-color:#47f3ff80;box-shadow:0 16px 48px #050a1499,0 0 40px #47f3ff26,inset 0 1px #47f3ff1a}.path-item--optimal:before{background:linear-gradient(90deg,transparent,rgba(71,243,255,.12),transparent)}.path-item--optimal:hover{border-color:#47f3ffb3;box-shadow:0 20px 56px #050a14b3,0 0 60px #47f3ff40,inset 0 1px #47f3ff33}.path-item--alternative{border-color:#ff475740}.path-item--info{border-color:#47f3ff14;background:#111727b3;text-align:center}.path-item__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}.path-item__badge{font-size:.75rem;font-family:Space Mono,monospace;text-transform:uppercase;letter-spacing:.2em;font-weight:700;padding:.45rem .85rem;border-radius:12px;box-shadow:0 4px 12px #0000004d;transition:all .3s ease;display:inline-flex;align-items:center;gap:.4rem}.path-item__badge:hover{transform:scale(1.05)}.path-item--optimal .path-item__badge{background:linear-gradient(135deg,#47f3ff40,#47f3ff26);color:var(--accent);border:1px solid rgba(71,243,255,.4);text-shadow:0 0 8px rgba(71,243,255,.5)}.path-item--alternative .path-item__badge{background:linear-gradient(135deg,#ff475740,#ff475726);color:#ff8f8f;border:1px solid rgba(255,71,87,.4)}.path-item__distance{font-size:1.2rem;font-weight:800;color:var(--ink);letter-spacing:-.01em;text-shadow:0 2px 8px rgba(0,0,0,.2)}.percent-diff{font-size:.85rem;color:#ff8f8f;font-weight:600;opacity:.9;padding:.25rem .6rem;border-radius:8px;background:#ff475726;display:inline-block;margin-top:.3rem}.path-item__route{margin:.8rem 0 .6rem;font-size:.9rem;color:var(--ink-secondary);line-height:1.6;font-weight:500}.path-item__duration{margin:0;font-size:.8rem;color:var(--muted);opacity:.9;display:flex;align-items:center;gap:.4rem;font-weight:500}.duration-icon{font-size:1rem;color:var(--accent);opacity:.8}.metrics-panel{margin-top:2rem}.metrics-panel__title{font-size:1.7rem;margin:0 0 1.5rem;letter-spacing:-.02em;background:linear-gradient(135deg,var(--ink) 0%,rgba(255,255,255,.8) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;padding-bottom:1rem}.metrics-panel__title:after{content:"";position:absolute;bottom:0;left:0;width:80px;height:3px;background:linear-gradient(90deg,var(--accent),transparent);border-radius:2px;box-shadow:0 0 10px #47f3ff80}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.metric-card{padding:1.4rem;border-radius:20px;background:linear-gradient(135deg,#0e1424e6,#111727d9);border:1px solid rgba(71,243,255,.15);box-shadow:var(--shadow-sm),0 0 20px #47f3ff0d;transition:all .3s ease;display:flex;flex-direction:column;gap:.6rem}.metric-card:hover{border-color:#47f3ff4d;box-shadow:0 16px 48px #050a14a6,0 0 30px #47f3ff1a;transform:translateY(-4px)}.metric-card--highlight{border-color:#47f3ff66;background:linear-gradient(135deg,#0e1424f2,#111727e6);box-shadow:0 12px 36px #050a1499,0 0 30px #47f3ff1f}.metric-card--complexity{border-color:#8e7eff4d;box-shadow:var(--shadow-sm),0 0 20px #8e7eff14}.metric-card--complexity:hover{border-color:#8e7eff80;box-shadow:0 16px 48px #050a14a6,0 0 30px #8e7eff26}.metric-card__label{font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);font-weight:700}.metric-card__value{font-size:1.6rem;font-weight:800;color:var(--accent);font-family:Space Mono,monospace;letter-spacing:-.02em}.metric-card--highlight .metric-card__value{font-size:1.8rem;text-shadow:0 0 20px rgba(71,243,255,.4)}.complexity-formula{font-size:1.6rem;font-weight:800;color:var(--accent);font-family:Space Mono,monospace;letter-spacing:-.02em}.metric-card__desc{font-size:.85rem;color:var(--ink-secondary);opacity:.8}.algo-viz{margin-top:2rem}.algo-viz__header{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.algo-viz__title{font-size:1.7rem;margin:0;letter-spacing:-.02em;background:linear-gradient(135deg,var(--ink) 0%,rgba(255,255,255,.8) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.algo-viz__progress{display:flex;flex-direction:column;gap:.5rem}.algo-viz__step-count{font-family:Space Mono,monospace;font-size:.85rem;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.1em}.progress-bar{height:8px;background:#0e1424cc;border-radius:999px;overflow:hidden;border:1px solid rgba(71,243,255,.2)}.progress-bar__fill{height:100%;background:linear-gradient(90deg,var(--accent),rgba(142,126,255,.8));border-radius:999px;transition:width .5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 15px #47f3ff99}.algo-viz__content{display:flex;flex-direction:column;gap:1.5rem}.step-info{background:linear-gradient(135deg,#0e1424f2,#111727e6);padding:1.5rem;border-radius:18px;border:1px solid rgba(71,243,255,.2);box-shadow:var(--shadow-sm),0 0 25px #47f3ff14}.step-info__action{font-size:1.1rem;font-weight:700;color:var(--accent);margin-bottom:1.2rem;padding-bottom:1rem;border-bottom:1px solid rgba(71,243,255,.15)}.step-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.step-detail{display:flex;flex-direction:column;gap:.4rem}.step-detail__label{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:700}.step-detail__value{font-size:1.1rem;font-weight:700;color:var(--ink);font-family:Space Mono,monospace}.node-badge{display:inline-block;padding:.3rem .8rem;border-radius:10px;background:#47f3ff33;color:var(--accent);border:1px solid rgba(71,243,255,.3);font-size:.9rem}.relaxations{margin-top:1.2rem;padding-top:1.2rem;border-top:1px solid rgba(71,243,255,.15)}.relaxations__title{font-size:.9rem;font-weight:700;color:var(--ink-secondary);margin-bottom:.8rem;text-transform:uppercase;letter-spacing:.08em}.relaxations__list{display:flex;flex-direction:column;gap:.6rem}.relaxation-item{display:flex;align-items:center;gap:.7rem;padding:.8rem 1rem;background:#070c1899;border-radius:12px;border:1px solid rgba(255,255,255,.08);font-family:Space Mono,monospace;font-size:.85rem;flex-wrap:wrap}.relaxation-item__node{color:var(--ink);font-weight:700;flex-shrink:0}.relaxation-item__arrow{color:var(--muted);opacity:.6;flex-shrink:0}.relaxation-item__distance{color:#ff6b6bcc;text-decoration:line-through;flex-shrink:0}.relaxation-item__new{color:var(--accent);font-weight:700;flex-shrink:0}.relaxation-item__improvement{color:#90ee90;font-size:.8rem;margin-left:auto;flex-shrink:0}.algo-viz__controls{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}.play-button{min-width:140px}@media (max-width: 960px){.app__content,.app__header{grid-template-columns:1fr}.map__canvas{min-height:460px}.path-list,.metrics-grid,.step-details{grid-template-columns:1fr}.algo-viz__controls button{flex:1;min-width:100px}}
