:root{color:#16181d;background:#f7f8fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,textarea,input{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:minmax(380px,420px) 1fr;width:100vw;height:100vh;overflow:hidden;background:#edf1f7}.side-panel{position:relative;z-index:20;display:flex;flex-direction:column;min-width:0;height:100%;overflow-y:auto;border-right:1px solid #d7dce8;background:#f8f9fc}.panel-header{padding:26px 28px 20px;border-bottom:1px solid #dfe4ee;background:#fff}.brand-row{display:flex;align-items:center;gap:9px;color:#004ced;font-size:12px;font-weight:800;letter-spacing:0;text-transform:uppercase}.brand-mark{display:grid;width:28px;height:28px;place-items:center;border-radius:8px;background:#e5edff}.panel-header h1{margin:18px 0 8px;font-size:32px;line-height:1.08;letter-spacing:0}.panel-header p,.trip-summary p,.day-heading p,.stop-card p,.stop-card small,.empty-panel p,.map-empty p{color:#4b5567}.import-box,.itinerary-content,.empty-panel{padding:18px 20px}.field-label{display:block;margin-bottom:8px;color:#3d4658;font-size:13px;font-weight:700}textarea{width:100%;min-height:170px;resize:vertical;border:1px solid #cfd6e5;border-radius:8px;padding:13px 14px;background:#fff;color:#1d2430;line-height:1.5;outline:none}textarea:focus{border-color:#0052ff;box-shadow:0 0 0 3px #0052ff24}.import-actions{display:grid;grid-template-columns:1fr;gap:10px;margin:12px 0}.file-button,.ghost-button,.primary-button,.share-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border-radius:8px;border:1px solid #cfd6e5;padding:0 14px;background:#fff;color:#1d2430;font-weight:700}.file-button{position:relative;overflow:hidden}.file-button input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.image-preview{display:grid;grid-template-columns:74px minmax(0,1fr) auto;gap:10px;align-items:center;margin:0 0 12px;border:1px solid #d7deeb;border-radius:8px;padding:8px;background:#fff}.image-preview img{width:74px;height:56px;border-radius:6px;object-fit:cover;background:#eef2f7}.image-preview-meta{display:grid;gap:4px;min-width:0}.image-preview-meta strong{overflow:hidden;color:#202838;font-size:13px;line-height:1.3;text-overflow:ellipsis;white-space:nowrap}.image-preview-meta span{color:#647086;font-size:12px}.image-preview button{display:grid;width:32px;height:32px;place-items:center;border:1px solid #d8dfeb;border-radius:8px;background:#f7f9fc;color:#43516a}.primary-button,.share-button{width:100%;border-color:#004ced;background:#004ced;color:#fff}.primary-button:disabled,.share-button:disabled{border-color:#aeb7ca;background:#aeb7ca;cursor:not-allowed}.parse-progress{display:flex;align-items:flex-start;gap:8px;margin-top:10px;border:1px solid #d8e2f5;border-radius:8px;padding:10px 11px;background:#f3f7ff;color:#294060;font-size:13px;line-height:1.45}.parse-progress svg{flex:0 0 auto;margin-top:2px;color:#0052ff}.import-error{margin:-2px 0 12px;border:1px solid #ffd1d1;border-radius:8px;padding:9px 11px;background:#fff1f1;color:#a21b1b;font-size:13px;line-height:1.4}.trip-summary{padding-bottom:14px}.trip-summary h2{margin:0 0 9px;font-size:24px;line-height:1.15;letter-spacing:0}.date-line{display:flex;align-items:center;gap:8px;color:#4b5567;font-size:14px}.trip-scope-line{display:inline-flex;max-width:100%;margin-top:9px;border:1px solid #d7deeb;border-radius:8px;padding:6px 9px;background:#fff;color:#4b5567;font-size:12px;font-weight:800;line-height:1.35;overflow-wrap:anywhere}.day-selector{display:flex;gap:6px;padding:5px;overflow-x:auto;border:1px solid #d9deeb;border-radius:8px;background:#fff}.day-selector button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-width:62px;height:32px;border:0;border-radius:6px;background:transparent;color:#536075;font-size:13px;font-weight:800;white-space:nowrap}.day-selector button.active{background:#e8edf7;color:#101827}.day-selector i{width:8px;height:8px;border-radius:50%}.map-controls-panel{display:grid;gap:8px;margin-top:12px;border:1px solid #d9deeb;border-radius:8px;padding:10px;background:#fff}.route-mode-selector{display:grid;gap:8px}.route-mode-title{color:#4b5567;font-size:12px;font-weight:800}.route-mode-options{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.route-mode-options button{display:inline-flex;min-width:0;height:34px;align-items:center;justify-content:center;gap:5px;border:1px solid #d7deeb;border-radius:7px;background:#f8fafd;color:#4c5870;font-size:12px;font-weight:800}.route-mode-options button.active{border-color:#004ced;background:#e8efff;color:#004ced}.map-label-toggle{display:flex;min-height:34px;align-items:center;justify-content:space-between;gap:10px;border-top:1px solid #edf0f6;padding-top:8px;color:#4b5567;font-size:12px;font-weight:800}.map-label-toggle input{width:18px;height:18px;accent-color:#004ced}.day-list{padding:18px 0 84px}.day-section{margin-bottom:24px}.day-heading{display:grid;grid-template-columns:36px 1fr;gap:11px;align-items:start;margin-bottom:12px}.day-heading>span{display:grid;width:30px;height:30px;place-items:center;border-radius:8px;background:var(--day-color);color:#fff;font-size:13px;font-weight:900}.day-heading h3,.alt-section h3{margin:0;font-size:18px;line-height:1.25;letter-spacing:0}.day-heading p{margin:4px 0 0;font-size:13px}.stop-list{display:grid;gap:10px;margin-left:15px;padding-left:20px;border-left:2px solid var(--day-color)}.stop-card{position:relative;border:1px solid #dde3ee;border-radius:8px;padding:12px;background:#fff;box-shadow:0 2px 8px #1821350d;cursor:pointer}.stop-card.not-focusable{cursor:default}.stop-card:before{content:"";position:absolute;left:-29px;top:17px;width:12px;height:12px;border:3px solid var(--day-color, #0052ff);border-radius:50%;background:#fff}.stop-card.compact:before{display:none}.stop-card.unmatched{border-style:dashed}.stop-card.selected{border-color:#0052ff;box-shadow:0 0 0 3px #0052ff1f,0 8px 18px #18213514}.stop-card-title{display:grid;grid-template-columns:auto 1fr auto auto;gap:8px;align-items:center}.stop-card-title>span{border-radius:6px;padding:4px 6px;background:#e9efff;color:#004ced;font-size:11px;font-weight:900}.stop-card h4{min-width:0;margin:0;overflow-wrap:anywhere;font-size:16px;line-height:1.3;letter-spacing:0}.stop-card a{color:#0052ff}.stop-delete-button{display:grid;width:28px;height:28px;place-items:center;border:1px solid #ffd2d2;border-radius:7px;background:#fff5f5;color:#b42318}.stop-card p{margin:9px 0 0;line-height:1.55}.stop-card small{display:block;margin-top:7px;font-size:12px;line-height:1.4}.alt-section{display:grid;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid #dfe4ee}.share-button{position:sticky;bottom:16px;box-shadow:0 10px 24px #004ced38}.share-area{position:sticky;bottom:16px;display:grid;gap:8px}.share-area .share-button{position:static}.status-block{margin:auto 20px 18px;border:1px solid #d6e4c8;border-radius:8px;padding:11px 12px;background:#f0f8e8;color:#2f5f28;font-size:13px;line-height:1.45;overflow-wrap:anywhere}.status-block.error{border-color:#ffd1d1;background:#fff1f1;color:#a21b1b}.share-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:20px;background:#10182861;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.share-dialog{position:relative;width:min(440px,100%);border:1px solid #dce3ef;border-radius:8px;padding:22px;background:#fff;box-shadow:0 24px 70px #0f172a42}.icon-button{display:grid;width:34px;height:34px;place-items:center;border:1px solid #d8dfeb;border-radius:8px;background:#f7f9fc;color:#344054}.share-dialog-close{position:absolute;top:14px;right:14px}.share-dialog-icon{display:grid;width:46px;height:46px;place-items:center;border-radius:8px;background:#e8efff;color:#004ced}.share-dialog h2{margin:16px 42px 8px 0;color:#171b24;font-size:24px;line-height:1.18;letter-spacing:0}.share-dialog p{margin:0;color:#556174;line-height:1.5}.share-link-box{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;margin-top:18px}.share-link-box input{min-width:0;width:100%;min-height:40px;border:1px solid #cfd7e6;border-radius:8px;padding:0 11px;background:#f8fafd;color:#1e2736;font-size:13px}.copy-button,.share-dialog-actions a,.share-dialog-actions button{display:inline-flex;min-height:40px;align-items:center;justify-content:center;gap:7px;border-radius:8px;border:1px solid #004ced;padding:0 13px;background:#004ced;color:#fff;font-weight:800;text-decoration:none}.copy-hint{display:block;margin-top:9px;color:#9a3412;line-height:1.45}.share-dialog-actions{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:16px}.share-dialog-actions button{border-color:#d2d9e7;background:#fff;color:#344054}.map-stage{min-width:0;height:100%}.map-wrap{position:relative;height:100%;background:#dbe4ef}.map-container{position:absolute;top:0;right:0;bottom:0;left:0}.map-empty{position:absolute;left:50%;top:50%;width:min(420px,calc(100% - 40px));transform:translate(-50%,-50%);border:1px solid rgba(183,192,211,.9);border-radius:8px;padding:22px;background:#ffffffeb;text-align:center;box-shadow:0 14px 38px #141f351f}.map-empty h2{margin:12px 0 8px;font-size:22px;letter-spacing:0}.map-toast{position:absolute;top:18px;left:50%;display:flex;max-width:min(520px,calc(100% - 36px));transform:translate(-50%);align-items:center;gap:8px;border:1px solid #dbe2ee;border-radius:8px;padding:10px 13px;background:#fffffff0;color:#263246;box-shadow:0 10px 28px #1118271f;font-size:13px;overflow-wrap:anywhere}.map-toast.error{border-color:#ffd1d1;color:#9b1717}.map-day-filter{position:absolute;left:50%;bottom:18px;width:min(520px,calc(100% - 36px));transform:translate(-50%)}.route-marker-wrap{display:grid;justify-items:center;gap:5px;transform:translateY(-2px)}.route-marker{display:grid;min-width:36px;height:36px;place-items:center;border:2px solid #ffffff;border-radius:18px 18px 18px 4px;background:var(--marker-color);color:#fff;box-shadow:0 3px 10px #121b2c47;transform:rotate(-45deg)}.route-marker span{display:block;padding:0 6px;transform:rotate(45deg);font-size:11px;font-weight:900;white-space:nowrap}.route-marker-name{max-width:118px;border:1px solid rgba(207,216,231,.94);border-radius:8px;padding:3px 7px;background:#fffffff0;color:#1d2430;font-size:12px;font-weight:800;line-height:1.25;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap;box-shadow:0 4px 12px #121b2c29}.route-marker-wrap.muted{opacity:.78}.poi-window{width:230px;border:1px solid #dfe4ee;border-radius:8px;padding:12px;background:#fff;box-shadow:0 12px 26px #121b2c33}.poi-window strong,.poi-window p,.poi-window small,.poi-window a{display:block}.poi-window p{margin:8px 0;color:#4b5567;line-height:1.45}.poi-window small{color:#69758a}.poi-window a{margin-top:10px;color:#0052ff;font-weight:800;text-decoration:none}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:760px){.app-shell{display:block}.map-stage{height:100vh}.side-panel{position:fixed;left:0;right:0;bottom:0;z-index:40;height:min(64vh,620px);border-top:1px solid #d7dce8;border-right:0;border-radius:16px 16px 0 0;box-shadow:0 -10px 32px #0e172a29}.side-panel:before{content:"";position:sticky;top:8px;z-index:2;display:block;width:42px;height:5px;margin:8px auto 0;border-radius:999px;background:#c2cad8}.panel-header{padding:12px 18px 14px}.panel-header h1{margin-top:10px;font-size:24px}.panel-header p{margin:0;font-size:13px}.import-box,.itinerary-content,.empty-panel{padding:14px 16px}textarea{min-height:120px}.trip-summary h2{font-size:21px}.day-list{padding-bottom:76px}.map-day-filter{bottom:calc(min(64vh,620px) + 12px);width:calc(100% - 24px)}.map-toast{top:14px}.map-empty{top:28%}.share-dialog-backdrop{align-items:end;padding:14px}.share-dialog{padding:20px 16px 16px}.share-link-box,.share-dialog-actions{grid-template-columns:1fr}}
