*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,SF Pro Display,system-ui,sans-serif;font-size:13px;line-height:1.5;color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"kern" 1,"liga" 1;text-rendering:optimizeLegibility}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes springIn{0%{opacity:0;transform:scale(.88)}60%{opacity:1;transform:scale(1.03)}to{opacity:1;transform:scale(1)}}@keyframes popIn{0%{opacity:0;transform:scale(.9)}70%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulseGlow{0%,to{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 40%,transparent)}50%{box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 0%,transparent)}}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--text-secondary) 25%,transparent);border-radius:4px;border:1px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--text-secondary) 45%,transparent);background-clip:padding-box}::-webkit-scrollbar-corner{background:transparent}*{scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--text-secondary) 25%,transparent) transparent}:focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 50%,transparent);outline-offset:2px;border-radius:6px}::selection{background:color-mix(in srgb,var(--accent) 25%,transparent);color:var(--text-primary)}.frosted{background:color-mix(in srgb,var(--surface-elevated) 72%,transparent);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%)}.frosted-thin{background:color-mix(in srgb,var(--surface-elevated) 50%,transparent);-webkit-backdrop-filter:blur(10px) saturate(160%);backdrop-filter:blur(10px) saturate(160%)}.frosted-ultra{background:color-mix(in srgb,var(--surface-elevated) 85%,transparent);-webkit-backdrop-filter:blur(30px) saturate(200%);backdrop-filter:blur(30px) saturate(200%)}:root{--shadow-subtle:0 0.5px 1px rgba(0,0,0,0.04),0 1px 2px rgba(0,0,0,0.04);--shadow-section:0 0.5px 0 0 color-mix(in srgb,var(--text-secondary) 6%,transparent),0 1px 3px rgba(0,0,0,0.06),0 4px 8px rgba(0,0,0,0.05);--shadow-subsection:0 0.5px 0 0 color-mix(in srgb,var(--text-secondary) 5%,transparent),0 1px 2px rgba(0,0,0,0.06);--shadow-card:0 0.5px 0 0 color-mix(in srgb,var(--text-secondary) 4%,transparent),0 1px 3px rgba(0,0,0,0.06),0 2px 6px rgba(0,0,0,0.04);--shadow-floating:0 1px 2px rgba(0,0,0,0.06),0 4px 12px rgba(0,0,0,0.08);--shadow-popover:0 0 0 0.5px color-mix(in srgb,var(--divider) 50%,transparent),0 4px 16px rgba(0,0,0,0.12),0 8px 32px rgba(0,0,0,0.08);--shadow-modal:0 0 0 0.5px color-mix(in srgb,var(--divider) 50%,transparent),0 8px 32px rgba(0,0,0,0.2),0 2px 8px rgba(0,0,0,0.1)}.focus-ring:focus-visible{box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 40%,transparent);outline:none}.transition-all{transition:all .25s ease}.page-enter{animation:pageEnter .3s cubic-bezier(.25,.46,.45,.94) both}.section-panel{padding:16px;background:var(--surface-elevated);border:.5px solid color-mix(in srgb,var(--text-secondary) 8%,transparent);border-radius:12px;box-shadow:0 .5px 0 0 color-mix(in srgb,var(--text-secondary) 8%,transparent),0 1px 4px rgba(0,0,0,.06),0 4px 12px rgba(0,0,0,.06);transition:box-shadow .2s cubic-bezier(.25,.46,.45,.94)}.section-panel:hover{box-shadow:0 .5px 0 0 color-mix(in srgb,var(--text-secondary) 10%,transparent),0 2px 8px rgba(0,0,0,.09),0 6px 20px rgba(0,0,0,.08)}.subsection-panel{padding:12px;background:color-mix(in srgb,var(--surface) 80%,var(--surface-elevated));border:.5px solid color-mix(in srgb,var(--text-secondary) 6%,transparent);border-radius:10px;box-shadow:0 .5px 0 0 color-mix(in srgb,var(--text-secondary) 6%,transparent),0 1px 3px rgba(0,0,0,.05)}.trip-row-card{padding:8px 12px;background:var(--surface-elevated);border-radius:10px;border:.5px solid color-mix(in srgb,var(--text-secondary) 10%,transparent);box-shadow:0 .5px 0 0 color-mix(in srgb,var(--text-secondary) 6%,transparent),0 1px 3px rgba(0,0,0,.06),0 3px 8px rgba(0,0,0,.05);transition:background .2s cubic-bezier(.25,.46,.45,.94),box-shadow .2s cubic-bezier(.25,.46,.45,.94),transform .2s cubic-bezier(.25,.46,.45,.94)}.trip-row-card:hover{box-shadow:0 .5px 0 0 color-mix(in srgb,var(--text-secondary) 8%,transparent),0 2px 6px rgba(0,0,0,.1),0 6px 16px rgba(0,0,0,.08);transform:translateY(-.5px)}.trip-row-card.selected{background:color-mix(in srgb,var(--accent) 8%,var(--surface-elevated));border-color:color-mix(in srgb,var(--accent) 25%,transparent)}.travel-row-card{padding:8px 12px;border-radius:10px;box-shadow:0 1px 2px rgba(0,0,0,.06)}.floating-bar{padding:5px 10px;border-radius:9999px;border:.5px solid color-mix(in srgb,var(--divider) 80%,transparent)}.floating-bar,.floating-panel{background:color-mix(in srgb,var(--surface-elevated) 88%,transparent);backdrop-filter:blur(40px) saturate(190%);-webkit-backdrop-filter:blur(40px) saturate(190%);box-shadow:0 1px 2px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.1)}.floating-panel{padding:8px 14px;border-radius:12px;border:.5px solid color-mix(in srgb,var(--divider) 80%,transparent)}.icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--accent);cursor:pointer;border-radius:6px;transition:background .15s cubic-bezier(.25,.46,.45,.94),transform .1s cubic-bezier(.25,.46,.45,.94)}.icon-btn:hover{background:color-mix(in srgb,var(--text-primary) 8%,transparent)}.icon-btn:active{transform:scale(.92);background:color-mix(in srgb,var(--text-primary) 14%,transparent)}.icon-btn:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 40%,transparent)}.icon-btn.destructive{color:var(--destructive)}.icon-btn.destructive:hover{background:color-mix(in srgb,var(--destructive) 10%,transparent)}.icon-btn.destructive:active{background:color-mix(in srgb,var(--destructive) 18%,transparent)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:500;border-radius:9999px;line-height:1.4;letter-spacing:.01em}.badge.accent{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent)}.badge.success{background:color-mix(in srgb,var(--success) 12%,transparent);color:var(--success)}.badge.warning{background:color-mix(in srgb,var(--warning) 12%,transparent);color:var(--warning)}.badge.destructive{background:color-mix(in srgb,var(--destructive) 12%,transparent);color:var(--destructive)}.badge.muted{background:color-mix(in srgb,var(--text-secondary) 10%,transparent)}.badge.muted,.detail-chip{color:var(--text-secondary)}.detail-chip{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;font-size:11px;font-weight:500;border-radius:9999px;background:color-mix(in srgb,var(--surface) 70%,transparent);white-space:nowrap}.sidebar{width:240px;min-width:200px;max-width:320px;background:var(--sidebar-bg);border-radius:14px;border:.5px solid color-mix(in srgb,var(--divider) 60%,transparent);box-shadow:0 1px 3px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.06);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;flex-shrink:0}.collapsible{overflow:hidden;transition:max-height .3s cubic-bezier(.25,.46,.45,.94),opacity .3s cubic-bezier(.25,.46,.45,.94)}.drop-indicator{left:0;right:0;height:2px;pointer-events:none;border-radius:1px}.drop-indicator,.drop-indicator:before{position:absolute;background:var(--accent)}.drop-indicator:before{content:"";left:-3px;top:-3px;width:8px;height:8px;border-radius:50%}.visited-toggle{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--text-secondary);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.25,.46,.45,.94);flex-shrink:0}.visited-toggle:hover{border-color:var(--success);background:color-mix(in srgb,var(--success) 8%,transparent)}.visited-toggle.visited{border-color:var(--success);background:var(--success);color:white;animation:popIn .25s cubic-bezier(.175,.885,.32,1.275)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:48px 24px;color:var(--text-secondary);text-align:center;animation:fadeIn .4s ease}dialog{border:none;border-radius:14px;padding:0;background:var(--surface-elevated);color:var(--text-primary);box-shadow:0 0 0 .5px color-mix(in srgb,var(--divider) 50%,transparent),0 8px 32px rgba(0,0,0,.2),0 2px 8px rgba(0,0,0,.1);max-width:480px;width:90vw;animation:scaleIn .25s cubic-bezier(.25,.46,.45,.94)}dialog::-webkit-backdrop{background:rgba(0,0,0,.35);backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%);animation:fadeIn .2s ease}dialog::backdrop{background:rgba(0,0,0,.35);backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%);animation:fadeIn .2s ease}.split-divider{width:1px;background:var(--divider);position:relative;flex-shrink:0;cursor:col-resize;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .15s ease;z-index:5}.split-divider:before{content:"";position:absolute;top:0;bottom:0;left:-4px;right:-4px}.split-divider.dragging,.split-divider:hover{background:var(--accent)}.split-divider.dragging:after,.split-divider:hover:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:4px;height:32px;border-radius:2px;background:var(--accent);opacity:.6}.tab-bar-container{position:relative}.tab-bar-container::-webkit-scrollbar{display:none}.tab-link{position:relative;z-index:1}.tab-link:not(.tab-active):hover{color:var(--text-primary)!important;background:color-mix(in srgb,var(--text-primary) 6%,transparent)}.tab-pill-indicator{position:absolute;height:calc(100% - 8px);top:4px;border-radius:8px;background:var(--accent);transition:left .35s cubic-bezier(.175,.885,.32,1.275),width .25s cubic-bezier(.25,.46,.45,.94);z-index:0;box-shadow:0 1px 3px rgba(0,0,0,.12)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:none;border-radius:8px;background:var(--accent);color:var(--on-accent);font-size:13px;font-weight:600;cursor:pointer;transition:filter .15s ease,transform .1s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.btn-primary:hover{filter:brightness(.92)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:.5px solid var(--divider);border-radius:8px;background:transparent;color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s ease,transform .1s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.btn-secondary:hover{background:color-mix(in srgb,var(--surface-elevated) 50%,transparent)}.btn-secondary:active{transform:scale(.97)}.input-field{width:100%;padding:8px 12px;border:1px solid var(--divider);border-radius:8px;font-size:13px;background:var(--bg);color:var(--text-primary);outline:none;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.input-field:focus,.input-field:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 25%,transparent);outline:none}.input-field::placeholder{color:var(--text-secondary);opacity:.6}.subtask-add-input::placeholder{color:var(--text-secondary);opacity:.5}.segmented-control{display:inline-flex;gap:1px;padding:2px;background:color-mix(in srgb,var(--surface) 60%,transparent);border-radius:10px;position:relative}.segmented-control-item{position:relative;z-index:1;padding:5px 14px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:color .15s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.segmented-control-item.active{color:var(--text-primary);font-weight:600;background:var(--surface-elevated);box-shadow:0 1px 3px rgba(0,0,0,.08)}.segmented-control-item:not(.active):hover{color:var(--text-primary)}.trip-map-panel{isolation:isolate}@media (max-width:768px){.sidebar{display:none}.app-sidebar-expanded{position:fixed!important;top:10px;left:10px;bottom:10px;z-index:50;box-shadow:8px 0 32px rgba(0,0,0,.15);border-radius:14px;overflow:hidden}.app-sidebar-backdrop{display:block!important}.page-padded{padding:16px!important}.page-header{flex-wrap:wrap;gap:8px!important}.filter-pill-row{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;padding-bottom:2px;scrollbar-width:none}.filter-pill-row::-webkit-scrollbar{display:none}.scroll-x-mobile{overflow-x:auto;-webkit-overflow-scrolling:touch}.goals-grid{grid-template-columns:1fr!important}.settings-row{flex-direction:column!important;align-items:flex-start!important;gap:8px!important}.settings-row-label{flex:none!important;width:100%!important}.settings-row-value{min-width:unset!important;width:60px!important;text-align:left!important}.stats-strip{display:grid!important;grid-template-columns:1fr 1fr!important}.icon-btn{min-width:44px;min-height:44px}.time-sink-bars{overflow-x:auto;-webkit-overflow-scrolling:touch}.detail-panel-overlay{top:0!important;right:0!important;bottom:0!important;left:0!important;width:100%!important;max-width:100%!important;border-radius:0!important}.timeline-grid-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.trips-header-controls{flex-wrap:wrap}.trips-header-auth{display:none!important}}@media (max-width:480px){.tab-label{display:none}.tab-link{padding:4px 8px!important}.page-padded{padding:12px!important}.pomodoro-ring{transform:scale(.85);transform-origin:center top}.timeline-anchor-label{min-width:100px!important;font-size:12px!important}}.page-transition-enter{animation:slideInUp .3s cubic-bezier(.25,.46,.45,.94)}.gantt-bar{border-radius:6px;cursor:pointer;transition:filter .15s ease,box-shadow .15s ease}.gantt-bar:hover{filter:brightness(1.1);box-shadow:0 2px 8px rgba(0,0,0,.15)}.calendar-hour-cell{border-bottom:.5px solid var(--divider);transition:background .1s ease}.calendar-hour-cell:hover{background:color-mix(in srgb,var(--accent) 4%,transparent)}.tooltip{position:absolute;padding:4px 10px;background:color-mix(in srgb,var(--surface-elevated) 92%,transparent);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:6px;border:.5px solid color-mix(in srgb,var(--divider) 50%,transparent);box-shadow:0 2px 8px rgba(0,0,0,.12);font-size:11px;font-weight:500;color:var(--text-primary);white-space:nowrap;pointer-events:none;z-index:1000;animation:fadeIn .15s ease}.skeleton{background:linear-gradient(90deg,color-mix(in srgb,var(--text-secondary) 6%,transparent) 25%,color-mix(in srgb,var(--text-secondary) 12%,transparent) 50%,color-mix(in srgb,var(--text-secondary) 6%,transparent) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:6px}.skeleton-text{height:12px;width:60%}.skeleton-text-short{height:12px;width:35%}.skeleton-title{height:18px;width:40%}.skeleton-row{display:flex;align-items:center;gap:12px;padding:8px 16px}.skeleton-circle{width:20px;height:20px;border-radius:50%;flex-shrink:0}