@font-face{font-family:Playfair Display;font-style:normal;font-weight:600 700;font-display:swap;src:url(/fonts/playfair-vietnamese.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Playfair Display;font-style:normal;font-weight:600 700;font-display:swap;src:url(/fonts/playfair-latin-ext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Playfair Display;font-style:normal;font-weight:600 700;font-display:swap;src:url(/fonts/playfair-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{color:#18332f;background:#f2f1e9;font-family:Segoe UI,system-ui,sans-serif;font-synthesis:none;--ink: #18332f;--forest: #123d36;--forest-soft: #225a50;--paper: #faf9f3;--cream: #f2f1e9;--sand: #d7d1bf;--orange: #ec7d4b;--muted: #6f7f78;--danger: #b84a40;--shadow: 0 24px 60px rgba(31, 49, 43, .1)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,textarea,select{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin-top:0}h1,h2,h3{font-family:Playfair Display,Georgia,Times New Roman,serif;font-weight:600;letter-spacing:-.025em}.eyebrow{color:var(--orange);font-size:.72rem;font-weight:700;letter-spacing:.16em}.brand-mark{display:grid;place-items:center;width:56px;height:56px;border:1px solid rgba(255,255,255,.5);border-radius:50% 50% 48% 52%/46% 54%;color:#fff;font-family:Playfair Display,Georgia,Times New Roman,serif;font-size:1.7rem}.brand-mark.small{width:36px;height:36px;color:var(--forest);border-color:var(--sand);font-size:1.1rem}.auth-layout{display:grid;min-height:100vh;grid-template-columns:1.08fr .92fr}.auth-story{position:relative;overflow:hidden;padding:clamp(2rem,6vw,6rem);color:#f9f6eb;background:radial-gradient(circle at 75% 22%,rgba(244,176,92,.25),transparent 22%),linear-gradient(145deg,#0b2925,#1d5147)}.auth-story:after{position:absolute;right:-15%;bottom:-20%;width:70%;aspect-ratio:1;border:1px solid rgba(255,255,255,.12);border-radius:44% 56% 62% 38%;content:"";transform:rotate(12deg)}.auth-story .eyebrow{margin-top:18vh}.auth-story h1{max-width:680px;margin-bottom:1.5rem;font-size:clamp(3.2rem,7vw,7rem);line-height:.88}.auth-story>p:not(.eyebrow){max-width:560px;color:#ffffffb8;font-size:1.05rem;line-height:1.8}.route-art{position:absolute;right:12%;top:15%;display:flex;gap:16px;align-items:end;transform:rotate(18deg)}.route-art span{display:block;width:11px;height:11px;border:2px solid #f4b05c;border-radius:50%}.route-art span:nth-child(2){width:90px;height:1px;border:0;border-top:1px dashed rgba(255,255,255,.6);margin-bottom:5px}.auth-panel{display:grid;place-items:center;padding:2rem;background:var(--paper)}.auth-card{width:min(430px,100%)}.auth-card h2{margin-bottom:2rem;font-size:3rem}form{display:grid;gap:1rem}label{display:grid;gap:.45rem;color:#41534e;font-size:.78rem;font-weight:700;letter-spacing:.04em}input,textarea,select{width:100%;border:1px solid #d8ddd7;border-radius:12px;outline:none;padding:.9rem 1rem;color:var(--ink);background:#fff;transition:border-color .2s,box-shadow .2s}input:focus,textarea:focus,select:focus{border-color:var(--forest-soft);box-shadow:0 0 0 3px #225a501f}.primary-button,.ghost-button,.text-button,.back-button{border:0;border-radius:999px;padding:.9rem 1.25rem}.primary-button{margin-top:.5rem;color:#fff;background:var(--forest);font-weight:700}.primary-button:hover{background:var(--forest-soft)}.primary-button.compact{width:max-content;margin:0}.primary-button:disabled{opacity:.55;cursor:wait}.text-button{margin-top:1rem;padding-left:0;color:var(--forest-soft);background:transparent}.inline-link{display:inline-block;text-align:center}.inline-link.light{color:#fff}.ghost-button,.back-button{color:var(--forest);background:transparent;border:1px solid #d7ddd8}.form-error{margin:0;color:var(--danger);font-size:.85rem}.form-success{margin:.5rem 0;color:#21705c;font-size:.85rem}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;height:76px;padding:0 clamp(1.25rem,5vw,5rem);border-bottom:1px solid #deddd4;background:#faf9f3e6;backdrop-filter:blur(18px)}.brand,.user-menu{display:flex;align-items:center;gap:.8rem;font-weight:700}.user-menu{color:var(--muted);font-size:.85rem}.dashboard{width:min(1240px,calc(100% - 2.5rem));margin:0 auto;padding:clamp(3rem,7vw,6rem) 0}.hero-row{display:flex;align-items:end;justify-content:space-between;gap:2rem;margin-bottom:3.5rem}.hero-row h1{max-width:760px;margin-bottom:.6rem;font-size:clamp(2.7rem,6vw,5.3rem);line-height:.95}.hero-row p:not(.eyebrow){color:var(--muted)}.section-heading{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.2rem}.section-heading h2{margin:0;font-size:2.1rem}.section-heading span{color:var(--muted);font-size:.82rem}.create-trip-card{grid-template-columns:2fr 1fr 1fr;margin:-1rem 0 3rem;padding:1.4rem;border:1px solid #deddd4;border-radius:22px;background:var(--paper);box-shadow:var(--shadow)}.create-trip-card .wide{grid-column:1 / -1}.trip-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem}.trip-card{overflow:hidden;border:1px solid #deddd4;border-radius:22px;background:var(--paper);box-shadow:0 8px 24px #1f312b0a;transition:transform .2s,box-shadow .2s;cursor:pointer}.trip-card:hover,.trip-card:focus{outline:none;transform:translateY(-4px);box-shadow:var(--shadow)}.trip-cover{display:flex;align-items:start;justify-content:space-between;min-height:160px;padding:1rem;background:linear-gradient(160deg,rgba(9,45,39,.2),transparent),radial-gradient(circle at 70% 35%,#dfa45f,transparent 22%),linear-gradient(145deg,#315f53,#abc1a8)}.status-pill,.role-pill{border-radius:999px;padding:.42rem .72rem;font-size:.67rem;font-weight:700;letter-spacing:.05em}.status-pill{color:#fff;background:#0e2924c7;backdrop-filter:blur(8px)}.role-pill{color:var(--forest);background:#eee9da}.trip-body{padding:1.3rem}.trip-body h3{margin-bottom:.5rem;font-size:1.65rem}.trip-body p{min-height:44px;color:var(--muted);font-size:.85rem;line-height:1.55}.trip-dates{display:flex;align-items:center;gap:.65rem;color:#52625d;font-size:.74rem;font-weight:700}.trip-dates .line{flex:1;height:1px;background:var(--sand)}.empty-state{padding:4rem 2rem;border:1px dashed #cbc9be;border-radius:22px;text-align:center}.empty-state>span{font-size:2rem}.empty-state h3{margin:.5rem 0;font-size:1.6rem}.empty-state p,.muted{color:var(--muted)}.trip-view{display:grid;gap:1rem;width:min(640px,100%);margin:0 auto;padding:1rem 1rem 4rem}.trip-hero{position:relative;overflow:hidden;padding:1.5rem 1.4rem 1.6rem;border-radius:24px;color:#f9f6eb;background:radial-gradient(circle at 82% 10%,rgba(244,176,92,.3),transparent 40%),linear-gradient(150deg,#0b2925,#1d5147);box-shadow:var(--shadow)}.trip-hero-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.3rem}.trip-hero-actions{display:flex;align-items:center;gap:.6rem}.hero-back{display:grid;place-items:center;width:40px;height:40px;border:1px solid rgba(255,255,255,.25);border-radius:50%;color:#fff;background:#ffffff14;font-size:1.15rem}.trip-hero .eyebrow{color:#f4b05c}.trip-hero h1{margin:.45rem 0 0;font-size:clamp(2rem,8vw,2.9rem);line-height:1.02}.trip-hero-sub{margin:.7rem 0 0;color:#ffffffbd;font-size:.9rem;line-height:1.55}.trip-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem}.meta-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .75rem;border:1px solid rgba(255,255,255,.16);border-radius:999px;color:#ffffffeb;background:#ffffff1a;font-size:.74rem;font-weight:600}.role-pill.light{color:#fff;background:#ffffff2e}.trip-tabs{position:sticky;top:.5rem;z-index:5;display:flex;gap:.35rem;overflow-x:auto;padding:.45rem;border:1px solid #deddd4;border-radius:999px;background:#faf9f3eb;backdrop-filter:blur(14px);scrollbar-width:none}.trip-tabs::-webkit-scrollbar{display:none}.trip-tabs button{display:inline-flex;flex:0 0 auto;align-items:center;gap:.4rem;border:0;border-radius:999px;padding:.6rem .95rem;color:var(--muted);background:transparent;font-weight:700;font-size:.8rem;white-space:nowrap}.trip-tabs button.active{color:#fff;background:var(--forest)}.trip-tabs .tab-ico{font-size:.95rem}.trip-panels{display:grid;gap:1rem}.trip-view .metric-grid,.trip-view .budget-summary{grid-template-columns:repeat(2,1fr)}.trip-view .activity-form,.trip-view .expense-form,.trip-view .settings-form,.trip-view .inline-form{grid-template-columns:1fr;margin-bottom:1.2rem}.trip-view .checklist-progress{grid-template-columns:auto 1fr}.trip-view .checklist-progress h2{font-size:2.4rem}.trip-view .module-panel h2{font-size:1.6rem}.trip-view .timeline-entry{grid-template-columns:56px 1fr;gap:.8rem;margin-top:.6rem;padding:.85rem;border:1px solid #e3e3da;border-radius:14px}.trip-view .timeline-entry .ghost-button{grid-column:2;width:max-content}.trip-view .danger-zone{flex-direction:column}.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.metric-card{padding:1.4rem;border:1px solid #deddd4;border-radius:18px;background:var(--paper)}.metric-card p{color:var(--muted);font-size:.75rem}.metric-card strong{display:block;margin-bottom:.6rem;font-family:Playfair Display,Georgia,Times New Roman,serif;font-size:1.7rem}.metric-card span{color:var(--muted);font-size:.67rem}.next-step{max-width:760px;margin-top:2rem;padding:2rem;border-radius:22px;background:#e6e1d2}.next-step h3{font-size:2rem}.next-step>p:last-child{color:#5d6c67;line-height:1.7}.public-action-page{padding:1.25rem;background:var(--cream)}.action-card{padding:2rem;border:1px solid #deddd4;border-radius:22px;background:var(--paper);box-shadow:var(--shadow)}.action-card h1{font-size:2.5rem}.settings-page{width:min(1100px,calc(100% - 2rem));margin:0 auto;padding:2rem 0 5rem}.settings-page>header{margin:3rem 0 2rem}.settings-page>header h1{font-size:clamp(2.8rem,6vw,5rem)}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.settings-card,.module-panel{padding:1.5rem;border:1px solid #deddd4;border-radius:22px;background:var(--paper)}.settings-card h2,.module-panel h2{font-size:2rem}.wide-card{grid-column:1 / -1}.session-list,.member-list{display:grid;gap:.7rem}.session-list article,.member-list article{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;border:1px solid #e3e3da;border-radius:14px}.session-list article>div,.member-list article>div:not(.avatar){display:grid;gap:.25rem;flex:1}.session-list span,.member-list span{color:var(--muted);font-size:.72rem}.avatar{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;color:#fff;background:var(--forest-soft);font-weight:700}.inline-form{display:grid;grid-template-columns:2fr 1fr auto;align-items:end;gap:.8rem;margin-bottom:1rem}.share-link{display:grid;gap:.4rem;margin:1rem 0;padding:1rem;border-radius:14px;background:#e8f0eb}.share-link-row{display:flex;align-items:stretch;gap:8px}.share-link-row input{flex:1;min-width:0}.share-link-copy-btn{display:grid;flex-shrink:0;place-items:center;width:40px;padding:0;border:1px solid rgba(9,19,21,.12);border-radius:10px;background:#fff;color:#1b2d32;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.share-link-copy-btn:hover{border-color:#0d4a4059;background:#f0f7f4}.share-link-copy-btn.copied{border-color:#2ecc7173;background:#2ecc711f;color:#1e7a45}.settings-form{grid-template-columns:repeat(3,1fr)}.settings-form .wide{grid-column:1 / -1}.danger-zone{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem;padding-top:1.2rem;border-top:1px solid #deddd4}.danger-button{border:1px solid #e1a59e;border-radius:999px;padding:.8rem 1rem;color:var(--danger);background:#fff2ef}.mfa-setup,.recovery-codes{display:grid;gap:1rem;margin-top:1rem;padding:1rem;border-radius:14px;background:#e8f0eb}.mfa-setup code,.recovery-codes code{overflow-wrap:anywhere;white-space:pre-wrap;font-family:ui-monospace,Cascadia Code,monospace}.activity-form,.expense-form{display:grid;grid-template-columns:repeat(4,1fr);align-items:end;margin-bottom:2rem}.activity-form .primary-button,.expense-form .primary-button{margin-bottom:.05rem}.timeline-days{display:grid;gap:1.5rem}.timeline-day{padding-left:1rem;border-left:2px solid var(--sand)}.timeline-day h3{font-size:1.7rem}.timeline-entry{display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:1rem;padding:.9rem 0;border-top:1px solid #e3e3da}.timeline-entry time{color:var(--orange);font-weight:700}.timeline-entry>div{display:grid;gap:.25rem}.timeline-entry span,.expense-list-new span{color:var(--muted);font-size:.72rem}.checklist-progress{display:grid;grid-template-columns:180px 1fr;align-items:center;gap:1rem}.checklist-progress h2{margin:0;font-size:3.5rem}.progress-track{overflow:hidden;height:12px;border-radius:999px;background:#dce2dc}.progress-track span{display:block;height:100%;border-radius:inherit;background:var(--forest-soft);transition:width .25s ease}.checklist-group{margin-top:1.5rem}.checklist-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;padding:.8rem 0;border-top:1px solid #e3e3da;cursor:pointer}.checklist-row input{width:20px;height:20px}.checklist-row small{color:var(--muted)}.budget-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.expense-form .wide{grid-column:span 2}.expense-list-new{display:grid;gap:.6rem;margin:1.5rem 0}.expense-list-new article{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:1rem;padding:.9rem;border:1px solid #e3e3da;border-radius:14px}.expense-list-new article>div{display:grid;gap:.25rem}:root[data-theme=dark] .mfa-setup,:root[data-theme=dark] .recovery-codes,:root[data-theme=dark] .share-link{background:#1c332e}.theme-button{min-width:42px;padding-inline:.7rem}:root[data-theme=dark]{color:#e9eee9;background:#0d1d1a;--ink: #e9eee9;--forest: #163c35;--forest-soft: #2d6a5e;--paper: #142723;--cream: #0d1d1a;--sand: #3a4b46;--muted: #9aaba5;--shadow: 0 24px 60px rgba(0, 0, 0, .25)}:root[data-theme=dark] body,:root[data-theme=dark] .auth-panel,:root[data-theme=dark] .topbar{background:var(--cream)}:root[data-theme=dark] .topbar,:root[data-theme=dark] .trip-card,:root[data-theme=dark] .metric-card,:root[data-theme=dark] .settings-card,:root[data-theme=dark] .module-panel,:root[data-theme=dark] .action-card{border-color:#30423d;background:var(--paper)}:root[data-theme=dark] input,:root[data-theme=dark] textarea,:root[data-theme=dark] select{border-color:#3a4d47;color:var(--ink);background:#0e211d}:root[data-theme=dark] label{color:#b8c5c0}:root[data-theme=dark] .next-step{background:#1c332e}:root[data-theme=dark] .trip-tabs{border-color:#30423d;background:#142723eb}:root[data-theme=dark] .trip-view .timeline-entry,:root[data-theme=dark] .expense-list-new article{border-color:#30423d}.loading-screen,.center-page{display:grid;place-content:center;justify-items:center;min-height:100vh;gap:1rem}.loading-screen p{margin:0;color:#ffffffc7;font-size:.92rem;font-weight:500;letter-spacing:.01em}.car-loader{display:block;overflow:visible}.car-loader-body{fill:#d4af37}.car-loader-cabin{fill:#b8942e}.car-loader-window{fill:#a8dcff8c}.car-loader-tire{fill:#1a2824;stroke:#2f4540;stroke-width:1.2}.car-loader-rim{fill:none;stroke:#d4af37;stroke-width:1.4}.car-loader-spoke{stroke:#d4af37;stroke-width:1.4;stroke-linecap:round}.car-loader-wheel{transform-origin:0 0;animation:car-wheel-spin 2.8s linear infinite}@keyframes car-wheel-spin{to{transform:rotate(360deg)}}.loader{width:34px;height:34px;border:3px solid #cfd5cf;border-top-color:var(--forest);border-radius:50%;animation:spin .8s linear infinite}.error-state{display:grid;gap:.3rem;padding:1rem;border-left:3px solid var(--danger);color:var(--danger);background:#f8e9e5}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:960px){.auth-layout{grid-template-columns:1fr}.auth-story{min-height:42vh}.auth-story .eyebrow{margin-top:3rem}.auth-story h1{font-size:4rem}.trip-grid,.metric-grid,.settings-form,.activity-form,.expense-form{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.auth-story{padding:2rem}.auth-story h1{font-size:3.2rem}.auth-panel{padding:3rem 1.2rem}.topbar{padding:0 1rem}.user-menu>span{display:none}.hero-row{align-items:start;flex-direction:column}.create-trip-card,.trip-grid,.metric-grid,.settings-grid,.settings-form,.inline-form,.activity-form,.expense-form,.budget-summary{grid-template-columns:1fr}.create-trip-card .wide,.wide-card,.settings-form .wide,.expense-form .wide{grid-column:auto}.timeline-entry{grid-template-columns:65px 1fr}.timeline-entry .ghost-button{grid-column:2;width:max-content}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.01ms!important;transition-duration:.01ms!important}}.gps-indicator{display:flex;align-items:center;gap:.65rem;margin:1rem 0;padding:.8rem 1rem;border:1px solid color-mix(in srgb,#2bb673 45%,var(--line));border-radius:12px;background:color-mix(in srgb,#2bb673 10%,var(--surface));color:var(--text)}.gps-indicator span{width:.65rem;height:.65rem;border-radius:50%;background:#2bb673;box-shadow:0 0 0 5px color-mix(in srgb,#2bb673 20%,transparent)}.live-grid{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(260px,.8fr);gap:1rem;margin:1rem 0}.live-grid iframe{width:100%;min-height:460px;border:1px solid var(--line);border-radius:16px}.device-list{display:grid;align-content:start;gap:.75rem}.device-list article{padding:1rem;border:1px solid var(--line);border-radius:14px;background:var(--surface)}.device-list article>div{display:flex;justify-content:space-between;gap:1rem}.device-list span,.device-list p{color:var(--muted)}@media(max-width:800px){.live-grid{grid-template-columns:1fr}.live-grid iframe{min-height:340px}}.offline-banner{position:fixed;z-index:1000;right:1rem;bottom:1rem;max-width:min(420px,calc(100vw - 2rem));padding:.75rem 1rem;border:1px solid #d59a3a;border-radius:12px;background:#402d11;color:#fff5df;box-shadow:var(--shadow)}.offline-banner.online{border-color:#2bb673;background:#133f2c}@font-face{font-family:Be Vietnam Pro;font-weight:400;font-display:swap;src:url(/fonts/bvp-400-vietnamese.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-weight:400;font-display:swap;src:url(/fonts/bvp-400-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Be Vietnam Pro;font-weight:500;font-display:swap;src:url(/fonts/bvp-500-vietnamese.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-weight:500;font-display:swap;src:url(/fonts/bvp-500-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Be Vietnam Pro;font-weight:600;font-display:swap;src:url(/fonts/bvp-600-vietnamese.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-weight:600;font-display:swap;src:url(/fonts/bvp-600-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Be Vietnam Pro;font-weight:700;font-display:swap;src:url(/fonts/bvp-700-vietnamese.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-weight:700;font-display:swap;src:url(/fonts/bvp-700-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}.legacy-trip{--primary: #1e3f20;--primary-light: #2c5c2f;--accent: #d4af37;--accent-light: #f3e5ab;--accent-blue: #3498db;--bg-dark: #091315;--text-light: #f5f6fa;--text-muted: #95a5a6;--text-highlight: #ffffff;--card-bg: rgba(255, 255, 255, .06);--card-border: rgba(255, 255, 255, .1);--card-glow: rgba(0, 0, 0, .25);--success: #2ecc71;--warning: #f1c40f;--danger: #e74c3c;--font-primary: "Be Vietnam Pro", "Segoe UI", system-ui, sans-serif;--transition-smooth: all .35s cubic-bezier(.25, .8, .25, 1);position:relative;display:flex;justify-content:center;min-height:100vh;padding:16px;overflow-x:hidden;color:var(--text-light);background-color:var(--bg-dark);background-image:radial-gradient(circle at 50% 0%,#152b20,#091315 70%);font-family:var(--font-primary);line-height:1.5}.legacy-trip h1,.legacy-trip h2,.legacy-trip h3,.legacy-trip h4,.legacy-trip p,.legacy-trip ul{margin:0;font-family:var(--font-primary);letter-spacing:normal}.legacy-trip ul{list-style:none;padding:0}.legacy-trip button{font-family:var(--font-primary)}.legacy-trip .bg-glow{position:fixed;width:300px;height:300px;border-radius:50%;filter:blur(100px);opacity:.15;z-index:0;pointer-events:none}.legacy-trip .bg-glow-1{top:5%;left:-10%;background-color:var(--primary-light)}.legacy-trip .bg-glow-2{bottom:10%;right:-10%;background-color:var(--accent)}.legacy-trip .app-container{position:relative;z-index:1;width:100%;max-width:600px;display:flex;flex-direction:column;gap:16px;padding-bottom:90px}.legacy-trip .glass{background:var(--card-bg);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border:1px solid var(--card-border);border-radius:20px;box-shadow:0 8px 32px 0 var(--card-glow)}.legacy-trip .app-header{padding:64px 18px 24px;text-align:center;position:relative;overflow:hidden}.legacy-trip .hdr-corner{position:absolute;top:16px;display:flex;gap:8px;z-index:3}.legacy-trip .hdr-corner.left{left:16px;width:36px;height:36px;align-items:center;justify-content:center;border:0;border-radius:50%;color:var(--text-light);background:#ffffff0f;cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .hdr-corner.right{right:16px}.legacy-trip .hdr-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:0;border-radius:50%;color:var(--text-light);background:#ffffff0f;cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .hdr-corner.left:hover,.legacy-trip .hdr-btn:hover{background:#ffffff24}.legacy-trip .hdr-btn.active{color:var(--accent);background:#d4af3726}.legacy-trip .header-content{display:flex;flex-direction:column;align-items:center;gap:8px}.legacy-trip .badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid rgba(212,175,55,.3);border-radius:30px;background:#d4af3726;color:var(--accent);font-size:.75rem;font-weight:600;letter-spacing:1px}.legacy-trip .icon-spin{animation:spin 8s linear infinite}.legacy-trip .app-header h1{font-size:2.2rem;font-weight:700;background:linear-gradient(135deg,#fff 0%,var(--accent-light) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.5px}.legacy-trip .subtitle{font-size:.85rem;color:var(--text-muted)}.legacy-trip .trip-meta{display:flex;justify-content:center;flex-wrap:wrap;gap:12px;margin-top:14px;width:100%}.legacy-trip .meta-item{display:flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid rgba(255,255,255,.05);border-radius:12px;background:#ffffff0a;font-size:.78rem}.legacy-trip .meta-item svg{color:var(--accent)}.legacy-trip .weather-strip{display:inline-flex;align-items:center;gap:10px;margin:10px 0 2px;padding:8px 16px;border:1px solid rgba(255,255,255,.12);border-radius:16px;background:#ffffff0d}.legacy-trip .weather-emoji{font-size:1.5rem;line-height:1}.legacy-trip .weather-temp{color:var(--text-highlight);font-size:1.5rem;font-weight:700;line-height:1}.legacy-trip .weather-meta{display:flex;flex-direction:column;gap:2px;text-align:left;color:var(--text-muted);font-size:.7rem}.legacy-trip.light-mode .weather-strip{border-color:#0913151a;background:#0913150a}.legacy-trip .nav-tabs{position:fixed;bottom:16px;left:16px;right:16px;max-width:600px;margin:0 auto;z-index:100;display:flex;justify-content:space-around;padding:10px;border:1px solid rgba(255,255,255,.08);border-radius:24px;background:#091315d9;backdrop-filter:blur(16px)}.legacy-trip .tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 6px;border:0;border-radius:16px;background:none;color:var(--text-muted);font-size:.7rem;font-weight:500;cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .tab-btn:hover{color:var(--text-light)}.legacy-trip .tab-btn.active{color:var(--accent);background:#d4af371a}.legacy-trip .tab-btn.active svg{transform:translateY(-2px) scale(1.1)}.legacy-trip .tab-btn svg{transition:transform .3s ease}.legacy-trip .tab-panel{display:flex;flex-direction:column;gap:16px;animation:fadeIn .4s ease forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.legacy-trip .panel-header{padding:8px 4px}.legacy-trip .panel-header h2{font-size:1.25rem;font-weight:600}.legacy-trip .panel-header p{margin-top:2px;font-size:.8rem;color:var(--text-muted)}.legacy-trip .card{display:flex;flex-direction:column;gap:12px;padding:20px}.legacy-trip .cards-grid{display:flex;flex-direction:column;gap:16px}.legacy-trip .card-title{display:flex;align-items:center;gap:8px}.legacy-trip .card-title h3{font-size:1.05rem;font-weight:600}.legacy-trip .card-desc{font-size:.85rem;color:var(--text-muted);line-height:1.45}.legacy-trip .text-blue{color:var(--accent-blue)}.legacy-trip .text-gold{color:var(--accent)}.legacy-trip .border-blue{border-left:4px solid var(--accent-blue)}.legacy-trip .border-gold{border-left:4px solid var(--accent)}.legacy-trip .location-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.legacy-trip .location-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff0a;color:var(--text-light);font-size:.75rem;font-weight:500;text-decoration:none;cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .location-btn svg{color:var(--accent-blue)}.legacy-trip .location-btn:hover{background:#ffffff14;border-color:#fff3}.legacy-trip .location-btn.btn-accent{border-color:#d4af374d}.legacy-trip .location-btn.btn-accent svg{color:var(--accent)}.legacy-trip .add-toggle{align-self:flex-start}.legacy-trip .route-map-card{position:relative;overflow:hidden;padding:24px 16px}.legacy-trip .route-stops{display:flex;flex-direction:column;padding:4px 2px}.legacy-trip .route-stop{position:relative;display:flex;align-items:center;gap:14px;padding:8px 2px}.legacy-trip .route-stop:not(:last-child):before{content:"";position:absolute;left:18px;top:50%;width:2px;height:100%;transform:translate(-50%);background:#ffffff1f;z-index:0}.legacy-trip .route-stop-marker{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;border-radius:50%;border:2px solid var(--card-border);background:#112820;color:var(--text-light);box-shadow:0 4px 10px #00000040}.legacy-trip .route-stop-marker.start{background:var(--accent-blue);border-color:#5dade2;color:#fff;box-shadow:0 0 12px #3498db80}.legacy-trip .route-stop-marker.end{background:var(--success);border-color:#58d68d;color:#06210f}.legacy-trip .route-stop-info{display:flex;flex-direction:column;gap:2px;min-width:0}.legacy-trip .route-stop-name{font-size:.88rem;font-weight:600;color:var(--text-highlight)}.legacy-trip .route-stop-meta{font-size:.7rem;font-weight:600;color:var(--accent)}.legacy-trip .itinerary-nav{display:flex;width:100%;padding:4px;border:1px solid var(--card-border);border-radius:14px;background:#ffffff08}.legacy-trip .day-btn{flex:1;padding:10px;border:0;border-radius:10px;background:none;color:var(--text-muted);font-size:.78rem;font-weight:600;cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .day-btn.active{background:var(--primary-light);color:#fff;box-shadow:0 4px 10px #00000026}.legacy-trip .timeline-container{position:relative;padding-left:20px;margin-top:10px}.legacy-trip .timeline-container:before{content:"";position:absolute;top:10px;bottom:10px;left:7px;width:2px;background:#ffffff14}.legacy-trip .day-timeline{display:flex;flex-direction:column;gap:20px}.legacy-trip .timeline-item{position:relative;display:flex;flex-direction:column;gap:6px}.legacy-trip .time{padding-left:12px;color:var(--accent);font-size:.8rem;font-weight:700;letter-spacing:.5px}.legacy-trip .timeline-badge{position:absolute;left:-20px;top:0;width:16px;height:16px;border-radius:50%;border:2px solid var(--accent);background:var(--bg-dark);z-index:2}.legacy-trip .timeline-item:first-child .timeline-badge{border-color:var(--accent-blue);background:var(--accent-blue);box-shadow:0 0 8px var(--accent-blue)}.legacy-trip .timeline-content{display:flex;flex-direction:column;gap:6px;padding:16px;border-radius:16px}.legacy-trip .timeline-content h4{font-size:.95rem;font-weight:600;color:var(--text-highlight)}.legacy-trip .timeline-content p{font-size:.82rem;color:var(--text-muted);line-height:1.4}.legacy-trip .location-tag{display:inline-flex;align-items:center;gap:4px;align-self:flex-start;padding:4px 10px;border:1px solid rgba(52,152,219,.15);border-radius:8px;background:#3498db14;color:var(--accent-blue);font-size:.72rem;text-decoration:none;transition:var(--transition-smooth)}.legacy-trip .location-tag:hover{background:#3498db29;border-color:#3498db4d;transform:translateY(-1px)}.legacy-trip .timeline-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.legacy-trip .timeline-actions{display:flex;gap:4px;flex-shrink:0}.legacy-trip .icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--card-border);border-radius:8px;background:#ffffff0a;color:var(--text-muted);cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .icon-btn:hover{color:var(--text-light);background:#ffffff1a}.legacy-trip .icon-btn.danger:hover{color:var(--danger);background:#e74c3c1a;border-color:#e74c3c4d}.legacy-trip .activity-form{display:grid;grid-template-columns:1fr;gap:10px;margin:6px 0 0}.legacy-trip .activity-form label{color:var(--text-muted);font-size:.75rem;font-weight:500;letter-spacing:normal}.legacy-trip .activity-form select,.legacy-trip .activity-form input,.legacy-trip .activity-form textarea{margin-top:4px;width:100%;min-height:40px;padding:8px 10px;border-radius:10px;font-size:.85rem}.legacy-trip .activity-form select{color-scheme:dark}.legacy-trip.light-mode .activity-form select{color-scheme:light}.legacy-trip .activity-form-actions{display:flex;align-items:center;gap:8px}.legacy-trip.light-mode .icon-btn{border-color:#0913151f;background:#f8fafb;color:#4e5f62}.legacy-trip.light-mode .icon-btn:hover{color:#1b2d32;background:#0913150f}.legacy-trip .checklist-progress-container{padding:16px}.legacy-trip .progress-info{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.8rem;font-weight:500}.legacy-trip .progress-bar-bg{width:100%;height:8px;border-radius:10px;background:#ffffff0d;overflow:hidden}.legacy-trip .progress-bar-fill{height:100%;border-radius:10px;background:linear-gradient(to right,var(--accent),var(--success));transition:width .4s cubic-bezier(.25,.8,.25,1)}.legacy-trip .progress-blue{background:linear-gradient(to right,var(--accent-blue),var(--accent))}.legacy-trip .checklist-sections{display:flex;flex-direction:column;gap:16px}.legacy-trip .checklist-group{margin:0;padding:20px}.legacy-trip .checklist-group h3{display:flex;align-items:center;gap:8px;color:var(--accent-light);font-size:.95rem;font-weight:600}.legacy-trip .checklist-group h3 svg{color:var(--accent)}.legacy-trip .checklist-items{display:flex;flex-direction:column;gap:14px}.legacy-trip .check-item{display:flex;align-items:flex-start;gap:12px;position:relative;color:var(--text-light);font-size:.82rem;font-weight:400;line-height:1.35;letter-spacing:normal;cursor:pointer;user-select:none}.legacy-trip .check-item input{position:absolute;width:0;height:0;opacity:0}.legacy-trip .checkmark{position:relative;top:2px;width:18px;height:18px;flex-shrink:0;border:1px solid var(--card-border);border-radius:5px;background:#ffffff0d;transition:var(--transition-smooth)}.legacy-trip .check-item:hover input~.checkmark{border-color:#ffffff4d}.legacy-trip .check-item input:checked~.checkmark{background-color:var(--success);border-color:var(--success)}.legacy-trip .checkmark:after{content:"";position:absolute;display:none;left:5px;top:2px;width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.legacy-trip .check-item input:checked~.checkmark:after{display:block}.legacy-trip .check-item input:checked~.item-text{color:var(--text-muted);text-decoration:line-through}.legacy-trip .checklist-group-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.legacy-trip .checklist-group-head h3{margin:0;flex:1;min-width:0}.legacy-trip .checklist-group-actions,.legacy-trip .checklist-item-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.legacy-trip .check-item-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.legacy-trip .check-item-row .check-item{flex:1;min-width:0}.legacy-trip .checklist-inline-form{display:flex;align-items:center;gap:8px;width:100%}.legacy-trip .checklist-inline-form input{flex:1;min-width:0;padding:8px 10px;border:1px solid var(--card-border);border-radius:10px;background:#ffffff0d;color:var(--text-light);font:inherit;font-size:.82rem}.legacy-trip.light-mode .checklist-inline-form input{background:#fff;color:var(--text-highlight)}.legacy-trip.light-mode .checklist-group h3{color:var(--primary)}.legacy-trip.light-mode .checklist-group h3 svg{color:var(--primary-light)}.legacy-trip .checklist-icon-btn{display:grid;place-items:center;width:30px;height:30px;padding:0;border:1px solid var(--card-border);border-radius:8px;background:#ffffff0a;color:var(--text-muted);cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .checklist-icon-btn:hover{border-color:#d4af3759;color:var(--accent-light);background:#d4af3714}.legacy-trip .checklist-icon-btn.danger:hover{border-color:#e74c3c73;color:#ffb4ab;background:#e74c3c1f}.legacy-trip .checklist-add-item-btn{display:inline-flex;align-items:center;gap:6px;margin-top:2px;padding:6px 0;border:0;background:transparent;color:var(--text-muted);font-size:.76rem;font-weight:500;cursor:pointer}.legacy-trip .checklist-add-item-btn:hover{color:var(--accent-light)}.legacy-trip .checklist-add-group-form{padding:14px}.legacy-trip .checklist-add-group-btn{width:100%;justify-content:center}.legacy-trip .checklist-empty{margin:0;text-align:center}.legacy-trip .budget-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:0}.legacy-trip .b-card{display:flex;flex-direction:column;gap:4px;padding:16px}.legacy-trip .b-card.total{grid-column:span 2}.legacy-trip .b-title{color:var(--text-muted);font-size:.72rem;font-weight:500}.legacy-trip .b-value{color:var(--text-highlight);font-size:1.4rem;font-weight:700;letter-spacing:-.5px}.legacy-trip .b-subtitle{color:var(--text-muted);font-size:.65rem}.legacy-trip .text-accent{color:var(--accent)}.legacy-trip .text-green{color:var(--success)}.legacy-trip .budget-chart-container{padding:16px}.legacy-trip .budget-tracker-grid{display:flex;flex-direction:column;gap:16px}.legacy-trip .expense-form-container,.legacy-trip .expense-log-container{padding:20px}.legacy-trip .expense-form-container h3,.legacy-trip .expense-log-container h3{display:flex;align-items:center;gap:8px;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.08);font-size:.95rem;font-weight:600}.legacy-trip .expense-form-container h3 svg,.legacy-trip .expense-log-container h3 svg{color:var(--accent)}.legacy-trip #expense-form{display:flex;flex-direction:column;gap:12px}.legacy-trip .form-group{display:flex;flex-direction:column;gap:6px}.legacy-trip .form-group label{color:var(--text-muted);font-size:.75rem;font-weight:500;letter-spacing:normal}.legacy-trip .form-group input,.legacy-trip .form-group select{padding:10px 14px;border:1px solid var(--card-border);border-radius:12px;background:#ffffff08;color:var(--text-highlight);font-family:var(--font-primary);font-size:.85rem}.legacy-trip .form-group input:focus,.legacy-trip .form-group select:focus{border-color:var(--accent);background:#ffffff0f;box-shadow:none}.legacy-trip .submit-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;margin-top:4px;padding:12px;border:0;border-radius:12px;background:var(--accent);color:#111;font-family:var(--font-primary);font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .submit-btn:hover{background:#e5be58;transform:translateY(-1px)}.legacy-trip .expense-list-wrapper{max-height:360px;overflow-y:auto}.legacy-trip .expense-list{display:flex;flex-direction:column;gap:10px}.legacy-trip .exp-empty{color:var(--text-muted);font-size:.82rem}.legacy-trip .expense-item{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid rgba(255,255,255,.04);border-radius:14px;background:#ffffff05}.legacy-trip .exp-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px}.legacy-trip .bg-food{background:#2ecc711f;color:var(--success)}.legacy-trip .bg-ticket{background:#d4af371f;color:var(--accent)}.legacy-trip .bg-gas,.legacy-trip .bg-blue-light{background:#3498db1f;color:var(--accent-blue)}.legacy-trip .bg-other{background:#95a5a61f;color:var(--text-muted)}.legacy-trip .exp-details{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.legacy-trip .exp-name{color:var(--text-highlight);font-size:.8rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legacy-trip .exp-time{color:var(--text-muted);font-size:.65rem}.legacy-trip .exp-amount{color:var(--text-highlight);font-size:.82rem;font-weight:600;white-space:nowrap}.legacy-trip .delete-exp-btn{display:flex;align-items:center;justify-content:center;padding:6px;border:0;border-radius:8px;background:none;color:#e74c3c80;cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .delete-exp-btn:hover{color:var(--danger);background:#e74c3c14}.legacy-trip .export-link{margin-top:14px;justify-content:center}.legacy-trip select option{color:#14201d;background:#fff}.legacy-trip .b-edit{display:inline-grid;place-items:center;width:22px;height:22px;margin-left:8px;vertical-align:middle;border:0;border-radius:6px;background:#ffffff1a;color:var(--text-muted);cursor:pointer}.legacy-trip .b-edit:hover{color:var(--text-light);background:#ffffff2e}.legacy-trip.light-mode .b-edit{background:#0913150f}.legacy-trip .budget-edit-form{display:flex;align-items:center;gap:8px;margin-top:6px}.legacy-trip .budget-edit-form input{flex:1;min-width:0;padding:8px 10px;font-size:1rem;font-weight:700}.legacy-trip .budget-edit-actions{display:flex;gap:6px}.legacy-trip .budget-edit-actions .submit-btn,.legacy-trip .budget-edit-actions .ghost-button{margin:0;padding:8px 10px}.legacy-trip .expense-item.editing{flex-direction:column;align-items:stretch}.legacy-trip .expense-edit-form{display:grid;gap:8px;width:100%}.legacy-trip .expense-edit-form input,.legacy-trip .expense-edit-form select{padding:8px 10px;font-size:.85rem}.legacy-trip .expense-edit-actions{display:flex;gap:8px}.legacy-trip .expense-edit-actions .submit-btn,.legacy-trip .expense-edit-actions .ghost-button{margin:0}.legacy-trip .delete-exp-btn.edit{color:var(--text-muted)}.legacy-trip .delete-exp-btn.edit:hover{color:var(--accent);background:#d4af371a}.legacy-trip .cars-layout{display:flex;flex-direction:column;gap:16px}.legacy-trip .cars-control-card{padding:20px}.legacy-trip .gps-control{display:flex;flex-direction:column;gap:10px}.legacy-trip .switch-container{display:flex;align-items:center;gap:12px;color:var(--text-light);font-size:.85rem;font-weight:500}.legacy-trip .switch{position:relative;display:inline-block;width:44px;height:24px}.legacy-trip .switch input{width:0;height:0;opacity:0}.legacy-trip .slider{position:absolute;inset:0;border:1px solid var(--card-border);background-color:#ffffff0d;cursor:pointer;transition:.3s}.legacy-trip .slider:before{content:"";position:absolute;left:3px;bottom:3px;width:16px;height:16px;background-color:#fff;transition:.3s}.legacy-trip input:checked+.slider{background-color:var(--success);border-color:var(--success)}.legacy-trip input:checked+.slider:before{transform:translate(20px)}.legacy-trip .slider.round{border-radius:24px}.legacy-trip .slider.round:before{border-radius:50%}.legacy-trip .gps-status-text{display:flex;align-items:center;gap:4px;color:var(--text-muted);font-size:.72rem}.legacy-trip .gps-status-text.active{color:var(--success)}.legacy-trip .gps-status-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.legacy-trip .gps-edit-btn{padding:6px 10px;font-size:.72rem}.legacy-trip .gps-status-actions{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.legacy-trip .fleet-delete-toggle{display:inline-flex;align-items:center;cursor:pointer;user-select:none}.legacy-trip .gps-status-row--fleet-delete{justify-content:flex-end}.legacy-trip .fleet-delete-switch{width:38px;height:22px;flex-shrink:0}.legacy-trip .fleet-delete-switch .slider:before{width:14px;height:14px}.legacy-trip .fleet-delete-switch input:checked+.slider:before{transform:translate(16px)}.legacy-trip .fleet-delete-switch input:checked+.slider{background-color:var(--danger);border-color:var(--danger)}.legacy-trip .cars-dashboard{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.legacy-trip .dash-item{display:flex;flex-direction:column;gap:4px;padding:14px;border:1px solid var(--card-border);border-radius:16px;background:var(--card-bg)}.legacy-trip .dash-item-clickable{width:100%;text-align:left;color:inherit;font:inherit;cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .dash-item-wrap{position:relative}.legacy-trip .dash-item-wrap .dash-item-clickable{width:100%}.legacy-trip .dash-sub-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:22px}.legacy-trip .dash-sub-row .dash-sub{flex:1;min-width:0;line-height:1.35}.legacy-trip .dash-item-remove{flex-shrink:0;display:grid;place-items:center;width:22px;height:22px;padding:0;border:1px solid rgba(231,76,60,.35);border-radius:7px;background:#e74c3c1f;color:#ff9f94;cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .dash-item-remove.is-hidden{visibility:hidden;pointer-events:none}.legacy-trip .dash-item-remove:hover{background:#e74c3c38;color:#ffc8c2}.legacy-trip .dash-item-unnamed{opacity:.72;cursor:default}.legacy-trip .dash-item-clickable:hover{border-color:#d4af3759;background:#d4af370f}.legacy-trip .dash-item.colspan-2{grid-column:span 2;align-items:center;text-align:center}.legacy-trip .dash-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%}.legacy-trip .dash-title-row .dash-title{flex:1;min-width:0}.legacy-trip .dash-title{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:.74rem;font-weight:600}.legacy-trip .dash-dot{width:9px;height:9px;flex-shrink:0;border-radius:50%}.legacy-trip .dash-mine{color:var(--accent-blue);font-weight:700}.legacy-trip .dash-value{display:flex;align-items:center;gap:7px;color:var(--text-highlight);font-size:.95rem;font-weight:700}.legacy-trip .status-dot{width:11px;height:11px;flex-shrink:0;border-radius:50%}.legacy-trip .status-dot.live{background:var(--success);animation:pulse-live 1.4s ease-out infinite}.legacy-trip .status-dot.stale{background:var(--warning)}.legacy-trip .status-dot.offline{background:var(--danger);opacity:.45}@keyframes pulse-live{0%{box-shadow:0 0 #2ecc718c}70%{box-shadow:0 0 0 8px #2ecc7100}to{box-shadow:0 0 #2ecc7100}}.legacy-trip .dist-badges{display:flex;flex-wrap:wrap;gap:8px}.legacy-trip .dist-badge{display:inline-flex;align-items:center;gap:7px;padding:8px 12px;border:1px solid rgba(212,175,55,.25);border-radius:12px;background:#d4af371a;color:var(--accent-light);font-size:.78rem;font-weight:600}.legacy-trip .dist-badges--map-overlay{position:absolute;left:max(10px,env(safe-area-inset-left));bottom:max(10px,env(safe-area-inset-bottom));z-index:6;max-width:min(420px,calc(100% - 56px));pointer-events:none}.legacy-trip .dist-badges--map-overlay .dist-badge{background:#080e0c94;border-color:#ffffff24;box-shadow:0 4px 16px #00000047;backdrop-filter:blur(16px) saturate(1.1);-webkit-backdrop-filter:blur(16px) saturate(1.1);font-size:.82rem;font-weight:700;color:#fff;letter-spacing:.01em;text-shadow:0 0 1px rgba(0,0,0,.95),0 1px 3px rgba(0,0,0,.85),0 2px 10px rgba(0,0,0,.55);pointer-events:auto}.legacy-trip.light-mode .dist-badges--map-overlay .dist-badge,.legacy-trip .map-stage.light-mode .dist-badges--map-overlay .dist-badge{border:1px solid rgba(9,19,21,.32);background:#fffffff0;color:#1b2d32;box-shadow:0 2px 10px #0913151f;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);text-shadow:none}.legacy-trip .map-stage:fullscreen .dist-badges--map-overlay,.legacy-trip .map-stage:-webkit-full-screen .dist-badges--map-overlay{left:max(14px,env(safe-area-inset-left));bottom:max(14px,env(safe-area-inset-bottom))}.legacy-trip.map-fullscreen-portal .dist-badges--map-overlay{left:max(14px,env(safe-area-inset-left));bottom:max(14px,env(safe-area-inset-bottom))}.legacy-trip .dist-route-error{margin:0;font-size:.72rem}.legacy-trip .dist-dot{width:8px;height:8px;flex-shrink:0;border-radius:50%}.legacy-trip.light-mode .dist-badge{color:#8a6d00}.legacy-trip .dash-sub{color:var(--text-muted);font-size:.65rem}.legacy-trip .border-red{border-left:4px solid var(--danger)}.legacy-trip .map-card{display:flex;flex-direction:column;gap:8px;padding:8px}.legacy-trip .map-stage{position:relative}.legacy-trip .map-stage:fullscreen,.legacy-trip .map-stage:-webkit-full-screen{width:100%;height:100%;background:#0a1512}.legacy-trip .map-stage:fullscreen .static-map,.legacy-trip .map-stage:-webkit-full-screen .static-map{height:100%;max-height:none;border-radius:0}.legacy-trip.map-fullscreen-portal{position:fixed;inset:0;z-index:9999;box-sizing:border-box;width:100%;height:100%;height:100dvh;max-height:100dvh;margin:0;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);overflow:hidden;background:#0a1512}.legacy-trip.map-fullscreen-portal .map-stage{width:100%;height:100%}.legacy-trip.map-fullscreen-portal .static-map{height:100%;max-height:none;border-radius:0}.legacy-trip .map-stage-placeholder{width:100%;height:clamp(380px,64vh,560px);border-radius:14px;background:#08121047}.legacy-trip .map-fullscreen-btn{position:absolute;top:10px;right:10px;z-index:6;display:grid;place-items:center;width:36px;height:36px;padding:0;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:#091315cc;color:#fff;cursor:pointer;backdrop-filter:blur(6px);transition:var(--transition-smooth);touch-action:manipulation;-webkit-tap-highlight-color:transparent}.legacy-trip .map-fullscreen-btn:hover{background:#091315f2}.legacy-trip .vehicle-pin-card{position:absolute;top:10px;left:10px;z-index:5;width:min(320px,calc(100% - 56px));padding:10px 11px;border:1px solid rgba(255,255,255,.14);border-radius:12px;background:#081210e0;backdrop-filter:blur(10px);box-shadow:0 8px 24px #00000059;pointer-events:auto}.legacy-trip .vehicle-pin-card-head{display:flex;align-items:center;gap:6px;min-width:0}.legacy-trip .vehicle-pin-card-title{flex:1;min-width:0;overflow:hidden;color:var(--text-highlight);font-size:.82rem;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.legacy-trip .vehicle-pin-card-status{color:var(--text-muted);font-size:.68rem;font-weight:600;white-space:nowrap}.legacy-trip .vehicle-pin-close{display:grid;place-items:center;width:24px;height:24px;padding:0;border:none;border-radius:8px;background:#ffffff14;color:var(--text-muted);cursor:pointer;flex-shrink:0}.legacy-trip .vehicle-pin-close:hover{background:#ffffff24;color:#fff}.legacy-trip .vehicle-pin-card-address{margin:6px 0 0;color:var(--accent-light);font-size:.74rem;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.legacy-trip .vehicle-pin-card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px}.legacy-trip .vehicle-pin-card-meta{color:var(--text-muted);font-size:.68rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.legacy-trip .vehicle-pin-card-actions{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}.legacy-trip .vehicle-pin-card-trail{display:inline-flex;align-items:center;gap:4px;padding:0;border:none;background:transparent;color:var(--accent-light);font-size:.68rem;font-weight:600;font-family:inherit;white-space:nowrap;flex-shrink:0;cursor:pointer;text-decoration:none}.legacy-trip .vehicle-pin-card-trail:hover:not(:disabled){color:#fff}.legacy-trip .vehicle-pin-card-trail.active{color:#fff}.legacy-trip .vehicle-pin-card-trail:disabled{opacity:.72;cursor:wait}.legacy-trip .vehicle-pin-card-maps{display:inline-flex;align-items:center;gap:4px;color:var(--accent-light);font-size:.68rem;font-weight:600;text-decoration:none;white-space:nowrap;flex-shrink:0}.legacy-trip .vehicle-pin-card-maps:hover{color:#fff}.legacy-trip.light-mode .vehicle-pin-card{background:#fffffff0;border-color:#00000014}.legacy-trip .map-stage.light-mode .vehicle-pin-card{background:#fffffff0;border-color:#00000014;box-shadow:0 8px 24px #0000001f}.legacy-trip.light-mode .vehicle-pin-card-address,.legacy-trip .map-stage.light-mode .vehicle-pin-card-address{color:#2c3e50}.legacy-trip.light-mode .vehicle-pin-card-maps,.legacy-trip .map-stage.light-mode .vehicle-pin-card-maps,.legacy-trip.light-mode .vehicle-pin-card-trail,.legacy-trip .map-stage.light-mode .vehicle-pin-card-trail{color:#1a6b5c}.legacy-trip.light-mode .vehicle-pin-card-maps:hover,.legacy-trip .map-stage.light-mode .vehicle-pin-card-maps:hover,.legacy-trip.light-mode .vehicle-pin-card-trail:hover:not(:disabled),.legacy-trip .map-stage.light-mode .vehicle-pin-card-trail:hover:not(:disabled),.legacy-trip.light-mode .vehicle-pin-card-trail.active,.legacy-trip .map-stage.light-mode .vehicle-pin-card-trail.active{color:#0d4a40}.legacy-trip.light-mode .vehicle-pin-close,.legacy-trip .map-stage.light-mode .vehicle-pin-close{background:#0913150f;color:var(--text-muted)}.legacy-trip.light-mode .vehicle-pin-close:hover,.legacy-trip .map-stage.light-mode .vehicle-pin-close:hover{background:#0913151a;color:var(--text-highlight)}.legacy-trip.light-mode .vehicle-pin-card-title,.legacy-trip .map-stage.light-mode .vehicle-pin-card-title{color:#1a2e28}.legacy-trip.light-mode.map-fullscreen-portal{background:#eef3f1}.legacy-trip.light-mode .map-stage:fullscreen,.legacy-trip.light-mode .map-stage:-webkit-full-screen{background:#eef3f1}.legacy-trip .static-map{position:relative;width:100%;height:clamp(380px,64vh,560px);overflow:hidden;border-radius:14px;background:#0a1512;cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;overscroll-behavior:none}.legacy-trip .static-map:active{cursor:grabbing}.legacy-trip .static-map-viewport{position:absolute;inset:0;will-change:transform}.legacy-trip .map-controls{position:absolute;right:10px;bottom:10px;z-index:3;display:flex;flex-direction:column;gap:6px}.legacy-trip .map-controls button{display:grid;place-items:center;width:36px;height:36px;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:#091315cc;color:#fff;font-size:1.2rem;line-height:1;cursor:pointer;backdrop-filter:blur(6px);transition:var(--transition-smooth)}.legacy-trip .map-controls button:hover{background:#091315f2}.legacy-trip .map-controls .map-route-btn.active{border-color:#4caf508c;background:#2e7d3259;color:#b9f6ca}.legacy-trip.light-mode .map-fullscreen-btn,.legacy-trip .map-stage.light-mode .map-fullscreen-btn{border:1px solid rgba(9,19,21,.32);background:#fffffff0;color:#1b2d32;box-shadow:0 2px 10px #0913151f}.legacy-trip.light-mode .map-fullscreen-btn:hover,.legacy-trip .map-stage.light-mode .map-fullscreen-btn:hover{border-color:#09131573;background:#fff;color:#091315}.legacy-trip.light-mode .map-controls button,.legacy-trip .map-stage.light-mode .map-controls button{border:1px solid rgba(9,19,21,.32);background:#fffffff0;color:#1b2d32;box-shadow:0 2px 10px #0913151f}.legacy-trip.light-mode .map-controls button:hover,.legacy-trip .map-stage.light-mode .map-controls button:hover{border-color:#09131573;background:#fff;color:#091315}.legacy-trip.light-mode .map-controls .map-route-btn.active,.legacy-trip .map-stage.light-mode .map-controls .map-route-btn.active{border:1px solid rgba(27,94,32,.55);background:#81c78459;color:#1b5e20}.legacy-trip .static-map-inner{position:absolute;left:50%;top:50%}.legacy-trip .static-map-inner img{display:block;max-width:none}.legacy-trip .static-map-marker{position:absolute;z-index:2;display:flex;flex-direction:column;align-items:center;gap:4px;transform:translate(-50%,-50%);pointer-events:none}.legacy-trip .static-map-speed-tip{padding:2px 7px;border:1px solid rgba(255,255,255,.14);border-radius:8px;background:#091315eb;color:#fff;font-size:.62rem;font-weight:700;line-height:1.2;letter-spacing:.01em;white-space:nowrap;box-shadow:0 2px 8px #0000006b;backdrop-filter:blur(6px);pointer-events:none}.legacy-trip.light-mode .static-map-speed-tip{border-color:#0000001a;background:#fffffff2;color:#1a2e28}.legacy-trip .static-map-pin{position:relative;display:grid;place-items:center;width:30px;height:30px;padding:0;border:2px solid #fff;border-radius:50%;color:#fff;box-shadow:0 2px 8px #0000007a;pointer-events:auto;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.legacy-trip .static-map-pin-icon{display:grid;place-items:center;transform-origin:center center}.legacy-trip .static-map-pin:hover,.legacy-trip .static-map-pin:focus-visible{transform:scale(1.12);box-shadow:0 3px 12px #0000008c;outline:none}.legacy-trip .static-map-place{position:absolute;z-index:1;width:22px;height:22px;transform:translate(-50%,-50%);pointer-events:none}.legacy-trip .static-map-place-pin{display:grid;place-items:center;width:22px;height:22px;padding:0;color:#fff;background:#d4af37;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 7px #0006;cursor:pointer;pointer-events:auto;transition:transform .15s ease,box-shadow .15s ease}.legacy-trip .static-map-place-pin:hover,.legacy-trip .static-map-place-pin:focus-visible{transform:scale(1.15);box-shadow:0 3px 11px #00000080;outline:none}.legacy-trip .static-map-place-label{position:absolute;top:calc(100% + 3px);left:50%;max-width:130px;padding:1px 6px;transform:translate(-50%);color:#fff;background:#091315cc;border-radius:6px;font-size:.6rem;font-weight:600;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.legacy-trip.light-mode .static-map-place-label{background:#ffffffeb;color:#1a2e28}.legacy-trip .static-map-route{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none}.legacy-trip .static-map-route .route-shell{fill:none;stroke-width:6;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 1px 2px rgba(0,0,0,.42))}.legacy-trip .static-map-route.route-tone-ok .route-shell{stroke:#2ecc71}.legacy-trip .static-map-route.route-tone-warn .route-shell{stroke:#f1c40f}.legacy-trip .static-map-route.route-tone-danger .route-shell{stroke:#e74c3c}.legacy-trip .static-map-route .route-center{fill:none;stroke:#0c1614c7;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:8 10}.legacy-trip .static-map-route.route-tone-warn .route-center{stroke:#121c1ad1}.legacy-trip .static-map-route.route-tone-danger .route-center{stroke:#ffffffeb}.legacy-trip .static-map-device-trail{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none}.legacy-trip .static-map-device-trail .device-trail-line{fill:none;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:7 5;opacity:.92;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35))}.legacy-trip.light-mode .static-map-device-trail .device-trail-line,.legacy-trip .map-stage.light-mode .static-map-device-trail .device-trail-line{stroke-width:4.5;filter:drop-shadow(0 1px 1px rgba(255,255,255,.65))}.legacy-trip.light-mode .static-map-route .route-center{stroke:#ffffffe0}.legacy-trip.light-mode .static-map-route.route-tone-warn .route-center{stroke:#1e2826c7}.legacy-trip .map-open-link{justify-content:center}.legacy-trip .gps-note{color:var(--text-muted);font-size:.72rem}.legacy-trip .gps-note-link{padding:0;border:none;background:none;color:var(--accent-light);font-size:inherit;font-family:inherit;font-weight:600;text-decoration:underline;cursor:pointer}.legacy-trip .gps-note-link:hover:not(:disabled){color:#fff}.legacy-trip .gps-note-link:disabled{opacity:.65;cursor:wait}.legacy-trip.light-mode .gps-note-link{color:#1a6b5c}.legacy-trip.light-mode .gps-note-link:hover:not(:disabled){color:#0d4a40}.legacy-trip .gps-note-error{margin-top:4px;font-size:.72rem}.legacy-trip .gps-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.legacy-trip .gps-header-switch{flex-shrink:0;margin-top:4px}.legacy-trip .gps-modal-backdrop{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:18px;background:#050c0bb8;backdrop-filter:blur(4px)}.legacy-trip .gps-modal{width:min(380px,100%);display:grid;gap:12px;padding:22px}.legacy-trip .gps-modal h3{color:var(--text-highlight);font-size:1.1rem}.legacy-trip .gps-modal-field{display:grid;gap:6px;color:var(--text-muted);font-size:.78rem}.legacy-trip .gps-modal-field-label{color:var(--text-muted);font-size:.78rem}.legacy-trip .color-grid{display:flex;flex-wrap:wrap;gap:10px}.legacy-trip .color-swatch{display:grid;place-items:center;width:36px;height:36px;border:2px solid rgba(255,255,255,.25);border-radius:50%;color:#fff;cursor:pointer;transition:var(--transition-smooth)}.legacy-trip .color-swatch.selected{border-color:#fff;transform:scale(1.1);box-shadow:0 0 0 3px #ffffff4d}.legacy-trip .color-swatch.taken{opacity:.3;cursor:not-allowed}.legacy-trip .color-swatch.taken:after{content:"✕";color:#fff;font-size:.8rem}.legacy-trip .gps-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.legacy-trip .gps-modal-actions .submit-btn,.legacy-trip .gps-modal-actions .ghost-button{margin:0}.legacy-trip .app-footer{margin-top:6px;padding:20px 12px;border-top:1px solid rgba(255,255,255,.05);color:var(--text-muted);font-size:.72rem;text-align:center}.legacy-trip .module-panel{padding:20px;border:1px solid var(--card-border);border-radius:20px;background:var(--card-bg);backdrop-filter:blur(16px) saturate(160%)}.legacy-trip .module-panel h2{color:var(--text-highlight);font-size:1.25rem}.legacy-trip .section-heading span,.legacy-trip .muted,.legacy-trip label{color:var(--text-muted)}.legacy-trip input,.legacy-trip select,.legacy-trip textarea{border:1px solid var(--card-border);background:#ffffff0a;color:var(--text-highlight)}.legacy-trip input:focus,.legacy-trip select:focus,.legacy-trip textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #d4af371f}.legacy-trip .member-list article,.legacy-trip .session-list article{border-color:var(--card-border);background:#ffffff08}.legacy-trip .member-list span,.legacy-trip .session-list span{color:var(--text-muted)}.legacy-trip .primary-button{background:var(--accent);color:#111}.legacy-trip .primary-button:hover{background:#e5be58}.legacy-trip .ghost-button{border-color:var(--card-border);color:var(--text-light)}.legacy-trip .role-pill{background:#d4af3726;color:var(--accent)}.legacy-trip .share-link{background:#ffffff0a;color:var(--text-light)}.legacy-trip .share-link-row input{padding:8px 10px;border:1px solid var(--card-border);border-radius:10px;background:#ffffff0a;color:var(--text-light);font:inherit;font-size:.82rem}.legacy-trip .share-link-copy-btn{border-color:var(--card-border);background:#ffffff0f;color:var(--text-muted)}.legacy-trip .share-link-copy-btn:hover{border-color:#d4af3759;background:#d4af371a;color:var(--accent-light)}.legacy-trip .share-link-copy-btn.copied{border-color:#2ecc7173;background:#2ecc7124;color:#9ef0b8}.legacy-trip .pin-card{display:grid;gap:10px;margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--card-border)}.legacy-trip .pin-card h3{color:var(--accent-light);font-size:1rem}.legacy-trip .pin-form{display:flex;flex-wrap:wrap;align-items:end;gap:10px}.legacy-trip .pin-form label{flex:1;min-width:160px}.legacy-trip .pin-form .primary-button,.legacy-trip .pin-form .ghost-button{margin:0}.legacy-trip .form-success{color:var(--success)}@media(max-width:420px){.legacy-trip .tab-btn span{font-size:.62rem}}.legacy-trip.light-mode{--bg-dark: #f0f4f5;--text-light: #1b2d32;--text-muted: #4e5f62;--text-highlight: #091315;--card-bg: #ffffff;--card-border: rgba(9, 19, 21, .08);--card-glow: rgba(9, 19, 21, .04);background-image:radial-gradient(circle at 50% 0%,#d5eada,#f0f4f5 70%)}.legacy-trip.light-mode .glass{background:#fff;border-color:#09131514;box-shadow:0 10px 30px #0913150a;backdrop-filter:none;-webkit-backdrop-filter:none}.legacy-trip.light-mode .bg-glow{opacity:.04}.legacy-trip.light-mode .app-header h1{background:linear-gradient(135deg,#1e3f20,#2c3e50);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.legacy-trip.light-mode .hdr-corner.left,.legacy-trip.light-mode .hdr-btn{color:#1b2d32;background:#0913150d}.legacy-trip.light-mode .hdr-corner.left:hover,.legacy-trip.light-mode .hdr-btn:hover{background:#0913151a}.legacy-trip.light-mode .nav-tabs{border:1px solid rgba(9,19,21,.08);background:#f0f3f4f2;box-shadow:0 8px 24px #0913150d}.legacy-trip.light-mode .tab-btn{color:#4e5f62}.legacy-trip.light-mode .tab-btn.active{color:#1e3f20;background:#1e3f200f}.legacy-trip.light-mode .meta-item{background:#09131508;border-color:#0913150f}.legacy-trip.light-mode .location-btn{background:#f8fafb;border-color:#0913151a;color:#1b2d32}.legacy-trip.light-mode .location-btn:hover{background:#0913150d}.legacy-trip.light-mode .route-stop-marker{background:#fff;border-color:#09131526;color:#1b2d32}.legacy-trip.light-mode .route-stop-marker.start{background:var(--accent-blue);border-color:#5dade2;color:#fff}.legacy-trip.light-mode .route-stop-marker.end{background:var(--success);border-color:#58d68d;color:#06210f}.legacy-trip.light-mode .route-stop:not(:last-child):before{background:#0913151f}.legacy-trip.light-mode .itinerary-nav{border-color:#09131514;background:#09131508}.legacy-trip.light-mode .timeline-container:before{background:#09131514}.legacy-trip.light-mode .progress-bar-bg{background:#0913150f}.legacy-trip.light-mode .checkmark{background:#fff;border-color:#09131526}.legacy-trip.light-mode .check-item:hover input~.checkmark{border-color:var(--primary-light)}.legacy-trip.light-mode .form-group input,.legacy-trip.light-mode .form-group select,.legacy-trip.light-mode input,.legacy-trip.light-mode select,.legacy-trip.light-mode textarea{background:#f8fafb;border:1px solid rgba(9,19,21,.12);color:#091315}.legacy-trip.light-mode .form-group input:focus,.legacy-trip.light-mode .form-group select:focus,.legacy-trip.light-mode input:focus,.legacy-trip.light-mode select:focus,.legacy-trip.light-mode textarea:focus{border-color:var(--primary-light);background:#fff;box-shadow:0 0 0 3px #1e5c2f14}.legacy-trip.light-mode .submit-btn{background:var(--primary-light);color:#fff}.legacy-trip.light-mode .submit-btn:hover{background:var(--primary)}.legacy-trip.light-mode .expense-item{background:#f8fafb;border-color:#0913150f}.legacy-trip.light-mode .slider{background-color:#f1f2f6;border-color:#09131526}.legacy-trip.light-mode .dash-item{background:#fff;border-color:#09131514}.legacy-trip.light-mode .map-card iframe{border:1px solid rgba(9,19,21,.08)}.legacy-trip.light-mode .module-panel{background:#fff;border-color:#09131514}.legacy-trip.light-mode .member-list article,.legacy-trip.light-mode .session-list article,.legacy-trip.light-mode .share-link{background:#f8fafb;border-color:#0913150f}.legacy-trip.light-mode .share-link-row input{background:#fff;color:var(--text-highlight)}.legacy-trip.light-mode .share-link-copy-btn{background:#fff;color:#1b2d32}.legacy-trip.light-mode .ghost-button{border-color:#09131526;color:#1b2d32}.legacy-trip.light-mode .app-footer{border-top-color:#09131514}.app-dark{--primary: #1e3f20;--primary-light: #2c5c2f;--accent: #d4af37;--accent-light: #f3e5ab;--accent-blue: #3498db;--bg-dark: #091315;--text-light: #f5f6fa;--text-muted: #95a5a6;--text-highlight: #ffffff;--card-bg: rgba(255, 255, 255, .06);--card-border: rgba(255, 255, 255, .1);--success: #2ecc71;--danger: #e74c3c;min-height:100vh;color:var(--text-light);background-color:var(--bg-dark);background-image:radial-gradient(circle at 50% 0%,#152b20,#091315 70%);font-family:Be Vietnam Pro,Segoe UI,system-ui,sans-serif}.app-dark .glass{border:1px solid var(--card-border);border-radius:20px;background:var(--card-bg);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);box-shadow:0 8px 32px #00000040}.app-dark label{color:var(--text-muted)}.app-dark input,.app-dark select,.app-dark textarea{border:1px solid var(--card-border);background:#ffffff0a;color:var(--text-highlight)}.app-dark input:focus,.app-dark select:focus,.app-dark textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #d4af3724}.app-dark select option{color:#14201d;background:#fff}.app-dark .primary-button{background:var(--accent);color:#14110a}.app-dark .primary-button:hover{background:#e5be58}.app-dark .text-button{color:var(--accent-light)}.app-dark .ghost-button,.app-dark .back-button{border:1px solid var(--card-border);color:var(--text-light);background:transparent}.app-dark .ghost-button:hover,.app-dark .back-button:hover{background:#ffffff0f}.app-dark .eyebrow{color:var(--accent)}.app-dark .muted,.app-dark .empty-state p{color:var(--text-muted)}.app-dark .form-error{color:#ff8a7a}.app-dark .form-success{color:var(--success)}.app-dark code{color:var(--accent-light)}.auth-screen{position:relative;display:grid;place-items:center;gap:16px;padding:24px;overflow:hidden}.app-dark .bg-glow{position:fixed;z-index:0;width:340px;height:340px;border-radius:50%;filter:blur(110px);opacity:.18;pointer-events:none}.app-dark .bg-glow-1{top:-8%;left:-6%;background:var(--primary-light)}.app-dark .bg-glow-2{right:-6%;bottom:-8%;background:var(--accent)}.auth-box{position:relative;z-index:1;width:min(440px,100%);display:grid;gap:1.1rem;padding:2.2rem}.auth-brand{display:flex;align-items:center;gap:14px}.auth-brand .brand-mark{width:52px;height:52px;flex-shrink:0;color:#fff;border-color:#ffffff59;font-size:1.5rem}.auth-brand .eyebrow{margin-bottom:4px}.auth-brand h1{margin:0;color:var(--text-highlight);font-size:1.85rem;line-height:1.05}.auth-tagline{margin:-2px 0 0;color:var(--text-muted);font-size:.88rem;line-height:1.6}.auth-box--register{width:min(480px,100%)}.auth-mode-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:4px;border-radius:12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.auth-mode-tab{border:none;border-radius:9px;padding:10px 12px;font-size:.88rem;font-weight:600;color:var(--text-muted);background:transparent;cursor:pointer;transition:background .15s,color .15s}.auth-mode-tab.active{color:#fff;background:#ff9f942e;box-shadow:inset 0 0 0 1px #ff9f9459}.auth-register-closed{margin:0;padding:10px 12px;border-radius:10px;font-size:.82rem;line-height:1.5;color:#ffc8a8;background:#ff9f941a;border:1px solid rgba(255,159,148,.25)}.auth-invite-banner{margin:0;padding:12px 14px;border-radius:10px;font-size:.84rem;line-height:1.55;color:#e8f4ff;background:#60a5fa1f;border:1px solid rgba(96,165,250,.28);display:grid;gap:6px}.auth-invite-banner strong{color:#fff;font-weight:600}.auth-invite-banner--error{color:#ffc8a8;background:#ff9f941a;border-color:#ff9f9447}.auth-form-hint{margin:-4px 0 0;font-size:.78rem;line-height:1.55;color:var(--text-muted)}.auth-box form{gap:.9rem;margin-top:2px}.auth-box .primary-button{margin-top:.4rem;padding:.95rem;font-size:.95rem}.auth-links{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.auth-links .text-button{margin:0;padding:4px 0}.auth-foot{position:relative;z-index:1;margin:0;color:var(--text-muted);font-size:.72rem;text-align:center}.app-dark .action-card{border-color:var(--card-border);background:var(--card-bg);backdrop-filter:blur(16px) saturate(160%);box-shadow:0 8px 32px #00000040}.app-dark .action-card h1{color:var(--text-highlight)}.app-dark .topbar{border-bottom:1px solid var(--card-border);background:#091315b8;backdrop-filter:blur(18px)}.app-dark .brand,.app-dark .user-menu{color:var(--text-light)}.app-dark .brand-mark.small{color:var(--text-light);border-color:var(--card-border)}.app-dark .hero-row h1{color:var(--text-highlight)}.app-dark .hero-row p:not(.eyebrow){color:var(--text-muted)}.app-dark .section-heading h2{color:var(--text-highlight)}.app-dark .section-heading span{color:var(--text-muted)}.app-dark .create-trip-card,.app-dark .trip-card{border:1px solid var(--card-border);background:var(--card-bg);backdrop-filter:blur(16px) saturate(160%);box-shadow:0 8px 32px #00000040}.app-dark .trip-card:hover,.app-dark .trip-card:focus{box-shadow:0 18px 44px #0006}.app-dark .trip-body h3{color:var(--text-highlight)}.app-dark .trip-body p,.app-dark .trip-dates{color:var(--text-muted)}.app-dark .trip-dates .line{background:var(--card-border)}.app-dark .role-pill{color:var(--accent);background:#d4af3729}.app-dark .empty-state{border:1px dashed var(--card-border)}.app-dark .empty-state h3{color:var(--text-highlight)}.app-dark .hero-row h1{font-size:clamp(2.2rem,5vw,4.2rem)}.app-dark .trip-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin:-1.5rem 0 2.5rem}.stat-card{display:grid;gap:4px;padding:1.3rem 1.5rem}.stat-num{color:var(--text-highlight);font-family:Playfair Display,Georgia,Times New Roman,serif;font-size:2.2rem;font-weight:600;line-height:1}.stat-label{color:var(--text-muted);font-size:.78rem}.trip-foot{display:flex;align-items:center;justify-content:space-between;margin-top:1rem;padding-top:.9rem;border-top:1px solid var(--card-border);color:var(--accent);font-size:.8rem;font-weight:700}.trip-arrow{transition:transform .2s ease}.trip-card:hover .trip-arrow{transform:translate(4px)}.app-dark .settings-page>header h1{color:var(--text-highlight)}.app-dark .settings-card{border:1px solid var(--card-border);background:var(--card-bg);backdrop-filter:blur(16px) saturate(160%);box-shadow:0 8px 32px #0003}.app-dark .settings-card h2{color:var(--text-highlight)}.app-dark .session-list article,.app-dark .member-list article{border-color:var(--card-border);background:#ffffff08}.app-dark .session-list span,.app-dark .member-list span{color:var(--text-muted)}.app-dark .avatar{background:var(--primary-light)}.app-dark .share-link,.app-dark .mfa-setup,.app-dark .recovery-codes{background:#ffffff0a}.app-dark .danger-zone{border-top:1px solid var(--card-border)}.app-dark .danger-button{border:1px solid rgba(231,76,60,.4);background:#e74c3c1f;color:#ff8a7a}.app-dark .loader{border-color:#ffffff2e;border-top-color:var(--accent)}.admin-console .admin-main{max-width:1100px;margin:0 auto;padding:24px 20px 48px}.admin-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.admin-tab{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:var(--text-muted);border-radius:999px;padding:8px 14px;font-size:.82rem;cursor:pointer;text-decoration:none}.admin-tab.active{color:#fff;border-color:#ff9f9473;background:#ff9f941f}.admin-panel{padding:20px;border-radius:16px}.admin-panel h2{margin:0 0 8px;font-size:1.2rem}.admin-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.admin-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-top:16px}.admin-stat-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px}.admin-stat-value{display:block;font-size:1.35rem;font-weight:700}.admin-stat-label{color:var(--text-muted);font-size:.75rem}.admin-toolbar{display:flex;gap:10px;margin:12px 0}.admin-toolbar input{flex:1;min-width:0}.admin-create-panel{margin:16px 0;padding:18px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:#0000002e}.admin-create-form{display:grid;gap:16px}.admin-form-section{margin:0;padding:0;border:0;min-width:0}.admin-form-section legend{padding:0 0 10px;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}.admin-form-row{display:grid;gap:12px}.admin-form-row.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-form-row.align-end{align-items:end}.admin-create-form label.full{display:grid;gap:6px;margin-top:12px}.admin-create-form textarea{min-height:72px;resize:vertical}.admin-edit-panel{margin-top:0}.admin-panel-head.compact{margin-bottom:12px}.admin-panel-head.compact h3{margin:0;font-size:1rem}.admin-form-actions{display:flex;justify-content:flex-start;gap:8px;padding-top:4px}.admin-check--inline{min-height:42px;justify-content:flex-start}.admin-user-name{font-weight:600;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-self-badge{display:inline-block;padding:1px 7px;border-radius:999px;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);background:#ffd05c1f;border:1px solid rgba(255,208,92,.25)}.admin-table tr.self{background:#ffd05c0a}.admin-user-meta{margin-top:4px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.78rem}@media(max-width:720px){.admin-form-row.cols-2{grid-template-columns:1fr}}.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:16px 0}.admin-form-grid .wide{grid-column:1 / -1}.admin-create-hint{margin:0;font-size:.82rem}.admin-created-credentials{display:grid;gap:10px;padding:14px;border:1px solid rgba(46,204,113,.25);border-radius:12px;background:#2ecc710f}.admin-credential-row{display:grid;grid-template-columns:72px 1fr auto;gap:10px;align-items:center}.admin-credential-label{font-size:.78rem;color:var(--text-muted)}.admin-credential-value{padding:8px 10px;border-radius:8px;background:#00000040;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.85rem;word-break:break-all}.admin-copy-btn.copied{border-color:#2ecc7173;color:#7ddea8}.admin-form-stack{display:grid;gap:12px;margin-top:16px}.admin-console label.admin-check{display:flex;align-items:flex-start;gap:10px;width:100%;font-weight:500;font-size:.85rem;letter-spacing:0;line-height:1.45;cursor:pointer}.admin-console label.admin-check input[type=checkbox]{width:18px;height:18px;min-width:18px;margin-top:2px;padding:0;flex-shrink:0;accent-color:var(--accent)}.admin-console .admin-form-grid label:not(.admin-check),.admin-console .admin-create-form label:not(.admin-check){display:grid;gap:6px;font-size:.78rem;font-weight:600;letter-spacing:.03em}.admin-console .admin-form-stack .primary-button.compact{justify-self:start;width:auto;min-width:120px}.admin-console .admin-smtp-form{display:grid;gap:12px;margin:16px 0}.admin-console .admin-form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}@media(max-width:640px){.admin-console .admin-form-row{grid-template-columns:1fr}}.admin-console .admin-check--solo{width:100%}.admin-console .admin-smtp-form .primary-button.compact{justify-self:start;width:auto}.admin-smtp-hint{display:block;margin-top:8px;font-size:.78rem;line-height:1.5;color:var(--text-muted)}.admin-email-logs{margin-top:28px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08)}.admin-email-logs h3{margin:0 0 12px;font-size:1rem}.admin-table tr.row-fail td{color:#ff9f94}.admin-cell-subject{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-cell-mono{font-family:ui-monospace,monospace;font-size:.72rem;max-width:120px;overflow:hidden;text-overflow:ellipsis}.admin-console .admin-table select{width:auto;min-width:110px;padding:6px 8px;font-size:.8rem}.admin-console .admin-table input[type=checkbox]{width:16px;height:16px;padding:0;margin:0}.admin-check{display:flex;align-items:flex-start;gap:10px}.admin-table-wrap{overflow-x:auto;margin-top:12px}.admin-table{width:100%;border-collapse:collapse;font-size:.82rem}.admin-table th,.admin-table td{border-bottom:1px solid rgba(255,255,255,.08);padding:10px 8px;text-align:left;vertical-align:middle}.admin-table tr.deleted{opacity:.55}.admin-audit-hint{margin:0 0 12px;font-size:.85rem}.admin-audit-toolbar{flex-wrap:wrap;align-items:center}.admin-audit-toolbar .ghost-button.danger,.admin-audit-day-actions{margin-left:auto}.admin-audit-day-actions{display:flex;gap:6px;flex-shrink:0}.admin-audit-day-row td{padding-top:14px;padding-bottom:6px;font-size:.78rem;font-weight:600;letter-spacing:.02em;color:#ffffffb8;border-bottom-color:#ffffff1f;background:#0000001f}.admin-audit-day-row.collapsed td{padding-bottom:10px}.admin-audit-day-toggle{display:inline-flex;align-items:center;gap:8px;width:100%;padding:0;border:0;background:transparent;color:inherit;font:inherit;font-weight:600;cursor:pointer;text-align:left}.admin-audit-day-toggle:hover{color:#ffffffeb}.admin-audit-chevron{flex-shrink:0;opacity:.85;transition:transform .15s ease}.admin-audit-chevron.collapsed{transform:rotate(-90deg)}.admin-audit-day-count{margin-left:auto;font-weight:400;font-size:.74rem;opacity:.65}.admin-audit-total{font-size:.82rem}.admin-audit-table .admin-audit-check{width:36px;text-align:center;padding-left:4px;padding-right:4px}.admin-audit-table .admin-audit-check input{margin:0;cursor:pointer}.admin-audit-table tr.selected td{background:#ffc1070f}.admin-audit-table .admin-audit-time{white-space:nowrap;font-size:.78rem}.admin-audit-table .admin-audit-summary{font-weight:500;min-width:180px}.admin-audit-table .admin-audit-actor{display:block;max-width:220px;word-break:break-word}.admin-audit-table .admin-audit-target{max-width:200px;word-break:break-word}.admin-audit-table .admin-audit-details{font-size:.76rem;max-width:260px;word-break:break-word}.admin-audit-table .admin-audit-code{font-size:.72rem;opacity:.75}.admin-badge.guest{display:inline-block;margin-top:4px;padding:2px 6px;border-radius:999px;font-size:.68rem;background:#ffc10726;color:#ffc107}.admin-actions{display:flex;flex-wrap:wrap;gap:4px;white-space:nowrap}.admin-console .admin-icon-btn{display:inline-grid;place-items:center;width:34px;height:34px;min-width:34px;padding:0}.admin-console .admin-icon-btn.accent{color:var(--accent)}.admin-console .admin-icon-btn.accent:hover{color:#ffe08a;border-color:#ffd05c66;background:#ffd05c14}.admin-console .admin-icon-btn.danger{color:#ff9f94}.admin-console .admin-icon-btn.danger:hover{color:#ffb8b0;border-color:#ff786459}.admin-pager{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px}.admin-smtp-test{margin-top:24px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}.ghost-button.compact.danger{color:#ff8a7a}.legacy-trip .app-header:has(.header-content.has-music-player){width:min(920px,calc(100vw - 32px));align-self:center;padding:78px clamp(34px,5vw,58px) 34px}.legacy-trip .header-content.has-music-player{width:100%;align-items:stretch}.legacy-trip .music-player-card{position:relative;isolation:isolate;display:grid;grid-template-columns:134px minmax(0,1fr);align-items:center;gap:20px;min-width:0;padding:20px 22px;overflow:hidden;color:var(--text-light);border:1px solid rgba(255,255,255,.12);border-radius:26px;background:linear-gradient(135deg,rgba(255,255,255,.05),transparent 60%),#0210126b;box-shadow:inset 0 1px #ffffff14,0 22px 60px #00000047}.legacy-trip .music-player-glow{position:absolute;z-index:-1;inset:-40% -20%;background-position:center;background-size:cover;opacity:.32;filter:blur(46px) saturate(170%);transform:scale(1.1);transition:opacity .6s ease,transform 8s ease-out;pointer-events:none}.legacy-trip .music-player-card.is-playing .music-player-glow{opacity:.5;transform:scale(1.25)}.legacy-trip .music-player-card:after{position:absolute;z-index:-1;inset:0;background:radial-gradient(120% 120% at 18% 30%,transparent,rgba(2,14,16,.55) 100%);content:"";pointer-events:none}.music-player-art,.music-player-body{position:relative;z-index:1;min-width:0}.music-player-art{display:grid;place-items:center}.music-player-body{display:flex;flex-direction:column;align-items:stretch}.music-player-heading{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px}.music-player-kicker{display:inline-flex;align-items:center;gap:7px;color:var(--text-muted);font-size:.65rem;font-weight:700;letter-spacing:.11em;text-transform:uppercase}.music-eq-dot{width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.45}.music-eq{display:inline-flex;align-items:flex-end;gap:2px;height:11px;color:#f4ca64}.music-eq i{width:2.5px;height:100%;border-radius:2px;background:currentColor;transform-origin:bottom;animation:music-eq-bounce .9s ease-in-out infinite}.music-eq i:nth-child(2){animation-duration:1.15s;animation-delay:-.4s}.music-eq i:nth-child(3){animation-duration:.75s;animation-delay:-.2s}.music-eq i:nth-child(4){animation-duration:1.05s;animation-delay:-.6s}@keyframes music-eq-bounce{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}.music-current-title{display:flex;min-width:0;flex-direction:column;overflow:hidden;text-align:left}.music-current-title strong{display:-webkit-box;overflow:hidden;min-height:2.65em;color:var(--text-highlight);font-size:.98rem;line-height:1.3;text-overflow:ellipsis;-webkit-box-orient:vertical;-webkit-line-clamp:2}.music-current-title small{overflow:hidden;margin-top:3px;opacity:.65;font-size:.72rem;text-overflow:ellipsis;white-space:nowrap}.music-transport{display:flex;align-items:center;justify-content:center;gap:10px;margin:14px 0 9px}.music-transport button,.music-modal-head button,.music-playlist-add,.music-playlist-remove,.music-icon-btn{display:inline-grid;width:32px;height:32px;flex:0 0 auto;place-items:center;color:inherit;border:0;border-radius:50%;background:#ffffff14;cursor:pointer}.music-transport button:hover,.music-icon-btn:hover{background:#ffffff2b}.music-player-card .music-transport button{width:34px;height:34px;background:transparent}.music-transport .primary{color:#102023;background:#f4ca64}.music-player-card .music-transport .primary{width:44px;height:44px;box-shadow:0 8px 22px #f4ca6438}.music-mode{position:relative}.music-mode.active{color:#f4ca64;background:#f4ca6424!important}.music-mode b{position:absolute;right:3px;bottom:1px;font-size:8px}.music-progress-wrap{display:flex;flex:1 1 auto;align-items:center;gap:8px;min-width:80px}.music-progress-wrap input,.music-volume input{width:100%;height:18px;margin:0;accent-color:#f4ca64;cursor:pointer}.music-progress-wrap input{-webkit-appearance:none;appearance:none;height:16px;background:transparent}.music-progress-wrap input::-webkit-slider-runnable-track{height:4px;border-radius:4px;background:linear-gradient(90deg,#f4ca64,#f0b94d) 0 / var(--pct, 0%) 100% no-repeat,#ffffff29}.music-progress-wrap input::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;margin-top:-4px;border-radius:50%;background:#fff;box-shadow:0 0 0 4px #f4ca6433,0 1px 4px #0006;cursor:pointer}.music-progress-wrap input::-moz-range-track{height:4px;border-radius:4px;background:#ffffff29}.music-progress-wrap input::-moz-range-progress{height:4px;border-radius:4px;background:linear-gradient(90deg,#f4ca64,#f0b94d)}.music-progress-wrap input::-moz-range-thumb{width:12px;height:12px;border:0;border-radius:50%;background:#fff;box-shadow:0 0 0 4px #f4ca6433;cursor:pointer}.music-progress-wrap span{min-width:30px;font-size:.66rem;opacity:.68}.music-progress-wrap span:last-child{text-align:right}.music-volume{display:flex;width:92px;align-items:center;gap:5px}.music-player-footer{display:flex;align-items:center;justify-content:space-between;padding-top:9px;margin-top:4px;border-top:1px solid rgba(255,255,255,.07)}.music-player-modes{display:flex;gap:3px}.music-player-modes button{display:inline-grid;width:30px;height:30px;place-items:center;color:inherit;border:0;border-radius:9px;background:transparent;cursor:pointer}.music-retry{width:100%;padding:7px 10px;margin-top:8px;color:#ffb2a8;border:1px solid rgba(255,130,115,.2);border-radius:9px;background:#ff827314;font-size:.75rem;cursor:pointer}.music-vinyl-wrap{display:grid;flex:0 0 auto;place-items:center;padding:8px}.music-vinyl{position:relative;display:grid;width:124px;height:124px;place-items:center;overflow:hidden;border:5px solid #070a0a;border-radius:50%;background:repeating-radial-gradient(circle,transparent 0 3px,rgba(255,255,255,.06) 4px 5px),radial-gradient(circle at 32% 28%,#25292a,#0c0f0f 72%);box-shadow:inset 0 0 26px #000,0 16px 38px #0000006b}.music-vinyl:before{position:absolute;z-index:2;inset:0;border-radius:50%;background:conic-gradient(from 210deg,transparent 0deg,rgba(255,255,255,.16) 28deg,transparent 64deg,transparent 200deg,rgba(255,255,255,.08) 232deg,transparent 268deg);content:"";pointer-events:none}.music-vinyl.is-playing{animation:vinyl-spin 4s linear infinite}.legacy-trip .music-player-card.is-playing .music-vinyl{box-shadow:inset 0 0 26px #000,0 16px 38px #0000006b,0 0 0 1px #f4ca6459,0 0 26px #f4ca6452}.music-vinyl-label{width:66%;height:66%;object-fit:cover;border-radius:50%;box-shadow:0 0 0 2px #000000d9,0 0 0 4px #ffffff1f}.music-tonearm{position:absolute;top:2px;right:4px;width:56px;height:56px;z-index:3;transform:rotate(-32deg);transform-origin:top right;transition:transform .7s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.music-tonearm:before{position:absolute;top:0;right:0;width:11px;height:11px;border-radius:50%;background:linear-gradient(135deg,#e9c66a,#9c7d2e);box-shadow:0 1px 4px #00000080;content:""}.music-tonearm:after{position:absolute;top:4px;right:5px;width:3px;height:50px;border-radius:3px;background:linear-gradient(180deg,#cfd3d4,#7d8284);box-shadow:0 2px 5px #00000073;content:"";transform:rotate(34deg);transform-origin:top}.music-tonearm.engaged{transform:rotate(-12deg)}.music-vinyl-center{position:absolute;z-index:3;display:grid;width:34px;height:34px;place-items:center;color:#fff;border:2px solid rgba(255,255,255,.48);border-radius:50%;background:#171a1a;box-shadow:0 2px 9px #00000080;cursor:pointer}.music-vinyl-wrap.compact{padding:0}.music-vinyl-wrap.compact .music-vinyl{width:58px;height:58px;border-width:2px}.music-vinyl-wrap.compact .music-vinyl-center{width:24px;height:24px}@keyframes vinyl-spin{to{transform:rotate(360deg)}}.legacy-trip .music-disc-arc{position:absolute;z-index:2;top:50%;right:96px;width:0;height:0;pointer-events:none}.legacy-trip .music-arc-btn{position:absolute;top:0;left:0;display:grid;width:34px;height:34px;place-items:center;color:#f5f7f7eb;border:0;border-radius:50%;background:#080e0e8c;box-shadow:0 2px 9px #00000073;backdrop-filter:blur(4px);cursor:pointer;pointer-events:auto}.legacy-trip .music-arc-btn:hover{background:#161e1ed9}.legacy-trip .music-arc-btn.active{color:#f4ca64;background:#f4ca6433}.legacy-trip .music-arc-btn b{position:absolute;right:4px;bottom:2px;font-size:8px;font-weight:700}.legacy-trip .music-disc-ring-overlay{position:absolute;top:50%;right:-54px;width:300px;height:300px;transform:translateY(-50%);pointer-events:none}.music-disc-ring{display:block;width:100%;height:100%}.music-disc-ring-track{fill:none;stroke:#ffffff1a;stroke-width:2.5}.music-disc-ring-fill{fill:none;stroke:#f5f7f7f2;stroke-width:2.5;stroke-linecap:round;filter:drop-shadow(0 0 4px rgba(255,255,255,.4));transition:stroke-dashoffset .25s linear}.legacy-trip .music-disc-time{position:absolute;z-index:2;top:50%;right:96px;display:flex;flex-direction:column;align-items:center;line-height:1.05;pointer-events:none;text-shadow:0 1px 4px rgba(0,0,0,.75);transform:translate(50%,-50%) translate(52px,-104px)}.music-disc-time strong{color:#f5f7f7f2;font-size:.8rem;font-weight:700}.music-disc-time span{color:#f5f7f7a6;font-size:.58rem}.legacy-trip .header-content.with-disc{position:relative;align-items:flex-start}.legacy-trip .header-tour-info{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.legacy-trip .header-content.with-disc .header-tour-info{position:relative;align-items:flex-start;text-align:left}.legacy-trip .header-content.with-disc .trip-meta{justify-content:flex-start}.legacy-trip .music-disc-stage{position:absolute;z-index:0;top:50%;right:-54px;width:300px;height:300px;transform:translateY(-50%);pointer-events:none;opacity:.92;-webkit-mask-image:linear-gradient(to right,transparent 0,#000 44%);mask-image:linear-gradient(to right,transparent 0,#000 44%)}.music-disc-spinner{width:100%;height:100%}.music-disc-svg{display:block;width:100%;height:100%}.music-disc-base{fill:#14181a;stroke:#060808;stroke-width:5}.music-disc-groove{fill:none;stroke:#ffffff0f;stroke-width:1}.music-disc-label-ring{fill:none;stroke:#000c;stroke-width:3}.music-disc-hole{fill:#0a0d0d}.legacy-trip .music-disc-controls{position:absolute;top:50%;right:96px;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none;transform:translate(50%,-50%)}.music-disc-play{display:grid;width:54px;height:54px;place-items:center;color:#fff;border:0;border-radius:50%;background:transparent;filter:drop-shadow(0 2px 6px rgba(0,0,0,.65));cursor:pointer;pointer-events:auto;transition:var(--transition-smooth)}.music-disc-play:hover{color:#f4ca64;transform:scale(1.08)}.music-disc-retry{width:auto;margin:0;pointer-events:auto}@media(max-width:760px){.legacy-trip .music-disc-stage{width:230px;height:230px;right:-42px}.legacy-trip .music-disc-controls{right:73px}.legacy-trip .music-disc-arc{right:73px;transform:scale(.82)}.legacy-trip .music-disc-ring-overlay{right:-42px;width:230px;height:230px}.legacy-trip .music-disc-time{right:73px;transform:translate(50%,-50%) translate(40px,-82px)}.music-disc-time strong{font-size:.72rem}.music-disc-play{width:48px;height:48px}.legacy-trip .music-hdr-controls{gap:4px}.legacy-trip .music-hdr-controls .hdr-btn{width:32px;height:32px}}.music-modal-overlay{position:fixed;z-index:12000;inset:0;display:grid;place-items:start center;padding:16px;padding-top:max(16px,env(safe-area-inset-top));padding-right:calc(16px + var(--app-scrollbar, 0px));background:#02080aa8;backdrop-filter:blur(10px)}.music-search-modal{display:flex;width:min(520px,calc(100vw - 32px));max-height:85vh;flex-direction:column;padding:18px;color:#eef7f5;border:1px solid rgba(255,255,255,.16);border-radius:20px;background:#0d1c1ff5;box-shadow:0 26px 80px #0000007a}.music-modal-head{display:flex;align-items:center;justify-content:space-between}.music-modal-head h2{margin:0;font-size:1.3rem}.music-modal-tabs{display:grid;grid-template-columns:1fr 1fr;gap:5px;padding:4px;margin:14px 0;border-radius:12px;background:#ffffff0f}.music-modal-tabs button{padding:9px;color:inherit;border:0;border-radius:9px;background:transparent;cursor:pointer}.music-modal-tabs button.active{color:#172224;background:#f4ca64;font-weight:700}.music-search-input{display:flex;align-items:center;gap:9px;padding:0 12px;border:1px solid rgba(255,255,255,.16);border-radius:12px;background:#ffffff12}.music-search-input input{width:100%;padding:12px 0;color:#eef7f5;-webkit-text-fill-color:#eef7f5;border:0;outline:0;background:transparent}.music-search-input input::placeholder{color:#eef7f58c}.music-results{min-height:100px;overflow-y:auto;margin-top:12px;overscroll-behavior:contain}.music-results.playlist{margin-top:0}.music-result-row{display:flex;align-items:center;gap:11px;padding:9px;border-radius:11px;cursor:pointer}.music-result-row:hover,.music-result-row:focus{outline:none;background:#ffffff0f}.music-result-row.is-playing{background:#f4ca6421}.music-result-row>img,.music-thumb-empty{width:80px;height:56px;flex:0 0 auto;object-fit:cover;border-radius:8px;background:#ffffff14}.music-thumb-empty{display:grid;place-items:center;font-size:1.4rem}.music-result-info{display:flex;min-width:0;flex:1;flex-direction:column}.music-result-info strong{display:-webkit-box;overflow:hidden;font-size:.9rem;-webkit-box-orient:vertical;-webkit-line-clamp:2}.music-result-info>span{overflow:hidden;opacity:.62;font-size:.78rem;text-overflow:ellipsis;white-space:nowrap}.music-result-info small{display:flex;gap:14px;margin-top:4px;opacity:.68}.music-result-info small span{display:flex;align-items:center;gap:3px}.music-playlist-add.saved{color:#75d49b;cursor:default}.music-playlist-remove{color:#ff9c92}.music-empty,.music-error{padding:25px 12px;margin:0;text-align:center;opacity:.68}.music-error{color:#ffaaa0;opacity:1}.music-load-more{align-self:center;padding:8px 16px;margin-top:10px;color:inherit;border:1px solid rgba(255,255,255,.15);border-radius:10px;background:#ffffff0f;cursor:pointer}.music-toast{position:fixed;z-index:13000;right:18px;bottom:calc(82px + env(safe-area-inset-bottom));max-width:min(360px,calc(100vw - 36px));padding:11px 15px;color:#102023;border-radius:12px;background:#f4ca64;box-shadow:0 12px 30px #0000004d;font-weight:650}.music-sticky-mini-bar{position:fixed;z-index:9000;top:0;left:50%;display:flex;width:min(760px,calc(100% - 20px));min-height:54px;align-items:center;gap:9px;padding:calc(7px + env(safe-area-inset-top)) 10px 7px;color:#eef7f5;border:1px solid rgba(255,255,255,.16);border-top:0;border-radius:0 0 16px 16px;background:#0b1a1df0;box-shadow:0 10px 30px #00000047;backdrop-filter:blur(18px);transform:translate(-50%);animation:music-mini-in .18s ease-out}@keyframes music-mini-in{0%{opacity:0;transform:translate(-50%,-12px)}}.music-sticky-mini-bar>img{width:38px;height:38px;object-fit:cover;border-radius:8px}.music-mini-title{display:flex;min-width:80px;flex:0 1 210px;flex-direction:column;overflow:hidden;color:inherit;text-align:left;border:0;background:none;cursor:pointer}.music-mini-title strong,.music-mini-title span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.music-mini-title span{opacity:.6;font-size:.7rem}.map-overlay-bottom-left{position:absolute;z-index:850;right:12px;bottom:12px;left:12px;display:flex;flex-direction:column;align-items:flex-start;gap:8px;pointer-events:none}.map-overlay-bottom-left .dist-badges--map-overlay{position:static!important;max-width:100%;pointer-events:auto}.music-map-dock{display:flex;width:min(420px,calc(100vw - 30px));flex-direction:column;gap:6px;padding:8px 13px 9px;color:#eef7f5;border:1px solid rgba(255,255,255,.18);border-radius:16px;background:linear-gradient(110deg,#071518f5,#13292cd1);box-shadow:0 16px 40px #00000061;backdrop-filter:blur(16px);pointer-events:auto;cursor:grab;touch-action:none}.music-map-dock.is-floating{position:fixed;z-index:30;margin:0}.music-map-dock.is-dragging{cursor:grabbing;user-select:none;box-shadow:0 22px 54px #00000080}.music-map-dock button{cursor:pointer}.music-map-dock input[type=range]{touch-action:auto}.music-map-dock-head{display:flex;align-items:center;gap:10px}.music-map-dock .music-vinyl-wrap.compact .music-vinyl{width:44px;height:44px}.music-map-dock .music-vinyl-wrap.compact .music-vinyl-center{width:20px;height:20px}.music-map-dock-title{display:flex;min-width:0;flex:1;flex-direction:column;text-align:left}.music-map-dock-title strong{overflow:hidden;font-size:.86rem;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.music-map-dock-title span{overflow:hidden;margin-top:1px;opacity:.62;font-size:.7rem;text-overflow:ellipsis;white-space:nowrap}.music-map-dock-progress{width:100%}.music-map-dock-controls{display:flex;align-items:center;justify-content:center;gap:8px}.music-dock-btn{position:relative;display:inline-grid;width:32px;height:32px;place-items:center;color:inherit;border:0;border-radius:50%;background:#ffffff14;cursor:pointer;transition:background .15s ease}.music-dock-btn:hover{background:#ffffff29}.music-dock-btn.play{width:40px;height:40px;color:#102023;background:#f4ca64;box-shadow:0 6px 18px #f4ca644d}.music-dock-btn.play:hover{background:#f0b94d}.music-dock-btn.active{color:#f4ca64;background:#f4ca6429}.music-dock-btn b{position:absolute;right:5px;bottom:3px;font-size:8px;font-weight:700}.legacy-trip.light-mode .music-player-card{color:#142426;border-color:#0913151a;background:radial-gradient(circle at 12% 20%,rgba(212,175,55,.12),transparent 38%),#ffffff8f;box-shadow:inset 0 1px #ffffffb3,0 18px 45px #2d4c3d17}.legacy-trip.light-mode .music-player-card:after{background:radial-gradient(120% 120% at 18% 30%,transparent,rgba(255,255,255,.62) 100%)}.legacy-trip.light-mode .music-player-glow{opacity:.24;mix-blend-mode:multiply}.legacy-trip.light-mode .music-player-card.is-playing .music-player-glow{opacity:.36}.legacy-trip.light-mode .music-player-footer{border-color:#09131514}.legacy-trip.light-mode .music-vinyl{border-color:#4d5252;background:repeating-radial-gradient(circle,transparent 0 4px,rgba(255,255,255,.13) 5px 6px),#303636}.legacy-trip.light-mode .music-sticky-mini-bar,.legacy-trip.light-mode.map-fullscreen-portal .music-map-dock,.map-stage.light-mode .music-map-dock{color:#142426;border-color:#0913151f;background:#f9fcfaf2}.legacy-trip.light-mode.map-fullscreen-portal .music-dock-btn:not(.play):not(.active),.map-stage.light-mode .music-dock-btn:not(.play):not(.active){background:#0913150f}.legacy-trip.light-mode.map-fullscreen-portal .music-dock-btn:not(.play):not(.active):hover,.map-stage.light-mode .music-dock-btn:not(.play):not(.active):hover{background:#0913151f}.legacy-trip.light-mode .music-search-modal{color:#142426;border-color:#0913151f;background:#fafcfaf7}.legacy-trip.light-mode .music-search-input,.legacy-trip.light-mode .music-modal-tabs{border-color:#0913151f;background:#0913150a}.legacy-trip.light-mode .music-search-input input{color:#142426;-webkit-text-fill-color:#142426}.legacy-trip.light-mode .music-search-input input::placeholder{color:#09131580}.legacy-trip.light-mode .music-result-row:hover,.legacy-trip.light-mode .music-result-row:focus{background:#0913150a}@media(max-width:760px){.legacy-trip .app-header:has(.header-content.has-music-player){width:100%;padding:68px 18px 22px}.legacy-trip .header-content.has-music-player{width:100%}.legacy-trip .header-main-row{grid-template-columns:minmax(0,1fr);gap:18px}.legacy-trip .music-player-card{grid-template-columns:82px minmax(0,1fr);gap:14px;width:min(460px,100%);padding:14px 15px;justify-self:center}.music-current-title strong{min-height:auto;display:block;white-space:nowrap}.music-tonearm{display:none}.music-player-card .music-vinyl{width:78px;height:78px}.music-player-card .music-vinyl-center{width:30px;height:30px}.music-player-card .music-transport{position:absolute;top:27px;right:0;gap:2px;margin:0}.music-player-card .music-transport button{width:30px;height:30px}.music-player-card .music-transport .primary{width:36px;height:36px}.music-player-card .music-current-title{padding-right:108px}.music-card-progress{margin-top:15px}.music-player-footer{padding-top:7px}.music-player-heading .music-playlist-add{margin-right:2px}.music-sticky-mini-bar .music-progress-wrap{display:none}}@media(max-width:480px){.music-search-modal{width:calc(100vw - 16px);max-height:88vh;padding:14px}.music-result-row>img,.music-thumb-empty{width:66px;height:48px}.music-sticky-mini-bar{width:100%;border-radius:0 0 13px 13px}.music-sticky-mini-bar>img{display:none}.music-mini-title{flex:1 1 auto}.music-map-dock{width:min(360px,calc(100vw - 24px))}.legacy-trip .music-player-card{grid-template-columns:68px minmax(0,1fr);gap:11px;padding:12px;border-radius:18px}.music-player-card .music-vinyl{width:64px;height:64px}.music-player-card .music-vinyl-center{width:27px;height:27px}.music-player-card .music-current-title{padding-right:93px}.music-player-card .music-transport{top:25px}.music-player-card .music-transport button{width:27px;height:27px}.music-player-card .music-transport .primary{width:32px;height:32px}.music-player-kicker{font-size:.58rem}.music-current-title strong{font-size:.84rem}.music-current-title small{font-size:.65rem}.music-player-footer .music-volume{width:78px}}@media(prefers-reduced-motion:reduce){.music-vinyl.is-playing,.music-eq i,.music-sticky-mini-bar{animation:none!important}.music-tonearm,.music-player-glow{transition:none!important}}
