:root{--bg-0: #000000;--bg-1: #000000;--surface: rgba(255, 255, 255, .06);--surface-2: rgba(255, 255, 255, .11);--border: rgba(255, 255, 255, .17);--border-strong: rgba(255, 255, 255, .32);--text: #f4f7fc;--muted: #b4c0d6;--faint: #7e8aa4;--accent: #4cc3fb;--accent-ink: #04121d;--green: #34d399;--yellow: #fbbf24;--red: #fb7185;--radius: 20px;--radius-sm: 14px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--bg-1)}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.screen{max-width:480px;margin:0 auto;min-height:100dvh;padding:calc(env(safe-area-inset-top) + 26px) 18px calc(env(safe-area-inset-bottom) + 28px);display:flex;flex-direction:column;gap:16px}.head{padding:4px 4px 2px}.head h1{font-size:40px;font-weight:800;letter-spacing:-.02em;line-height:1.05}.head h1 span{color:var(--accent)}.route{margin-top:6px;font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.scope-note{margin-top:5px;font-size:12px;font-weight:500;color:var(--faint)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:8px}.field-label{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.field-label em{font-style:normal;color:var(--faint);font-weight:600}.hint{font-size:12.5px;font-weight:500;color:var(--faint);margin-top:-2px}.input{width:100%;font-size:17px;font-weight:600;color:var(--text);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:15px 16px;outline:none;text-align:center;transition:border-color .15s,box-shadow .15s}.input::placeholder{color:var(--faint);font-weight:500}.input:focus{border-color:var(--accent);box-shadow:0 0 0 4px #38bdf829}input[type=date].input,input[type=time].input{-webkit-appearance:none;appearance:none;min-width:0}input[type=date]::-webkit-calendar-picker-indicator,input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.7)}input[type=date]::-webkit-date-and-time-value,input[type=time]::-webkit-date-and-time-value{margin:0;width:100%;text-align:center}input[type=date]::-webkit-datetime-edit,input[type=time]::-webkit-datetime-edit{padding:0;text-align:center}.toggle{display:flex;align-items:center;gap:12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px 16px;cursor:pointer;color:var(--text);font:inherit;transition:border-color .15s,background .15s}.toggle .toggle-knob{position:relative;width:44px;height:26px;border-radius:999px;background:#ffffff24;flex:none;transition:background .18s}.toggle .toggle-knob:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .18s}.toggle.on{border-color:#38bdf880}.toggle.on .toggle-knob{background:var(--accent)}.toggle.on .toggle-knob:after{transform:translate(18px)}.toggle-text{font-size:15px;font-weight:600}.segmented{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px}.seg{border:0;background:transparent;color:var(--muted);font:inherit;font-weight:700;font-size:14px;padding:9px 0;border-radius:10px;cursor:pointer;transition:background .15s,color .15s}.segmented.two{grid-template-columns:repeat(2,1fr)}.seg.active{background:var(--accent);color:var(--accent-ink)}.back{align-self:flex-start;border:0;background:transparent;color:var(--muted);font:inherit;font-size:15px;font-weight:700;padding:2px 4px;margin-bottom:-6px;cursor:pointer}.back:active{color:var(--accent)}.choices{display:flex;flex-direction:column;gap:14px;margin-top:8px}.choice{display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px 20px;cursor:pointer;color:var(--text);font:inherit;transition:border-color .15s,transform .08s,background .15s}.choice:active{transform:scale(.99)}.choice:hover{border-color:var(--border-strong);background:var(--surface-2)}.choice-emoji{font-size:30px;line-height:1;margin-bottom:6px}.choice-title{font-size:21px;font-weight:800;letter-spacing:-.01em}.choice-sub{font-size:14px;font-weight:500;color:var(--muted)}.cta{margin-top:2px;width:100%;border:0;border-radius:var(--radius-sm);padding:17px;font:inherit;font-size:17px;font-weight:800;letter-spacing:.01em;color:var(--accent-ink);background:linear-gradient(180deg,#7dd3fc,var(--accent));cursor:pointer;transition:transform .08s,opacity .15s,filter .15s}.cta:active{transform:scale(.985)}.cta:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.4)}.pending{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:14px;font-weight:600}.spinner{width:22px;height:22px;border-radius:50%;border:3px solid rgba(255,255,255,.15);border-top-color:var(--accent);animation:spin .8s linear infinite;flex:none}@keyframes spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.spinner{animation-duration:2s}}.banner{font-size:14px;font-weight:600;line-height:1.45;padding:15px 16px}.banner.error{background:#fb71851f;border-color:#fb718566;color:#fecdd3}.banner.warn{background:#fbbf241a;border-color:#fbbf2457;color:#fde6ad}.result{display:flex;flex-direction:column;gap:14px}.summary{padding:4px 4px 2px}.summary-main{font-size:22px;font-weight:800;letter-spacing:-.01em}.summary-main .arrow{color:var(--accent);margin:0 4px}.summary-term{margin-top:6px;font-size:15px;font-weight:800;letter-spacing:.01em;color:var(--accent)}.summary-sub{margin-top:6px;font-size:14px;color:var(--muted);font-weight:600}.summary-sub b{color:var(--text)}.target{margin-top:12px;font-size:15px;font-weight:700;color:var(--text)}.target b{color:var(--accent);font-size:17px}.option{position:relative;border-left-width:4px;padding:16px 16px 6px}.option.green{border-left-color:var(--green)}.option.yellow{border-left-color:var(--yellow)}.option.red{border-left-color:var(--red)}.buy-link{display:block;text-align:center;margin:8px 0 10px;padding:11px 12px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border);color:var(--accent);font-size:13px;font-weight:700;letter-spacing:.02em;text-decoration:none;transition:transform .08s ease,border-color .15s ease}.buy-link:active{transform:scale(.985)}.buy-link:hover{border-color:var(--border-strong)}.buy-arrow{font-size:12px;opacity:.85;margin-left:4px}.option-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}.best{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--accent-ink);background:var(--accent);padding:4px 9px;border-radius:999px}.tag{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.tag .dot{width:9px;height:9px;border-radius:50%}.tag.green{color:var(--green)}.tag.green .dot{background:var(--green)}.tag.yellow{color:var(--yellow)}.tag.yellow .dot{background:var(--yellow)}.tag.red{color:var(--red)}.tag.red .dot{background:var(--red)}.variance{margin:4px 0 12px;text-align:left;font-size:13px;font-weight:700;color:var(--muted)}.timeline{padding:6px 0 4px}.step{position:relative;display:flex;gap:14px;padding-bottom:18px}.step.last{padding-bottom:4px}.step-marker{position:relative;flex:none;width:14px;display:flex;justify-content:center}.step-marker i{width:12px;height:12px;border-radius:50%;background:var(--bg-0);border:2.5px solid var(--accent);margin-top:3px;z-index:1}.step:not(.last) .step-marker:after{content:"";position:absolute;top:14px;bottom:-4px;width:2px;background:var(--border-strong)}.step.last .step-marker i{background:var(--accent)}.step-time{font-size:20px;font-weight:800;letter-spacing:-.01em}.step-label{font-size:13px;color:var(--muted);font-weight:600;margin-top:1px}.foot{margin-top:auto;padding-top:8px;font-size:11.5px;line-height:1.5;color:var(--faint);text-align:center}.topbar{display:flex;justify-content:flex-end;margin-bottom:-8px}.theme-switch{position:relative;width:116px;height:36px;border-radius:999px;border:1px solid var(--border);background:var(--surface-2);padding:0;display:flex}.theme-switch .ts-icon{flex:1;display:flex;align-items:center;justify-content:center;font-size:15px;line-height:1;z-index:1;border:0;background:transparent;color:var(--muted);font-family:inherit;cursor:pointer;padding:0}.theme-switch .ts-knob{position:absolute;top:3px;left:3px;width:36px;height:28px;border-radius:999px;background:var(--accent);transition:transform .2s ease}.theme-switch.is-auto .ts-knob{transform:translate(0)}.theme-switch.is-dark .ts-knob{transform:translate(38px)}.theme-switch.is-light .ts-knob{transform:translate(76px)}.theme-switch.is-auto .ts-icon:nth-of-type(1),.theme-switch.is-dark .ts-icon:nth-of-type(2),.theme-switch.is-light .ts-icon:nth-of-type(3){color:var(--accent-ink)}[data-theme=light]{--bg-0: #ffffff;--bg-1: #e7f0f8;--surface: rgba(12, 45, 82, .035);--surface-2: rgba(12, 45, 82, .06);--border: rgba(12, 45, 82, .14);--border-strong: rgba(12, 45, 82, .26);--text: #0c2138;--muted: #4a5d76;--faint: #8190a4;--accent: #0f6fb8;--accent-ink: #ffffff;--green: #15924f;--yellow: #b9791c;--red: #d6453f}[data-theme=light] .cta{background:var(--accent)}[data-theme=light] .spinner{border-color:#0c2d5226;border-top-color:var(--accent)}[data-theme=light] .toggle .toggle-knob{background:#0c2d5233}[data-theme=light] .banner.error{background:#d6453f1a;border-color:#d6453f66;color:#a02320}[data-theme=light] .banner.warn{background:#b9791c1f;border-color:#b9791c66;color:#7a4f08}[data-theme=light] input[type=date]::-webkit-calendar-picker-indicator,[data-theme=light] input[type=time]::-webkit-calendar-picker-indicator{filter:none}.route-preview{padding:6px;margin-bottom:14px;overflow:hidden;animation:route-pop .4s ease both}.route-map{position:relative;height:116px;border-radius:14px;overflow:hidden;background:var(--surface-2)}.route-map canvas{outline:none}[data-theme=dark] .route-map canvas{filter:brightness(1.85) contrast(1.5) saturate(1.2)}.map-pin,.map-dot{position:relative;width:11px;height:11px;border-radius:50%;background:var(--accent);filter:drop-shadow(0 0 4px var(--accent)) drop-shadow(0 0 8px var(--accent))}.map-pin:after{content:"";position:absolute;inset:-6px;border-radius:50%;border:1.5px solid var(--accent);opacity:.4}.map-dot{width:12px;height:12px;filter:drop-shadow(0 0 5px var(--accent)) drop-shadow(0 0 11px var(--accent))}.route-map .maplibregl-ctrl-attrib{font-size:9px;background:transparent}.route-map .maplibregl-ctrl-attrib a{color:var(--faint)}.route-map .maplibregl-ctrl-bottom-right{opacity:.55}.route-map .maplibregl-ctrl-attrib-inner{display:none!important}.route-map .maplibregl-ctrl-attrib:hover .maplibregl-ctrl-attrib-inner,.route-map .maplibregl-ctrl-attrib:focus-within .maplibregl-ctrl-attrib-inner{display:inline-block!important}@keyframes route-pop{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.route-preview svg{width:100%;height:auto;display:block;overflow:visible}.route-rail{fill:none;stroke:var(--border-strong);stroke-width:2.5;stroke-linecap:round;opacity:.5}.route-line{fill:none;stroke:var(--accent);stroke-width:2.5;stroke-linecap:round;stroke-dasharray:1;stroke-dashoffset:1;filter:drop-shadow(0 0 3px var(--accent));animation:route-draw 1.05s ease .05s forwards}@keyframes route-draw{to{stroke-dashoffset:0}}.route-ring{fill:none;stroke:var(--accent);stroke-width:1.5;opacity:.4}.route-pin{fill:var(--accent);filter:drop-shadow(0 0 4px var(--accent))}.route-dot{fill:var(--accent);filter:drop-shadow(0 0 5px var(--accent)) drop-shadow(0 0 10px var(--accent))}.route-cap{fill:var(--muted);font-size:11px;font-weight:700;letter-spacing:.04em}@media(prefers-reduced-motion:reduce){.route-preview{animation:none}.route-line{animation:none;stroke-dashoffset:0}}
