:root{--bg:#eef2ef;--panel:#fbfcfb;--paper:#fff;--ink:#18211e;--muted:#65716b;--line:#d7ded9;--strong-line:#b9c5be;--green:#0d695f;--green-soft:#e1f0ec;--coral:#d9533f;--coral-soft:#fff1ed;--gold:#9d6b1d;--bus:#315f84}*{box-sizing:border-box}html{background:var(--bg)}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;margin:0;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Noto Sans KR,sans-serif}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:wait;opacity:.72}h1,h2,h3,p{margin:0}h1{letter-spacing:0;font-size:20px;line-height:1.25}h2{margin-bottom:12px;font-size:14px;line-height:1.25}p{color:var(--muted);font-size:13px;line-height:1.55}.app-shell{background:var(--paper);grid-template-columns:304px minmax(540px,1fr) 388px;min-height:100vh;display:grid}.left-panel,.right-panel{background:var(--panel);border-color:var(--line);min-width:0}.left-panel{border-right:1px solid var(--line)}.right-panel{border-left:1px solid var(--line);overflow:auto}.brand,.search-panel,.basecamp-list,.right-panel section{border-bottom:1px solid var(--line);padding:18px}.brand{align-items:center;gap:12px;display:flex}.brand>span{color:#fff;background:#13231f;border-radius:8px;place-items:center;width:38px;height:38px;font-weight:900;display:grid}.brand strong,.basecamp-card strong,.segment strong,.step strong,.provider-list strong{font-size:14px;line-height:1.35;display:block}.search-panel{gap:8px;display:grid}.search-panel label{color:var(--muted);font-size:12px;font-weight:800}.search-panel input{border:1px solid var(--strong-line);width:100%;min-height:42px;color:var(--ink);background:#fff;border-radius:8px;outline:0;padding:0 12px}.search-panel input:focus{border-color:var(--green);box-shadow:0 0 0 3px #0d695f1f}.primary-button,.secondary-button{border:1px solid #13231f;border-radius:8px;min-height:38px;font-weight:850}.primary-button{color:#fff;background:#13231f}.secondary-button{color:#13231f;background:#fff;padding:0 12px}.toolbar-actions{align-items:center;gap:8px;display:flex}.form-error{color:#a73728;font-weight:750}.basecamp-list{gap:10px;display:grid}.basecamp-card,.segment,.step,.brief,.provider-list article{border:1px solid var(--line);background:#fff;border-radius:8px}.basecamp-card{grid-template-columns:minmax(0,1fr) 48px;gap:12px;padding:12px;display:grid}.basecamp-card:first-of-type{border-left:4px solid var(--green);background:#f7fbfa}.basecamp-card b{background:var(--green-soft);width:44px;height:44px;color:var(--green);border-radius:8px;place-items:center;display:grid}.map-panel{background:#dfe8e4;min-height:100vh;position:relative;overflow:hidden}.map-toolbar{z-index:3;border:1px solid var(--line);background:#fffffff7;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:16px;padding:14px;display:flex;position:absolute;top:18px;left:18px;right:18px;box-shadow:0 2px 8px #16201d14}.map-canvas{background:linear-gradient(90deg,#5c736c2e 1px,#0000 1px) 0 0/80px 80px,linear-gradient(0deg,#5c736c29 1px,#0000 1px) 0 0/80px 80px,linear-gradient(135deg,#0000 0 58%,#689dab6b 58% 100%),#e8e5dc;position:absolute;inset:0;overflow:hidden}.map-canvas:before,.map-canvas:after{content:"";background:#68976929;border:1px solid #3253442e;border-radius:12px;position:absolute}.map-canvas:before{width:24%;height:22%;top:18%;left:11%;transform:rotate(-8deg)}.map-canvas:after{width:30%;height:24%;bottom:24%;right:12%;transform:rotate(9deg)}.water-label{color:#1a404c94;font-size:13px;font-weight:800;position:absolute;bottom:26px;right:24px}.road{background:#ffffffb8;border:1px solid #7568555c;border-radius:999px;height:9px;position:absolute}.road-main{width:120%;top:52%;left:-10%;transform:rotate(-9deg)}.road-east{width:78%;top:-4%;left:58%;transform:rotate(69deg)}.road-south{width:62%;bottom:18%;left:8%;transform:rotate(18deg)}.route-svg{z-index:2;filter:drop-shadow(0 2px 3px #18211e38);width:100%;height:100%;position:absolute;inset:0;overflow:visible}.map-path{fill:none;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.map-path-walk{stroke:var(--coral);stroke-width:5px;stroke-dasharray:1 9}.map-path-bus,.map-path-subway,.map-path-train,.map-path-ferry{stroke:var(--bus);stroke-width:5px}.map-path-taxi-fallback{stroke:var(--gold);stroke-width:5px;stroke-dasharray:10 8}.pin{z-index:4;color:#fff;background:#17201d;border:3px solid #fff;border-radius:8px;place-items:center;width:30px;height:30px;font-size:13px;font-weight:900;display:grid;position:absolute;transform:translate(-50%,-50%);box-shadow:0 2px 8px #14282233}.route-options{z-index:3;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid;position:absolute;bottom:18px;left:18px;right:18px}.route-card{border:1px solid var(--line);min-width:0;color:var(--ink);text-align:left;background:#fffffff7;border-radius:8px;grid-template-columns:minmax(0,1fr) 46px;align-items:center;gap:10px;padding:14px;display:grid;box-shadow:0 2px 8px #16201d14}.route-card.is-selected{border-left:4px solid var(--coral)}.route-card span,.route-card strong,.route-card em{min-width:0}.route-card strong{font-size:14px;line-height:1.35;display:block}.route-card em{color:var(--muted);margin-top:4px;font-size:13px;font-style:normal;line-height:1.45;display:block}.route-card b{background:var(--coral-soft);color:#a73728;border-radius:8px;place-items:center;height:44px;display:grid}.segment-list,.timeline,.provider-list{gap:10px;display:grid}.segment,.step{grid-template-columns:64px minmax(0,1fr);gap:10px;padding:11px;display:grid}.mission-panel{gap:12px;display:grid}.mission-summary{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;padding:11px;display:grid}.mission-summary strong{font-size:22px;line-height:1}.badge-list{grid-template-columns:repeat(4,28px);gap:8px;display:grid}.badge-list span{border:1px solid var(--line);width:28px;height:28px;color:var(--muted);background:#fff;border-radius:8px;place-items:center;font-size:12px;font-weight:900;display:grid}.badge-list span.is-earned{color:var(--green);background:var(--green-soft);border-color:#0d695f52}.mode,.step time,.step span,.provider-list span{font-size:12px;font-weight:900}.mode{color:var(--green)}.mode-bus,.mode-subway,.mode-train,.mode-ferry{color:var(--bus)}.mode-taxi-fallback{color:var(--gold)}.step time,.step span{color:var(--green)}.step.is-complete{background:#f7fbfa;border-color:#0d695f52}.step-action{border:1px solid var(--line);width:fit-content;min-height:30px;color:var(--ink);background:#fff;border-radius:8px;margin-top:8px;padding:0 10px;font-size:12px;font-weight:850}.brief{gap:8px;padding:12px;display:grid}.brief p{gap:2px;display:grid}.brief strong{color:var(--ink)}.provider-list article{grid-template-columns:minmax(0,1fr) auto;gap:4px 10px;padding:11px;display:grid}.provider-list p{grid-column:1/-1}.provider-list span{color:var(--green)}.modal-backdrop{z-index:20;background:#1119166b;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.login-modal{border:1px solid var(--line);background:#fff;border-radius:8px;gap:12px;width:min(100%,380px);padding:18px;display:grid;box-shadow:0 2px 8px #16201d1a}.modal-header,.modal-actions{justify-content:space-between;align-items:center;gap:10px;display:flex}.modal-header h2{margin:0}.modal-close{border:1px solid var(--line);min-height:30px;color:var(--muted);background:#fff;border-radius:8px;padding:0 8px;font-size:12px;font-weight:850}.login-modal label{color:var(--muted);font-size:12px;font-weight:800}.login-modal input{border:1px solid var(--strong-line);border-radius:8px;outline:0;width:100%;min-height:40px;padding:0 10px}.login-modal input:focus{border-color:var(--green);box-shadow:0 0 0 3px #0d695f1f}.admin-shell{background:var(--bg);min-height:100vh;padding:28px}.admin-panel{border:1px solid var(--line);background:#fff;border-radius:8px;max-width:880px;margin:0 auto}.admin-header,.admin-login,.admin-overview{border-bottom:1px solid var(--line);padding:18px}.admin-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.admin-header strong{color:var(--green);font-size:13px}.admin-login{grid-template-columns:minmax(160px,1fr) auto;align-items:end;gap:8px;display:grid}.admin-login label{color:var(--muted);grid-column:1/-1;font-size:12px;font-weight:800}.admin-login input{border:1px solid var(--strong-line);border-radius:8px;min-height:40px;padding:0 10px}.admin-overview{border-bottom:0}.admin-overview table{border-collapse:collapse;width:100%}.admin-overview th,.admin-overview td{border-top:1px solid var(--line);text-align:left;padding:12px 0;font-size:14px}.admin-overview th{color:var(--muted);font-weight:750}.admin-overview td{text-align:right;font-weight:900}@media (max-width:1120px){.app-shell{grid-template-columns:1fr}.map-panel{order:-1;min-height:660px}}@media (max-width:640px){h1{font-size:18px}.brand,.search-panel,.basecamp-list,.right-panel section{padding:14px}.map-toolbar{display:grid;left:12px;right:12px}.toolbar-actions{grid-template-columns:1fr 1fr;display:grid}.route-options{grid-template-columns:1fr;left:12px;right:12px}.route-card:nth-child(n+2){display:none}.admin-shell{padding:12px}.admin-header,.admin-login{display:grid}.admin-login{grid-template-columns:1fr}}
