body{margin:0;padding:0}:root{--map-bg: #f4f7fa;--land-fill: #e0ecf8;--land-stroke: #ffffff;--text-main: #334155;--text-muted: #64748b;--dot-color: #94a3b8;--dot-city: #3b82f6;--dot-temple: #8b4513;--dot-mountain: #22c55e;--text-temple: #78350f;--text-mountain: #14532d;--dot-active: var(--dot-city);--line-color: #64748b;--route-a: #4f7fac;--route-b: #6b9658;--route-c: #d99763;--route-d: #835b8f;--sidebar-w: 320px}body{font-family:Inter,system-ui,-apple-system,sans-serif;margin:0;padding:0;background-color:var(--map-bg);color:var(--text-main)}.map-app-container{display:flex;height:100vh;width:100vw;overflow:hidden}.sidebar{width:var(--sidebar-w);background:#fff;padding:2rem;box-shadow:2px 0 15px #0000000d;display:flex;flex-direction:column;gap:2rem;z-index:10;overflow-y:auto}.sidebar h2{margin:0;font-size:1.5rem;font-weight:700;color:#0f172a}.sidebar p{margin:0;font-size:.95rem;color:var(--text-muted);line-height:1.5}.route-controls h3,.selections h3,.transport-controls h3{font-size:1.1rem;margin-bottom:1rem;color:#1e293b;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.route-controls,.transport-controls{display:flex;flex-direction:column;gap:.75rem}.mode-selector{display:flex;gap:.5rem;flex-wrap:wrap}.transport-btn{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:1.4rem;display:flex;align-items:center;justify-content:center;width:44px;height:44px;transition:all .2s ease}.transport-btn:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-2px)}.transport-btn.active{background:#e0ecf8;border-color:var(--dot-city);box-shadow:0 4px 12px #3b82f633}.route-btn{display:flex;align-items:center;gap:.75rem;background:#f8fafc;border:1px solid #e2e8f0;padding:.8rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--text-main);text-align:left;transition:all .2s ease}.route-btn:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px)}.route-btn.active{background:#fff;border-color:var(--theme-color);box-shadow:0 4px 12px #0000000d}.color-dot{width:12px;height:12px;border-radius:50%;display:inline-block;flex-shrink:0}.clear-btn{margin-top:1rem;background:#fff;border:1px dashed #cbd5e1;color:#ef4444;padding:.75rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.clear-btn:hover{background:#fef2f2;border-color:#fca5a5}.selections{flex-grow:1}.empty-text{font-style:italic;color:#94a3b8}.selected-path-list{display:flex;flex-direction:column;gap:.5rem}.path-node{display:flex;align-items:center;gap:1rem;background:#f8fafc;padding:.5rem 1rem;border-radius:6px;border-left:3px solid var(--dot-active);animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.node-idx{background:var(--dot-active);color:#fff;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem;font-weight:700}.node-name{font-weight:600;font-size:.95rem}.map-view-area{flex-grow:1;position:relative;display:flex;align-items:center;justify-content:center;padding:2rem;background:radial-gradient(circle at center,#ffffff 0%,var(--map-bg) 100%)}.map-wrapper{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.route-line{stroke-dasharray:4 4;stroke-linecap:round;animation:drawLine 1s ease forwards}@keyframes drawLine{0%{opacity:0}to{opacity:1}}.city-marker{transition:all .2s ease}.city-marker:hover .marker-dot{stroke:var(--dot-active)}.marker-dot{transition:all .3s cubic-bezier(.175,.885,.32,1.275)}@media(max-width:768px){.map-app-container{flex-direction:column-reverse}.sidebar{width:100%;height:40vh;padding:1.5rem;box-shadow:0 -5px 15px #0000000d}.map-view-area{height:60vh;padding:1rem}}
