@font-face{font-family:Pretendard;font-style:normal;font-weight:400;src:url(/fonts/Pretendard-Regular.otf)format("opentype");font-display:swap}@font-face{font-family:Pretendard;font-style:normal;font-weight:700;src:url(/fonts/Pretendard-Bold.otf)format("opentype");font-display:swap}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;--bg:#fff;--surface:#fff;--surface-muted:#f0f0f0;--surface-pressed:#dbdbdb;--surface-floating:#fffffff5;--surface-floating-soft:#fffffff0;--surface-fade:#fff0;--map-bg:#f0f0f0;--map-grid-bg:#eee;--map-grid-line:#0000000d;--line:#0000001a;--line-strong:#0000002e;--text:#000;--body:#4b4b4b;--muted:#737373;--handle:#d6d6d6;--route:#1e6dff;--traveled:#3b4048;--error:#d92d20;--shadow-card:0 4px 16px #0000001f;--shadow-sheet:0 -8px 24px #00000029;--shadow-control:0 8px 20px #0000002e}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--bg:#050505;--surface:#151515;--surface-muted:#242424;--surface-pressed:#303030;--surface-floating:#151515f0;--surface-floating-soft:#151515eb;--surface-fade:#15151500;--map-bg:#1f1f1f;--map-grid-bg:#242424;--map-grid-line:#ffffff12;--line:#ffffff1f;--line-strong:#fff3;--text:#f7f7f7;--body:#c5c5c5;--muted:#9a9a9a;--handle:#4a4a4a;--traveled:#777f8c;--error:#ff6b5f;--shadow-card:0 4px 18px #00000061;--shadow-sheet:0 -8px 28px #00000080;--shadow-control:0 8px 24px #0000006b}}*{box-sizing:border-box}html,body{background:var(--bg);min-height:100%;color:var(--text);letter-spacing:0;margin:0;font-family:Pretendard,Apple SD Gothic Neo,Noto Sans KR,sans-serif}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{-webkit-tap-highlight-color:transparent}.landing-shell,.viewer-shell{min-height:100vh}.landing-shell{background:var(--bg);place-items:center;padding:20px;display:grid}.landing-hero{background:var(--surface);width:min(560px,100%);box-shadow:var(--shadow-card);border-radius:8px;padding:28px 20px}.eyebrow{color:var(--muted);margin:0 0 12px;font-size:13px;font-weight:700}.landing-hero h1{color:var(--text);margin:0;font-size:34px;font-weight:700;line-height:1.08}.hero-copy{max-width:44ch;color:var(--body);margin:12px 0 0;font-size:16px;line-height:1.55}.hero-actions{gap:10px;margin-top:28px;display:grid}.primary-link,.secondary-link{border:0;border-radius:999px;justify-content:center;align-items:center;min-height:48px;padding:0 18px;font-size:16px;font-weight:700;display:inline-flex}.primary-link{background:var(--text);color:var(--surface)}.secondary-link{background:var(--surface-muted);color:var(--text)}.viewer-shell{background:var(--bg);--viewer-sheet-expanded-height:90dvh;--viewer-sheet-collapsed-height:40dvh;--viewer-sheet-visible-height:40dvh;--viewer-sheet-map-underlap:28px;height:100dvh;min-height:100dvh;position:relative;overflow:hidden}.viewer-shell>.map-panel{top:0;right:0;bottom:calc(var(--viewer-sheet-collapsed-height) - var(--viewer-sheet-map-underlap));z-index:0;height:auto;min-height:0;position:absolute;left:0}.map-panel{background:var(--map-bg);min-height:52dvh;position:relative;overflow:hidden}.driver-map-shell{background:var(--surface);width:100%;height:100dvh;min-height:100dvh;overflow:hidden}.driver-map-shell .map-panel{--driver-map-card-overlap:32px;--driver-map-controls-bottom-inset:var(--driver-map-card-overlap);height:100%;min-height:0}.driver-place-picker-shell{background:var(--map-bg);width:100%;height:100dvh;min-height:100dvh;position:relative;overflow:hidden}.place-picker-map,.place-picker-fallback,.place-picker-backdrop{position:absolute;inset:0}.place-picker-map{touch-action:none;-webkit-user-select:none;user-select:none}.place-picker-fallback{background:var(--map-bg)}.place-picker-backdrop{pointer-events:none;background:0 0}.place-picker-pin{display:none}.place-picker-pin:after{content:""}.place-picker-name{z-index:5;pointer-events:none;left:50%;bottom:max(18px, env(safe-area-inset-bottom));background:var(--surface-floating-soft);max-width:calc(100% - 40px);color:var(--text);box-shadow:var(--shadow-control);white-space:nowrap;pointer-events:none;border-radius:999px;padding:9px 14px;font-size:13px;font-weight:700;position:absolute;transform:translate(-50%)}.map-grid{background-color:var(--map-grid-bg);background-image:linear-gradient(var(--map-grid-line) 1px, transparent 1px), linear-gradient(90deg, var(--map-grid-line) 1px, transparent 1px);background-size:56px 56px;position:absolute;inset:0}.map-canvas{position:absolute;inset:0}.map-control-stack,.map-location-control{z-index:20;pointer-events:none;position:absolute;right:14px}.map-control-stack{bottom:calc(var(--viewer-sheet-map-underlap) + 14px);justify-items:end;max-width:min(330px,100% - 28px);display:grid}.driver-map-shell .map-control-stack{bottom:calc(var(--driver-map-controls-bottom-inset) + 14px)}.map-location-control{top:max(14px, env(safe-area-inset-top));justify-items:end;gap:8px;max-width:min(260px,100% - 28px);display:grid}.map-mode-control{border:1px solid var(--line);background:var(--surface-floating);box-shadow:var(--shadow-control);pointer-events:auto;border-radius:999px;grid-template-columns:repeat(2,minmax(64px,1fr));gap:4px;padding:4px;display:inline-grid}.map-control-stack.is-fit-only .map-mode-control{grid-template-columns:44px}.map-control-button,.map-location-button{cursor:pointer;min-height:40px;color:var(--body);background:0 0;border:0;font-size:12px;font-weight:700}.map-control-button{border-radius:999px;grid-template-columns:18px auto;justify-content:center;align-items:center;gap:5px;min-width:64px;padding:0 10px;display:grid}.map-control-stack.is-icon-only .map-control-button{grid-template-columns:1fr;place-items:center;gap:0;min-width:44px;padding:0}.map-control-stack.is-icon-only .map-control-button span{display:none}.map-control-button[aria-pressed=true]{background:var(--text);color:var(--surface)}.map-control-button:disabled{cursor:not-allowed;opacity:.42}.map-location-button{background:var(--surface-floating);box-shadow:var(--shadow-control);pointer-events:auto;border-radius:999px;grid-template-columns:19px auto;align-items:center;gap:6px;padding:0 14px;display:inline-grid}.map-location-button:hover,.map-control-button:hover:not(:disabled):not([aria-pressed=true]){color:var(--text)}.map-control-button[aria-pressed=true]:hover{background:var(--text);color:var(--surface)}.map-location-error{background:var(--surface);max-width:260px;color:var(--error);box-shadow:var(--shadow-control);pointer-events:none;border-radius:8px;margin:0;padding:8px 10px;font-size:12px;font-weight:700}.map-route{position:absolute;inset:22% 14%}.map-route svg{width:100%;height:100%}.map-marker{border-radius:50%;place-items:center;width:18px;height:18px;display:grid;position:absolute;box-shadow:0 0 0 6px #00000014}.map-marker--car{width:26px;height:26px;box-shadow:none;background:url(/nav-arrow-marker-blue.svg) 50%/contain no-repeat;border-radius:999px}.map-marker--car:before{content:none}.map-marker--stop{background:var(--surface);border:3px solid var(--text);width:28px;height:28px;color:var(--text);font-size:12px;font-weight:700}.map-marker--stop.is-arrived{border-color:var(--muted);color:var(--muted);box-shadow:0 0 0 6px #00000014}.map-marker--stop.is-final{border-color:var(--text);color:var(--text)}.nav-marker{width:56px;height:56px;position:relative}.nav-marker__pulse{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#1e6dff2e;border-radius:999px;position:absolute;inset:10px}.nav-marker__vehicle{filter:drop-shadow(0 14px 20px #1f2c443d);place-items:center;display:grid;position:absolute;inset:0}.nav-marker__vehicle-image{-webkit-user-select:none;user-select:none;pointer-events:none;width:44px;height:44px;display:block}.viewer-location-marker{background:#1e6dff29;border-radius:999px;place-items:center;width:24px;height:24px;display:grid}.viewer-location-marker__dot{border:3px solid var(--surface);background:var(--route);border-radius:999px;width:12px;height:12px;box-shadow:0 4px 12px #1e6dff40}.stop-marker{pointer-events:none;flex-direction:column;align-items:center;gap:6px;display:inline-flex;transform:translateY(-8px)}.stop-marker__pin{border:3px solid var(--text);background:var(--surface);width:30px;height:30px;color:var(--text);border-radius:999px;place-items:center;font-size:12px;font-weight:700;display:grid;box-shadow:0 8px 18px #00000029}.stop-marker__label{text-overflow:ellipsis;background:var(--surface-floating);max-width:132px;color:var(--text);text-align:center;white-space:nowrap;border-radius:8px;padding:5px 9px;font-size:12px;font-weight:700;line-height:1.2;overflow:hidden;box-shadow:0 8px 22px #0000001f}.stop-marker.is-arrived .stop-marker__pin{border-color:var(--muted);color:var(--muted)}.stop-marker.is-final .stop-marker__pin{border-color:var(--text);color:var(--text)}.status-card{z-index:10;width:min(100%,560px);height:var(--viewer-sheet-expanded-height);overscroll-behavior:contain;background:var(--surface);max-height:none;box-shadow:var(--shadow-sheet);padding:0 16px max(24px, calc(env(safe-area-inset-bottom) + 16px));transform:translateY(calc(var(--viewer-sheet-expanded-height) - var(--viewer-sheet-visible-height)));will-change:transform;border-radius:28px 28px 0 0;margin:0 auto;transition:transform .26s cubic-bezier(.2,.8,.2,1);position:absolute;bottom:0;left:0;right:0;overflow-y:auto}.status-card.is-dragging{-webkit-user-select:none;user-select:none;transition:none}.status-card-handle{z-index:2;cursor:grab;touch-action:none;background:linear-gradient(to bottom, var(--surface) 0%, var(--surface) 72%, var(--surface-fade) 100%);border:0;place-items:center;width:100%;height:38px;display:grid;position:sticky;top:0}.status-card.is-dragging .status-card-handle{cursor:grabbing}.status-card-handle span{background:var(--handle);border-radius:999px;width:58px;height:6px;display:block}.status-card-header{justify-items:start;gap:12px;display:grid}.status-card-badge{background:var(--text);min-height:32px;color:var(--surface);border-radius:999px;align-items:center;padding:0 14px;font-size:14px;font-weight:700;display:inline-flex}.status-card-title{color:var(--text);margin:0;font-size:34px;font-weight:700;line-height:1.08}.status-card-subtitle{color:var(--body);margin:-2px 0 0;font-size:16px;line-height:1.4}.status-card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:18px;display:grid}.status-card-metric{background:var(--surface-muted);border-radius:8px;min-width:0;padding:12px}.status-card-metric-label{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:400;line-height:1.2;display:block;overflow:hidden}.status-card-metric-value{color:var(--text);text-overflow:ellipsis;white-space:nowrap;margin-top:7px;font-size:18px;font-weight:700;line-height:1.15;display:block;overflow:hidden}.status-card-route{background:var(--surface);box-shadow:var(--shadow-card);border-radius:8px;margin-top:18px;padding:16px}.status-card-route h2{color:var(--text);margin:0 0 12px;font-size:18px;font-weight:700;line-height:1.25}.status-card-stops{gap:12px;margin:0;padding:0;list-style:none;display:grid}.status-card-stop{grid-template-columns:28px minmax(0,1fr);align-items:center;gap:10px;display:grid}.status-card-stop-index{background:var(--text);width:28px;height:28px;color:var(--surface);border-radius:999px;place-items:center;font-size:12px;font-weight:700;display:grid}.status-card-stop.is-arrived .status-card-stop-index{background:var(--muted)}.status-card-stop-copy{gap:2px;min-width:0;display:grid}.status-card-stop-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:700;line-height:1.25;overflow:hidden}.status-card-stop-status{color:var(--body);font-size:12px;line-height:1.3}.state-panel{background:var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.state-panel-card{background:var(--surface);width:min(560px,100%);box-shadow:var(--shadow-card);border-radius:8px;padding:24px}.state-panel-card h1{color:var(--text);margin:0 0 12px;font-size:28px;line-height:1.15}.state-panel-card p{color:var(--body);margin:0;line-height:1.6}.state-panel-card a{background:var(--text);min-height:46px;color:var(--surface);border-radius:999px;justify-content:center;align-items:center;margin-top:20px;padding:0 18px;font-weight:700;display:inline-flex}@media (max-width:720px){.landing-shell{padding:20px}.landing-hero{padding:24px 20px}.status-card{width:100%}.status-card-grid{grid-template-columns:1fr}.status-card-title{font-size:32px}.map-control-stack{right:10px;bottom:calc(var(--viewer-sheet-map-underlap) + 10px)}.driver-map-shell .map-control-stack{bottom:calc(var(--driver-map-controls-bottom-inset) + 10px)}.map-location-control{top:max(10px, env(safe-area-inset-top));right:10px}.map-mode-control{grid-template-columns:repeat(2,44px)}.map-control-button{grid-template-columns:1fr;place-items:center;gap:0;min-width:44px;padding:0}.map-control-button span{display:none}.driver-map-shell .map-mode-control{grid-template-columns:repeat(2,minmax(64px,1fr))}.driver-map-shell .map-control-button{grid-template-columns:18px auto;gap:5px;min-width:64px;padding:0 10px}.driver-map-shell .map-control-button span{display:inline}.driver-map-shell .map-control-stack.is-fit-only .map-mode-control{grid-template-columns:44px}.driver-map-shell .map-control-stack.is-icon-only .map-control-button{grid-template-columns:1fr;place-items:center;gap:0;min-width:44px;padding:0}.driver-map-shell .map-control-stack.is-icon-only .map-control-button span{display:none}}
