:root,[data-theme=dark]{--bg-primary: #0B1220;--bg-secondary: #121A2B;--bg-tertiary: #182235;--bg-elevated: #1F2A40;--blue-400: #60A5FA;--blue-500: #2563EB;--blue-600: #1D4ED8;--blue-700: #1E40AF;--text-primary: #F1F5F9;--text-secondary: #CBD5E1;--text-muted: #94A3B8;--text-disabled: #64748B;--border-primary: #243044;--border-muted: #1B2435;--border-focus: rgba(37, 99, 235, .4);--success: #22C55E;--success-muted: rgba(34, 197, 94, .15);--warning: #F59E0B;--warning-muted: rgba(245, 158, 11, .15);--error: #EF4444;--error-muted: rgba(239, 68, 68, .15);--info: #0EA5E9;--info-muted: rgba(14, 165, 233, .15);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--shadow-elevated: 0 20px 25px rgba(0, 0, 0, .5);--focus-ring: 0 0 0 3px var(--border-focus)}[data-theme=light]{--bg-primary: #F8FAFC;--bg-secondary: #FFFFFF;--bg-tertiary: #F1F5F9;--bg-elevated: #FFFFFF;--blue-400: #60A5FA;--blue-500: #2563EB;--blue-600: #1D4ED8;--blue-700: #1E40AF;--text-primary: #0F172A;--text-secondary: #334155;--text-tertiary: #64748B;--text-muted: #64748B;--text-disabled: #94A3B8;--text-inverse: #FFFFFF;--border-primary: #E2E8F0;--border-secondary: #CBD5E1;--border-muted: #F1F5F9;--border-focus: rgba(37, 99, 235, .4);--success: #22C55E;--success-muted: rgba(34, 197, 94, .1);--warning: #F59E0B;--warning-muted: rgba(245, 158, 11, .1);--error: #EF4444;--error-muted: rgba(239, 68, 68, .1);--info: #0EA5E9;--info-muted: rgba(14, 165, 233, .1);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-elevated: 0 20px 25px rgba(0, 0, 0, .15);--focus-ring: 0 0 0 3px var(--border-focus);--input-bg: rgba(0, 0, 0, .04);--blue-500-alpha: rgba(37, 99, 235, .1);--warning-alpha: rgba(245, 158, 11, .1);--error-alpha: rgba(239, 68, 68, .1);--overlay-bg: rgba(0, 0, 0, .5)}:root{--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-14: 56px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--success-hover: #16A34A;--error-hover: #DC2626;--blue-500-alpha: rgba(37, 99, 235, .15);--warning-alpha: rgba(245, 158, 11, .15);--error-alpha: rgba(239, 68, 68, .15);--overlay-bg: rgba(0, 0, 0, .7);--input-bg: rgba(255, 255, 255, .08);--text-tertiary: #888;--text-inverse: #FFFFFF;--border-secondary: #3a3a5a}[data-palette=sunset][data-theme=dark]{--blue-400: #FF9F43;--blue-500: #FF6B4A;--blue-600: #E85D3A;--blue-700: #CC4B2C;--blue-500-alpha: rgba(255, 107, 74, .15);--border-focus: rgba(255, 107, 74, .4);--bg-primary: #12100E;--bg-secondary: #1A1613;--bg-tertiary: #231E19;--bg-elevated: #2B2520;--border-primary: #3A302A;--border-muted: #251F1A;--text-muted: #A89080;--success: #4ADE80}[data-palette=sunset][data-theme=light]{--blue-400: #FF9F43;--blue-500: #FF6B4A;--blue-600: #E85D3A;--blue-700: #CC4B2C;--blue-500-alpha: rgba(255, 107, 74, .1);--border-focus: rgba(255, 107, 74, .4);--bg-primary: #FFFAF7;--bg-secondary: #FFFFFF;--bg-tertiary: #FFF5EE;--bg-elevated: #FFFFFF;--border-primary: #F0DDD0;--border-muted: #FFF0E6}[data-palette=ocean][data-theme=dark]{--blue-400: #2DD4BF;--blue-500: #14B8A6;--blue-600: #0D9488;--blue-700: #0F766E;--blue-500-alpha: rgba(20, 184, 166, .15);--border-focus: rgba(20, 184, 166, .4);--bg-primary: #0A1214;--bg-secondary: #0F1A1D;--bg-tertiary: #152226;--bg-elevated: #1B2B30;--border-primary: #1E3A3F;--border-muted: #152528;--text-muted: #7FB8B0;--success: #4ADE80}[data-palette=ocean][data-theme=light]{--blue-400: #2DD4BF;--blue-500: #14B8A6;--blue-600: #0D9488;--blue-700: #0F766E;--blue-500-alpha: rgba(20, 184, 166, .1);--border-focus: rgba(20, 184, 166, .4);--bg-primary: #F5FFFE;--bg-secondary: #FFFFFF;--bg-tertiary: #ECFDF9;--bg-elevated: #FFFFFF;--border-primary: #CCF0EB;--border-muted: #E6FAF6}[data-palette=violet][data-theme=dark]{--blue-400: #A78BFA;--blue-500: #8B5CF6;--blue-600: #7C3AED;--blue-700: #6D28D9;--blue-500-alpha: rgba(139, 92, 246, .15);--border-focus: rgba(139, 92, 246, .4);--bg-primary: #0C0A14;--bg-secondary: #13101E;--bg-tertiary: #1A1628;--bg-elevated: #221D33;--border-primary: #2E2844;--border-muted: #1A1530;--text-muted: #9B8EC0;--success: #4ADE80}[data-palette=violet][data-theme=light]{--blue-400: #A78BFA;--blue-500: #8B5CF6;--blue-600: #7C3AED;--blue-700: #6D28D9;--blue-500-alpha: rgba(139, 92, 246, .1);--border-focus: rgba(139, 92, 246, .4);--bg-primary: #FAFAFF;--bg-secondary: #FFFFFF;--bg-tertiary: #F3F0FF;--bg-elevated: #FFFFFF;--border-primary: #E0D8F0;--border-muted: #F0ECFF}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);font-size:var(--font-size-base);background:var(--bg-primary);color:var(--text-primary);height:100vh;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body.landing-visible{background:transparent;overflow:auto;height:auto}.tooltip{position:fixed;background:var(--bg-elevated, #1a1a2e);color:var(--text-primary, #fff);font-size:var(--font-size-xs);font-weight:var(--font-normal);padding:4px 8px;border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;z-index:10000;border:1px solid var(--border-primary, #2a2a4a);display:none}.tooltip.visible{display:block}#app{display:grid;grid-template-columns:340px 1fr;grid-template-rows:auto auto 1fr;grid-template-areas:"header header" "topmenu topmenu" "sidebar map";height:100vh}#header{grid-area:header;background:var(--bg-secondary);padding:var(--space-3) var(--space-6);border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between}#header h1{font-size:var(--font-size-xl);color:var(--text-primary);font-weight:var(--font-bold);margin:0}.theme-toggle-btn{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);width:28px;height:28px;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);margin-right:auto;margin-left:var(--space-4);flex-shrink:0}.theme-toggle-btn:hover{background:var(--bg-elevated);border-color:var(--blue-500)}.theme-icon-dark,.theme-icon-light{font-size:.9rem;line-height:1}[data-theme=dark] .theme-icon-dark{display:block}[data-theme=light] .theme-icon-light{display:block}#header #dev-tools{position:relative}#top-menu{grid-area:topmenu;background:var(--bg-secondary);display:flex;align-items:center;border-bottom:1px solid var(--border-primary);height:48px}#top-menu-left{width:340px;padding:0 var(--space-3);display:flex;align-items:center;gap:var(--space-2);position:relative;flex-shrink:0;box-sizing:border-box;overflow:visible}.icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition-base);font-size:14px;flex-shrink:0}.icon-btn:hover{background:var(--bg-elevated);border-color:var(--blue-500);color:var(--blue-500)}.icon-btn.danger:hover{border-color:var(--error);color:var(--error)}.icon-btn:focus{outline:none;box-shadow:var(--focus-ring)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.icon-btn svg{flex-shrink:0}.top-menu-divider{width:1px;height:100%;background:var(--border-primary);flex-shrink:0}#top-menu-right{flex:1;display:flex;align-items:center;gap:var(--space-5);padding:0 var(--space-4)}.top-menu-spacer{flex:1}#trip-selector-btn{display:flex;align-items:center;gap:var(--space-2);background:transparent;border:none;border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:var(--font-medium);cursor:pointer;transition:var(--transition-base);flex:1;min-width:0}#trip-selector-btn:hover{background:var(--bg-tertiary)}#trip-selector-btn.disabled{opacity:.4;pointer-events:none}#trip-selector-btn:focus{outline:none}#current-trip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.trip-selector-meta{display:flex;align-items:center;gap:var(--space-2);margin-left:auto;font-size:var(--font-size-xs);color:var(--text-muted);font-weight:var(--font-normal);white-space:nowrap;flex-shrink:0}.dropdown-arrow{font-size:var(--font-size-xs);opacity:.7;transition:transform var(--transition-base);flex-shrink:0}#trip-selector-btn.open .dropdown-arrow{transform:rotate(180deg)}#trip-menu{position:absolute;top:100%;left:var(--space-3);background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-lg);min-width:280px;max-width:340px;box-shadow:var(--shadow-elevated);z-index:200;overflow:hidden;margin-top:var(--space-1)}#trip-menu.hidden{display:none}#trip-menu-current{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-primary)}.trip-menu-current-name{font-size:var(--font-size-sm);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trip-menu-current-actions{display:flex;gap:var(--space-2)}.trip-menu-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.trip-menu-action-btn:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--blue-500)}.trip-menu-action-btn.danger:hover{border-color:var(--error);color:var(--error)}#trip-menu-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4);background:var(--bg-tertiary)}#trip-menu-header h3{font-size:var(--font-size-xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}#trip-menu-footer{padding:var(--space-3);border-top:1px solid var(--border-primary)}.trip-action-btn.full-width{width:100%;text-align:center}.trip-action-btn{background:var(--blue-500);border:none;border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-medium);cursor:pointer;transition:background var(--transition-fast)}.trip-action-btn:hover{background:var(--blue-600)}.trip-action-btn:focus{outline:none;box-shadow:var(--focus-ring)}#trip-list{max-height:280px;overflow-y:auto}#trip-list:empty{display:none}.trip-list-empty{padding:var(--space-6) var(--space-4);text-align:center;color:var(--text-muted);font-size:var(--font-size-sm)}.trip-item-current{font-size:var(--font-size-xs);color:var(--blue-400);font-weight:var(--font-normal);margin-left:var(--space-1)}.trip-item{display:flex;align-items:center;padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-muted)}.trip-item:last-child{border-bottom:none}.trip-item:hover{background:var(--bg-tertiary)}.trip-item.active{background:var(--info-muted);border-left:3px solid var(--blue-500);cursor:default}.trip-item.active:hover{background:var(--info-muted)}.trip-item-info{flex:1;min-width:0}.trip-item-name{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:var(--font-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trip-item-meta{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:2px}#sidebar{grid-area:sidebar;background:var(--bg-secondary);padding:var(--space-4);overflow-y:auto;border-right:1px solid var(--border-primary);display:flex;flex-direction:column;gap:var(--space-4)}#no-trip-message{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-8) var(--space-5);flex:1}#no-trip-message .no-trip-icon{font-size:3rem;margin-bottom:var(--space-3);opacity:.7}#no-trip-message .no-trip-text{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}#no-trip-message .no-trip-hint{font-size:var(--font-size-sm);color:var(--text-tertiary);line-height:1.5;max-width:200px}#no-trip-message .no-trip-hint strong{color:var(--blue-500)}#no-trip-message.hidden{display:none}#upload-section{position:relative;flex-shrink:0}#upload-section.hidden{display:none}#upload-label{display:flex;align-items:center;justify-content:center;padding:var(--space-3) var(--space-5);border:2px dashed var(--border-secondary);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-base);color:var(--text-tertiary);transition:all var(--transition-fast);white-space:nowrap;text-align:center}#upload-label:hover{border-color:var(--blue-500);color:var(--text-primary);background:var(--blue-500-alpha)}#upload-label.dragover{border-color:var(--blue-500);background:var(--blue-500-alpha)}#upload-label.uploading{border-color:var(--blue-500);color:var(--blue-400);background:var(--blue-500-alpha);animation:pulse-upload 1.5s ease-in-out infinite}@keyframes pulse-upload{0%,to{opacity:1}50%{opacity:.7}}#gps-help-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;background:var(--warning-alpha);border:1px solid var(--warning);color:var(--warning);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:5}#gps-help-btn:hover{background:var(--warning);color:var(--bg-primary);transform:scale(1.1)}#gps-help-btn.hidden{display:none}.gps-help-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.gps-help-content{background:var(--bg-elevated);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);padding:var(--space-6);max-width:480px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.gps-help-content h3{color:var(--warning);font-size:1.2rem;margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.gps-help-content h4{color:var(--blue-500);font-size:var(--font-size-base);margin:var(--space-4) 0 var(--space-2) 0}.gps-help-content p{color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.5;margin-bottom:var(--space-3)}.gps-help-content ul{color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.6;padding-left:var(--space-5);margin-bottom:var(--space-3)}.gps-help-content li{margin-bottom:var(--space-1)}.gps-help-content .tip{background:var(--blue-500-alpha);border-left:3px solid var(--blue-500);padding:var(--space-2) var(--space-3);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:var(--space-3) 0}.gps-help-content .tip strong{color:var(--blue-500)}.gps-help-content .warning{background:var(--warning-alpha);border-left:3px solid var(--warning);padding:var(--space-2) var(--space-3);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:var(--space-3) 0}.gps-help-content .warning strong{color:var(--warning)}.gps-help-close{display:block;width:100%;margin-top:var(--space-5);padding:var(--space-3);background:var(--blue-500);border:none;border-radius:var(--radius-sm);color:var(--text-inverse);font-size:var(--font-size-base);font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.gps-help-close:hover{background:var(--blue-600)}#photo-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}#upload-progress{width:100%;background:var(--bg-tertiary);border:2px solid var(--border-secondary);border-radius:var(--radius-md);position:relative;overflow:hidden;padding:var(--space-3) var(--space-5)}#upload-progress-fill{position:absolute;top:0;left:0;bottom:0;background:linear-gradient(90deg,var(--blue-600),var(--blue-400));width:0%;transition:width .2s ease}#upload-progress-text{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-base);font-weight:600;color:var(--text-primary);white-space:nowrap}#upload-progress.uploading #upload-progress-fill{background:linear-gradient(90deg,var(--success),#4ade80)}#upload-section:has(#upload-progress:not(.hidden)) #upload-label{display:none}#upload-section:has(#upload-progress:not(.hidden)) #photo-input{display:none}#upload-message{font-size:var(--font-size-xs);color:var(--warning);padding:var(--space-2) 0;text-align:center;animation:toastIn .2s ease-out}#upload-message.hidden{display:none}#settings{background:transparent;padding:0;flex-shrink:0}#settings label{font-size:var(--font-size-xs);color:var(--text-muted);display:flex;flex-direction:row;align-items:center;gap:var(--space-1);white-space:nowrap}#settings input[type=range]{width:90px;accent-color:var(--blue-500)}#cluster-radius-value{color:var(--blue-500);font-weight:600;font-size:var(--font-size-sm);min-width:40px}#photo-stats{display:flex;gap:var(--space-2);font-size:var(--font-size-xs);flex-shrink:0}#photo-stats span{color:var(--text-muted);white-space:nowrap}#transport-selector{background:var(--bg-primary);border-radius:var(--radius-md);padding:var(--space-3)}#transport-selector>label{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-bottom:var(--space-2);display:block}.transport-buttons{display:flex;gap:var(--space-2)}.transport-btn{flex:1;background:var(--bg-tertiary);border:2px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);padding:var(--space-3) var(--space-2);cursor:pointer;font-size:var(--font-size-sm);display:flex;align-items:center;justify-content:center;gap:var(--space-2);transition:all var(--transition-fast)}.transport-btn:hover{border-color:var(--blue-500);color:var(--text-primary)}.transport-btn.active{border-color:var(--blue-500);background:var(--blue-500-alpha);color:var(--text-primary)}.transport-icon{font-size:1.2rem}.segment-connector{display:flex;align-items:center;gap:var(--space-1);padding:2px 0;margin:0 0 0 20px}.segment-line{flex:1;height:1px;background:var(--border-primary)}.segment-mode-toggle{display:flex;align-items:center;gap:var(--space-1);background:var(--bg-primary);border-radius:var(--radius-sm);padding:2px;border:1px solid var(--border-primary)}.segment-distance{font-size:.7rem;color:var(--text-muted);padding:0 var(--space-1);white-space:nowrap}.segment-mode-btn{background:transparent;border:none;border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);opacity:.4}.segment-mode-btn:hover{opacity:.7;background:var(--blue-500-alpha)}.segment-mode-btn.active{opacity:1;background:var(--blue-500-alpha)}.segment-mode-btn.disabled{opacity:.3;cursor:default;pointer-events:none}#journey-controls{display:flex;align-items:center;gap:var(--space-2);flex:1;background:transparent;padding:0}.journey-spacer{flex:1}.ratio-buttons{display:flex;align-items:center;gap:var(--space-1)}.ratio-btn{flex:none;background:var(--bg-tertiary);border:2px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-secondary);padding:var(--space-1) var(--space-2);cursor:pointer;font-size:.7rem;display:flex;align-items:center;gap:5px;transition:all var(--transition-fast);white-space:nowrap;height:28px}.ratio-label{line-height:1}.ratio-btn:hover{border-color:var(--blue-500);color:var(--text-primary)}.ratio-btn.active{border-color:var(--blue-500);background:var(--blue-500-alpha);color:var(--text-primary)}.ratio-icon{display:block;border:2px solid currentColor;border-radius:2px;flex-shrink:0}.landscape-icon{width:18px;height:10px}.portrait-icon{width:10px;height:18px}.square-icon{width:14px;height:14px}.action-btn{padding:7px 14px;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.action-btn.preview{background:var(--blue-500);color:var(--text-inverse)}.action-btn.preview:hover{background:var(--blue-600)}.action-btn.export{background:var(--success);color:var(--text-inverse)}.action-btn.export:hover{background:var(--success-hover)}.action-btn.stop{background:var(--error);color:var(--text-inverse)}.action-btn.stop:hover{background:var(--error-hover)}.export-dropdown{position:relative;display:inline-block}.export-menu{position:fixed;z-index:9999;min-width:200px;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--space-1);display:flex;flex-direction:column;gap:2px}.export-menu.hidden{display:none!important}.export-menu-item{display:block;width:100%;padding:var(--space-2) var(--space-3);background:none;border:none;color:var(--text-primary);font-size:var(--font-size-sm);text-align:left;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast);white-space:nowrap}.export-menu-item:hover{background:var(--bg-tertiary)}#export-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8000;background:#000000d9;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}#export-overlay.hidden{display:none!important}.export-overlay-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.export-overlay-icon{font-size:48px;animation:exportPulse 2s ease-in-out infinite}@keyframes exportPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}}.export-overlay-title{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary)}.export-overlay-progress-bar{width:320px;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}#export-overlay-fill{width:0%;height:100%;background:var(--success);border-radius:4px;transition:width .3s ease}#export-overlay-percent{font-size:var(--font-size-lg);font-weight:500;color:var(--text-secondary);font-variant-numeric:tabular-nums}#export-overlay-cancel{margin-top:var(--space-2)}#toast-container{position:fixed;top:var(--space-6);right:var(--space-6);z-index:10000;display:flex;flex-direction:column;gap:var(--space-3);pointer-events:none}.toast{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--space-4) var(--space-5);color:var(--text-primary);font-size:var(--font-size-sm);font-family:inherit;max-width:360px;pointer-events:auto;animation:toastIn .25s ease-out}.toast.toast-success{border-left:3px solid var(--success)}.toast.toast-error{border-left:3px solid var(--error)}.toast.toast-info{border-left:3px solid var(--blue-500)}.toast.toast-warning{border-left:3px solid var(--warning)}.toast.toast-out{animation:toastOut .2s ease-in forwards}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(20px)}}#progress-bar{background:var(--bg-tertiary);border-radius:var(--radius-sm);height:26px;min-width:140px;max-width:260px;flex:1;position:relative;overflow:hidden}#progress-fill{height:100%;background:linear-gradient(90deg,var(--blue-600),var(--blue-400));border-radius:var(--radius-sm);width:0%;transition:width .3s}#progress-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 var(--space-2)}.sidebar-section-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:var(--space-2) var(--space-1) var(--space-1)}#stops-list{display:flex;flex-direction:column;gap:var(--space-2)}.stop-card{background:var(--bg-primary);border-radius:var(--radius-md);padding:var(--space-3);padding-left:var(--space-2);cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;display:grid;grid-template-columns:22px 1fr;grid-template-rows:auto auto;gap:var(--space-1) var(--space-1);position:relative}.stop-card:hover{border-color:var(--blue-500)}.drag-handle{grid-column:1;grid-row:1;width:22px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1.1rem;cursor:grab;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast);letter-spacing:1px}.drag-handle:hover{color:var(--blue-500)}.drag-handle:active{cursor:grabbing}.stop-card .stop-header{grid-column:2;grid-row:1;display:flex;justify-content:space-between;align-items:center;min-width:0}.stop-preview-row{grid-column:1 / -1;grid-row:2;display:flex;align-items:flex-start;gap:var(--space-1);margin-top:var(--space-1)}.stop-card .stop-photo-count{font-size:.7rem;color:var(--text-tertiary);width:22px;text-align:center;flex-shrink:0;padding-top:var(--space-1)}.stop-card .stop-photos-preview{flex:1;display:flex;align-items:center;gap:var(--space-1);overflow-x:auto;overflow-y:hidden;padding-bottom:var(--space-1)}.stop-card .stop-photos-preview::-webkit-scrollbar{height:4px}.stop-card .stop-photos-preview::-webkit-scrollbar-track{background:#ffffff0d;border-radius:2px}.stop-card .stop-photos-preview::-webkit-scrollbar-thumb{background:var(--blue-500-alpha);border-radius:2px}.photo-item{position:relative;flex-shrink:0;cursor:grab;padding:var(--space-1) var(--space-1) 0 0}.photo-item:active{cursor:grabbing}.photo-item.dragging{opacity:.4;transform:scale(.95)}.photo-item.drag-over{transform:translate(4px)}.photo-item.drag-over-left{box-shadow:-3px 0 0 0 var(--blue-500)}.photo-item.drag-over-right{box-shadow:3px 0 0 0 var(--blue-500)}.photo-item img{width:48px;height:48px;object-fit:cover;border-radius:var(--radius-sm);display:block;transition:all .15s}.photo-placeholder{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--surface-secondary);border-radius:var(--radius-sm);font-size:20px;opacity:.6}.photo-item:hover img{opacity:.7}.photo-delete-btn{position:absolute;top:0;right:0;width:18px;height:18px;border-radius:50%;background:var(--error);border:2px solid var(--bg-primary);color:var(--text-inverse);font-size:10px;font-weight:700;cursor:pointer;display:none;align-items:center;justify-content:center;transition:all .15s;z-index:5;line-height:1;padding:0}.photo-item:hover .photo-delete-btn{display:flex}.photo-delete-btn:hover{background:var(--error-hover);transform:scale(1.1)}.delete-confirm-btns{position:absolute;top:0;right:0;display:flex;gap:2px;z-index:10}.delete-confirm-btn{width:18px;height:18px;border-radius:50%;border:2px solid var(--bg-primary);color:var(--text-inverse);font-size:10px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0;line-height:1}.delete-confirm-btn.confirm{background:var(--error)}.delete-confirm-btn.confirm:hover{background:var(--error-hover);transform:scale(1.1)}.delete-confirm-btn.cancel{background:var(--blue-500)}.delete-confirm-btn.cancel:hover{background:var(--blue-400);transform:scale(1.1)}.stop-edit-btn{width:22px;height:22px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;margin-left:auto;flex-shrink:0;opacity:.6}.stop-edit-btn:hover{color:var(--accent);opacity:1;transform:scale(1.1)}.stop-delete-btn{width:22px;height:22px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;opacity:.6}.stop-delete-btn:hover{color:var(--error);opacity:1;transform:scale(1.1)}.stop-header{display:flex;align-items:center;gap:var(--space-2)}.stop-header-info{flex:1;min-width:0;display:flex;align-items:center;gap:var(--space-2)}.stop-delete-confirm{display:flex;gap:var(--space-1);margin-left:auto}.stop-delete-confirm .delete-confirm-btn{width:22px;height:22px;font-size:11px}.stop-card.dragging{opacity:.4;border-color:var(--blue-500);transform:scale(.97)}.stop-card.drag-over-above{border-top:2px solid var(--blue-500);padding-top:var(--space-3)}.stop-card.drag-over-below{border-bottom:2px solid var(--blue-500);padding-bottom:var(--space-3)}.stop-card .stop-name{font-weight:600;font-size:var(--font-size-sm);color:var(--text-primary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.stop-card .stop-name .stop-icon{vertical-align:middle;flex-shrink:0}.stop-icon{flex-shrink:0;vertical-align:middle}#map-area{grid-area:map;position:relative;width:100%;height:100%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#000}#map-container{position:relative;width:100%;height:100%;overflow:hidden}#map{width:100%;height:100%}#photo-overlay{position:absolute;z-index:10;pointer-events:none;transition:opacity .6s ease;opacity:0;top:0;right:0;bottom:0;width:50%;display:flex;align-items:center;justify-content:center;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}#photo-overlay.visible{opacity:1;pointer-events:auto;cursor:pointer}#photo-overlay.landscape,#photo-overlay.portrait,#photo-overlay.square{top:0;right:0;bottom:0;left:auto;width:50%;transform:none}#photo-overlay.landscape #photo-frame{width:90%;max-width:700px;min-width:300px}#photo-overlay.portrait #photo-frame{width:auto;max-width:90%}#photo-overlay.portrait #overlay-photo{height:70vh;max-height:700px;min-height:300px;width:auto}#photo-overlay.square #photo-frame{width:80%;max-width:500px;min-width:280px}#photo-frame{background:var(--overlay-bg);border-radius:var(--radius-lg);padding:var(--space-3);box-shadow:var(--shadow-elevated);border:2px solid var(--blue-500-alpha);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:default}#overlay-photo{width:100%;border-radius:var(--radius-md);display:block;object-fit:contain;transition:opacity .3s ease}#overlay-caption{padding:var(--space-2) var(--space-2) var(--space-1);font-size:.9rem;color:var(--text-secondary);text-align:center;font-weight:500}#photo-overlay-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border:none;border-radius:50%;background:#0009;color:#fff;font-size:24px;cursor:pointer;pointer-events:auto;display:flex;align-items:center;justify-content:center;z-index:15;transition:background .2s ease,transform .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}#photo-overlay-close:hover{background:#000c;transform:scale(1.1)}#photo-overlay-close.hidden{display:none}#stop-overlay{position:absolute;top:40px;left:50%;transform:translate(-50%);z-index:11;text-align:center;pointer-events:none;opacity:0;transition:opacity .5s ease}#stop-overlay.visible{opacity:1;animation:fadeSlideIn .6s ease}#stop-overlay-name{font-size:1.3rem;font-weight:700;color:var(--text-primary);text-shadow:0 2px 20px rgba(0,0,0,.8);background:var(--overlay-bg);padding:var(--space-2) var(--space-7);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--blue-500-alpha);max-width:80vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#stop-overlay-count{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-1);text-shadow:0 1px 10px rgba(0,0,0,.8)}@keyframes fadeSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.mapboxgl-popup-content{background:var(--bg-primary)!important;color:var(--text-primary)!important;border-radius:var(--radius-md)!important;padding:var(--space-3)!important;box-shadow:var(--shadow-lg)!important}.mapboxgl-popup-tip{border-top-color:var(--bg-primary)!important}.popup-carousel{min-width:220px}.popup-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.popup-header strong{font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.popup-counter{font-size:var(--font-size-xs);color:var(--text-tertiary);background:#ffffff1a;padding:2px var(--space-2);border-radius:var(--radius-md)}.popup-photo-container{position:relative;display:flex;align-items:center;justify-content:center;min-width:150px;min-height:100px}.popup-photo{max-width:220px;max-height:200px;object-fit:contain;border-radius:var(--radius-sm);display:block;transition:width var(--transition-fast),height var(--transition-fast)}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:28px;height:28px;border:none;border-radius:50%;background:var(--blue-500);color:var(--text-inverse);font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:10}.carousel-btn:hover{background:var(--blue-600);transform:translateY(-50%) scale(1.1)}.carousel-prev{left:-10px}.carousel-next{right:-10px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-elevated);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);padding:var(--space-7) var(--space-8);min-width:340px;max-width:420px;box-shadow:var(--shadow-lg);animation:modalSlideIn .25s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content h3{color:var(--text-primary);font-size:1.3rem;font-weight:600;margin-bottom:var(--space-5);text-align:center}.modal-content input[type=text]{width:100%;padding:var(--space-3) var(--space-4);background:var(--input-bg);border:1px solid var(--blue-500-alpha);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-base);outline:none;transition:all var(--transition-fast)}.modal-content input[type=text]:focus{border-color:var(--blue-500);background:var(--blue-500-alpha);box-shadow:0 0 0 3px var(--blue-500-alpha)}.modal-content input[type=text]::placeholder{color:var(--text-muted)}.modal-error{color:var(--error);font-size:var(--font-size-sm);margin-top:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--error-alpha);border-radius:var(--radius-sm);border:1px solid var(--error-alpha)}.modal-hint{color:var(--text-muted);font-size:var(--font-size-xs);margin-top:var(--space-2);font-style:italic}.modal-buttons{display:flex;gap:var(--space-3);margin-top:var(--space-6)}.modal-btn{flex:1;padding:var(--space-3) var(--space-5);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.modal-btn.primary{background:var(--blue-500);color:var(--text-inverse)}.modal-btn.primary:hover{background:var(--blue-600);transform:translateY(-1px)}.modal-btn.secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-primary)}.modal-btn.secondary:hover{background:var(--bg-elevated);color:var(--text-primary)}.modal-btn.danger{background:var(--error);color:#fff}.modal-btn.danger:hover{background:#c53030;transform:translateY(-1px)}.modal-overlay.modal-anchored{align-items:flex-start;justify-content:flex-start}.modal-content.modal-dropdown{min-width:300px;max-width:300px;padding:var(--space-5)}.modal-content.modal-dropdown h3{font-size:1rem;margin-bottom:var(--space-4);text-align:left}.modal-content.modal-dropdown .modal-buttons{margin-top:var(--space-4)}.modal-content.modal-dropdown .modal-btn{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.modal-content.modal-danger{border:1px solid var(--error);background:var(--bg-elevated)}.modal-content.modal-danger h3{color:var(--error);text-align:center}.modal-danger-icon{font-size:2rem;text-align:center;margin-bottom:var(--space-2)}.modal-danger-text{color:var(--text-secondary);font-size:var(--font-size-sm);text-align:center;margin-bottom:var(--space-2);line-height:1.4}.hidden{display:none!important}#welcome-wizard{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;pointer-events:none}#welcome-wizard:not(.hidden){pointer-events:auto}.wizard-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.wizard-step{display:none;position:absolute;top:0;right:0;bottom:0;left:0}.wizard-step.active{display:block}.wizard-card.wizard-step-card{max-width:460px;padding:36px 44px}.wizard-card.wizard-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-elevated);border:1px solid var(--blue-500-alpha);border-radius:var(--radius-xl);padding:var(--space-12) var(--space-14);text-align:center;max-width:480px;box-shadow:var(--shadow-lg);animation:wizardFadeIn .4s ease-out}@keyframes wizardFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.wizard-icon{font-size:4rem;margin-bottom:var(--space-4)}.wizard-card h2{font-size:1.8rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-3)}.wizard-card h3{font-size:1.3rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.wizard-card p{font-size:var(--font-size-base);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-6)}.wizard-step-number{font-size:var(--font-size-xs);color:var(--blue-500);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-2)}.wizard-card.wizard-positioned{position:absolute;background:var(--bg-elevated);border:1px solid var(--blue-500-alpha);border-radius:var(--radius-lg);padding:var(--space-7) var(--space-8);max-width:380px;box-shadow:var(--shadow-lg);animation:wizardSlideIn .3s ease-out}@keyframes wizardSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.wizard-highlight{position:absolute;border:3px solid var(--blue-500);border-radius:var(--radius-md);box-shadow:0 0 0 9999px #000000bf,0 0 30px var(--blue-500-alpha);pointer-events:none;animation:wizardPulse 2s ease-in-out infinite}@keyframes wizardPulse{0%,to{box-shadow:0 0 0 9999px #000000bf,0 0 20px var(--blue-500-alpha)}50%{box-shadow:0 0 0 9999px #000000bf,0 0 40px var(--blue-500)}}.wizard-buttons{display:flex;gap:var(--space-3);justify-content:flex-end}.wizard-btn{padding:var(--space-3) var(--space-6);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.wizard-btn.wizard-next,.wizard-btn.wizard-finish{background:var(--blue-500);color:var(--text-inverse)}.wizard-btn.wizard-next:hover,.wizard-btn.wizard-finish:hover{background:var(--blue-600);transform:translateY(-2px);box-shadow:0 6px 20px var(--blue-500-alpha)}.wizard-btn.wizard-secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-primary)}.wizard-btn.wizard-secondary:hover{background:var(--bg-elevated);color:var(--text-primary)}.wizard-btn.wizard-prev{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.header-build-time{margin-left:auto;margin-right:var(--space-3);font-size:var(--font-size-xs);color:var(--warning);font-family:SF Mono,Fira Code,Consolas,monospace;white-space:nowrap;flex-shrink:0}#dev-tools{position:relative;flex-shrink:0;font-family:SF Mono,Fira Code,Consolas,monospace}.dev-tools-btn{background:var(--warning-alpha);border:1px solid var(--warning);border-radius:var(--radius-sm);color:var(--warning);font-size:.78rem;font-weight:700;padding:var(--space-1) var(--space-2);cursor:pointer;display:flex;align-items:center;gap:var(--space-1);transition:all var(--transition-fast);white-space:nowrap;letter-spacing:.4px}.dev-tools-btn:hover{background:var(--warning);color:var(--bg-primary)}#dev-tools-body{position:fixed;top:52px;right:16px;background:#120d00;border:1px solid var(--warning);border-radius:var(--radius-sm);padding:var(--space-3);z-index:9999;min-width:280px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:var(--space-2)}#dev-tools-body.hidden{display:none!important}.dev-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.dev-danger-row{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--error)}.dev-danger-btn{width:100%;padding:var(--space-2) var(--space-3);background:var(--error);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.dev-danger-btn:hover{filter:brightness(1.15)}.dev-label{font-size:.73rem;color:#cca600;flex:1}.dev-input-group{display:flex;align-items:center;gap:var(--space-1)}.dev-input-group input[type=number]{width:62px;padding:3px 6px;background:#0d0900;border:1px solid var(--warning);border-radius:var(--radius-sm);color:gold;font-family:inherit;font-size:.78rem;text-align:right;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.dev-input-group input[type=number]::-webkit-inner-spin-button,.dev-input-group input[type=number]::-webkit-outer-spin-button{opacity:.5}.dev-input-group input[type=number]:focus{outline:none;border-color:var(--warning);box-shadow:0 0 0 2px var(--warning-alpha)}.dev-unit{font-size:.7rem;color:#8a6200;min-width:14px}.dev-select{padding:3px 6px;background:#0d0900;border:1px solid var(--warning);border-radius:var(--radius-sm);color:var(--warning);font-size:.73rem;cursor:pointer}.dev-select:focus{outline:none;border-color:var(--warning);box-shadow:0 0 0 2px var(--warning-alpha)}.dev-select-sm{padding:2px 4px;background:#0d0900;border:1px solid var(--warning);border-radius:var(--radius-sm);color:var(--warning);font-size:.65rem;cursor:pointer}.dev-input-group input[type=checkbox]{width:16px;height:16px;accent-color:var(--warning);cursor:pointer}.dev-speed-slider{width:80px;accent-color:var(--warning)}.dev-speed-label{min-width:56px;font-size:.72rem;color:gold}.modal-section{margin-top:var(--space-4)}.modal-section>p{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-bottom:var(--space-2)}.modal-transport-btns{display:flex;gap:var(--space-2)}.modal-transport-btn{flex:1;background:var(--bg-tertiary);border:2px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-secondary);padding:var(--space-2) var(--space-2);cursor:pointer;font-size:var(--font-size-sm);text-align:center;transition:all var(--transition-fast)}.modal-transport-btn:hover{border-color:var(--blue-500);color:var(--text-primary)}.modal-transport-btn.active{border-color:var(--blue-500);background:var(--blue-500-alpha);color:var(--text-primary)}.modal-transport-btn.disabled{opacity:.3;cursor:default;pointer-events:none}#loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.loading-content{text-align:center}.loading-icon{font-size:3rem;margin-bottom:var(--space-3);animation:loadingPulse 1.5s ease-in-out infinite}.loading-text{font-size:var(--font-size-2xl);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:-.5px}@keyframes loadingPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}}#landing-page{min-height:100vh;background:transparent;color:var(--text-primary);font-family:var(--font-family);position:relative}.landing-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden}.landing-bg img{width:120%;height:120%;margin:-10%;object-fit:cover;animation:kenBurns 25s ease-in-out infinite alternate;will-change:transform}@keyframes kenBurns{0%{transform:scale(1) translate(0)}to{transform:scale(1.1) translate(-4%,-3%)}}.landing-nav{position:sticky;top:0;z-index:100;background:#0b1220b3;border-bottom:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=light] .landing-nav{background:#f8fafcb3;border-bottom-color:#0000001a}.landing-nav-inner{max-width:1100px;margin:0 auto;padding:var(--space-3) var(--space-6);display:flex;align-items:center;justify-content:space-between}.landing-logo{font-size:var(--font-size-xl);font-weight:var(--font-bold);letter-spacing:-.5px}.landing-nav-buttons{display:flex;gap:var(--space-2)}.landing-btn{padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-semibold);cursor:pointer;border:none;transition:all var(--transition-fast)}.landing-btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-primary)}.landing-btn-secondary:hover{color:var(--text-primary);border-color:var(--text-muted)}.landing-btn-primary{background:var(--blue-500);color:#fff}.landing-btn-primary:hover{background:var(--blue-600)}.landing-btn-cta{background:var(--blue-500);color:#fff;padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg);border-radius:var(--radius-lg)}.landing-btn-cta:hover{background:var(--blue-600);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.landing-hero{position:relative;z-index:1;padding:120px var(--space-6) 100px;text-align:center;overflow:hidden;background:#0b122066;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}[data-theme=light] .landing-hero{background:#f8fafc66}.landing-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(11,18,32,.3) 0%,transparent 50%,rgba(11,18,32,.3) 100%);z-index:0}[data-theme=light] .landing-hero:after{background:linear-gradient(180deg,rgba(248,250,252,.3) 0%,transparent 50%,rgba(248,250,252,.3) 100%)}.landing-hero-inner{position:relative;z-index:1;max-width:750px;margin:0 auto}.landing-hero-title{font-size:clamp(2rem,5vw,3.2rem);font-weight:var(--font-bold);line-height:1.2;margin-bottom:var(--space-6);letter-spacing:-1px}.landing-hero-highlight{background:linear-gradient(135deg,var(--blue-400),var(--blue-600));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-hero-subtitle{font-size:var(--font-size-lg);color:var(--text-secondary);line-height:1.7;margin-bottom:var(--space-8);max-width:600px;margin-left:auto;margin-right:auto}.landing-features{position:relative;z-index:1;padding:80px var(--space-6);background:#0b122099;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}[data-theme=light] .landing-features{background:#f8fafca6;border-top-color:#00000014;border-bottom-color:#00000014}.landing-section-title{font-size:var(--font-size-2xl);font-weight:var(--font-bold);text-align:center;margin-bottom:var(--space-10);letter-spacing:-.5px}.landing-features-grid{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.landing-feature-card{background:#ffffff0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-6);text-align:center;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}[data-theme=light] .landing-feature-card{background:#fff6;border-color:#00000014}.landing-feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.landing-feature-icon{font-size:2.5rem;margin-bottom:var(--space-4)}.landing-feature-card h3{font-size:var(--font-size-lg);font-weight:var(--font-semibold);margin-bottom:var(--space-3)}.landing-feature-card p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}.landing-how-it-works{position:relative;z-index:1;padding:80px var(--space-6);background:#0b122080;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}[data-theme=light] .landing-how-it-works{background:#f8fafc8c}.landing-steps{max-width:900px;margin:0 auto;display:flex;align-items:flex-start;gap:var(--space-4)}.landing-step{flex:1;text-align:center}.landing-step-number{width:48px;height:48px;border-radius:50%;background:var(--blue-500);color:#fff;font-size:var(--font-size-xl);font-weight:var(--font-bold);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4)}.landing-step h3{font-size:var(--font-size-base);font-weight:var(--font-semibold);margin-bottom:var(--space-2)}.landing-step p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}.landing-step-arrow{font-size:1.5rem;color:var(--text-muted);margin-top:12px}.landing-footer{position:relative;z-index:1;padding:var(--space-6);background:#0b1220cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.08);text-align:center}[data-theme=light] .landing-footer{background:#f8fafccc;border-top-color:#00000014}.landing-footer-inner{font-size:var(--font-size-sm);color:var(--text-muted)}.landing-footer-sep{margin:0 var(--space-2)}.landing-build-time{opacity:.5;font-size:var(--font-size-xs)}@media(max-width:768px){.landing-features-grid{grid-template-columns:1fr;max-width:400px}.landing-steps{flex-direction:column;align-items:center}.landing-step-arrow{transform:rotate(90deg);margin:0}}.auth-modal-overlay{z-index:10000}.auth-modal{max-width:400px;width:100%}.auth-modal h3{font-size:var(--font-size-xl);font-weight:var(--font-bold);margin-bottom:var(--space-1)}.auth-subtitle{color:var(--text-muted);font-size:var(--font-size-sm);margin-bottom:var(--space-6)}.auth-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-elevated);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.auth-google-btn:hover:not(:disabled){border-color:var(--text-muted);background:var(--bg-tertiary)}.auth-google-btn:disabled{opacity:.5;cursor:not-allowed}.auth-divider{display:flex;align-items:center;margin:var(--space-5) 0;gap:var(--space-3)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-primary)}.auth-divider span{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-field{display:flex;flex-direction:column;gap:var(--space-1)}.auth-field label{font-size:var(--font-size-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.auth-field input{padding:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-elevated);color:var(--text-primary);font-size:var(--font-size-sm);transition:border-color var(--transition-fast)}.auth-field input:focus{outline:none;border-color:var(--blue-500);box-shadow:var(--focus-ring)}.auth-field input::placeholder{color:var(--text-disabled)}.auth-error{background:var(--error-muted);color:var(--error);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.auth-success{background:var(--success-muted);color:var(--success);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.auth-submit-btn{width:100%;padding:var(--space-3);border-radius:var(--radius-md);border:none;background:var(--blue-500);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-semibold);cursor:pointer;transition:background var(--transition-fast)}.auth-submit-btn:hover:not(:disabled){background:var(--blue-600)}.auth-submit-btn:disabled{opacity:.5;cursor:not-allowed}.auth-links{margin-top:var(--space-5);text-align:center;font-size:var(--font-size-sm);color:var(--text-muted)}.auth-link{background:none;border:none;color:var(--blue-400);cursor:pointer;font-size:var(--font-size-sm);padding:0}.auth-link:hover{text-decoration:underline}.auth-link-separator{margin:0 var(--space-2);color:var(--text-disabled)}#email-verification-banner{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);padding:var(--space-3) var(--space-4);display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);color:var(--text-secondary)}#email-verification-banner .verification-icon{width:32px;height:32px;border-radius:50%;background:var(--blue-500-alpha);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:var(--font-size-base)}#email-verification-banner .verification-text{flex:1}#email-verification-banner .verification-text strong{color:var(--text-primary);display:block;font-size:var(--font-size-sm);margin-bottom:2px}#email-verification-banner .verification-text span{font-size:var(--font-size-xs);color:var(--text-muted)}.verification-resend-btn,.verification-check-btn{background:none;border:1px solid var(--border-primary);color:var(--text-secondary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-size-xs);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.verification-resend-btn:hover{border-color:var(--blue-500);color:var(--blue-400);background:var(--blue-500-alpha)}.verification-check-btn{background:var(--blue-500);border-color:var(--blue-500);color:#fff}.verification-check-btn:hover{background:var(--blue-600);border-color:var(--blue-600)}#verification-message{width:100%;font-size:var(--font-size-xs);text-align:center;padding:var(--space-1) 0 0;animation:toastIn .2s ease-out}#verification-message.hidden{display:none}#verification-message.success{color:var(--success)}#verification-message.error{color:var(--error)}#verification-message.warning{color:var(--warning)}#user-profile{position:relative;margin-left:var(--space-2)}.user-avatar-btn{width:34px;height:34px;border-radius:50%;border:2px solid var(--border-primary);background:var(--blue-500);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-bold);cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:border-color var(--transition-fast)}.user-avatar-btn:hover{border-color:var(--blue-400)}.user-avatar-btn img{width:100%;height:100%;object-fit:cover}#user-profile-menu{position:fixed;z-index:9999;min-width:220px;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-elevated);padding:var(--space-2) 0}.profile-menu-header{padding:var(--space-3) var(--space-4)}.profile-name{font-weight:var(--font-semibold);font-size:var(--font-size-sm);color:var(--text-primary)}.profile-email{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:2px}.profile-menu-divider{height:1px;background:var(--border-primary);margin:var(--space-1) 0}.profile-menu-item{width:100%;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);border:none;background:none;color:var(--text-secondary);font-size:var(--font-size-sm);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.profile-menu-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.profile-menu-icon{font-size:var(--font-size-base);width:20px;text-align:center}.profile-menu-logout{color:var(--error)}.profile-menu-logout:hover{background:var(--error-muted);color:var(--error)}.profile-menu-settings{padding:var(--space-2) var(--space-4) var(--space-3)}.profile-menu-settings-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2)}.profile-menu-settings-row{display:flex;align-items:center;gap:var(--space-2)}.profile-menu-settings-row input[type=range]{flex:1;accent-color:var(--blue-500)}.profile-menu-settings-row #cluster-radius-value{color:var(--blue-500);font-weight:600;font-size:var(--font-size-sm);min-width:40px}[data-theme=dark] .theme-icon-light,[data-theme=light] .theme-icon-dark{display:none}.palette-chooser{padding:var(--space-2) var(--space-4) var(--space-3)}.palette-chooser-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2)}.palette-swatches{display:flex;gap:var(--space-2)}.palette-swatch{width:28px;height:28px;border-radius:50%;border:2px solid var(--border-primary);cursor:pointer;transition:all var(--transition-fast);position:relative}.palette-swatch:hover{transform:scale(1.15);border-color:var(--text-muted)}.palette-swatch.active{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--text-primary)}.palette-swatch[data-palette=blue]{background:linear-gradient(135deg,#60a5fa,#2563eb)}.palette-swatch[data-palette=sunset]{background:linear-gradient(135deg,#ff9f43,#ff6b4a)}.palette-swatch[data-palette=ocean]{background:linear-gradient(135deg,#2dd4bf,#14b8a6)}.palette-swatch[data-palette=violet]{background:linear-gradient(135deg,#a78bfa,#8b5cf6)}#photo-panel{position:absolute;top:0;right:0;bottom:0;width:50%;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;overflow:hidden;z-index:8}#photo-panel.portrait{top:auto;right:0;bottom:0;width:100%;height:50%}#photo-panel.fullscreen-mode,#photo-panel.hidden{display:none!important}#journey-trip-header{flex-shrink:0;padding:var(--space-2) var(--space-4);background:#0006;border-bottom:1px solid rgba(255,255,255,.08);text-align:center;overflow:hidden;max-height:0;opacity:0;transition:max-height .5s ease,opacity .4s ease,padding .5s ease}#journey-trip-header.hidden{display:block!important;max-height:0;opacity:0;padding-top:0;padding-bottom:0}#journey-trip-header.visible{max-height:50px;opacity:1}#journey-trip-summary{font-size:var(--font-size-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.3px}#photo-panel-default{flex:1;display:flex;align-items:center;justify-content:center;transition:opacity .4s ease,transform .5s ease}#photo-panel-default.collapsing{opacity:0;transform:translateY(-30px) scale(.95);pointer-events:none}#photo-panel-default.expanding{animation:expandIn .6s ease forwards}@keyframes expandIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.panel-default-content{text-align:center;padding:var(--space-6)}#panel-default-icon{font-size:3rem;margin-bottom:var(--space-3);opacity:.6}#panel-default-message{font-size:var(--font-size-lg);color:var(--text-secondary);margin-bottom:var(--space-4)}#panel-default-stats{font-size:var(--font-size-sm);color:var(--text-muted);line-height:1.8}.panel-default-story{font-size:var(--font-size-sm);color:var(--text-muted);font-style:italic;margin-top:var(--space-4);line-height:1.6;text-align:center;padding:0 var(--space-4)}#photo-panel-header{padding:var(--space-3) var(--space-4);flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;max-width:100%;overflow:hidden}#photo-panel-stop-name{font-size:var(--font-size-base);font-weight:var(--font-bold);color:var(--text-primary);text-shadow:0 1px 6px rgba(0,0,0,.6);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;display:flex;align-items:center;gap:6px}#photo-panel-photo-count{font-size:var(--font-size-xs);color:var(--text-muted);text-shadow:0 1px 4px rgba(0,0,0,.6);white-space:nowrap}#photo-panel-stack{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:0}.photo-stack-card{position:absolute;max-width:calc(100% - 50px);max-height:calc(100% - 50px);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-elevated);cursor:pointer;border:2px solid rgba(255,255,255,.1);transition:transform .4s ease,opacity .4s ease;transform:rotate(0) translate(0)}.photo-stack-card:hover{border-color:var(--blue-400)}.photo-stack-card img{display:block;max-width:100%;max-height:100%;object-fit:contain}.photo-stack-card.spread.stack-0{transform:rotate(0) translate(0);opacity:1;z-index:4}.photo-stack-card.spread.stack-1{transform:rotate(-2deg) translate(-8px,4px);opacity:.85;z-index:3}.photo-stack-card.spread.stack-2{transform:rotate(2deg) translate(8px,8px);opacity:.7;z-index:2}.photo-stack-card.spread.stack-3{transform:rotate(-1deg) translate(-4px,12px);opacity:.55;z-index:1}.photo-missing-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-lg);z-index:10}.photo-missing-text{color:var(--text-muted);font-size:var(--font-size-sm);text-align:center}.photo-missing-relink{font-size:var(--font-size-xs);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md)}.stop-card.selected{border-color:var(--blue-500);background:var(--blue-500-alpha)}#photo-panel-single{position:relative;flex:1;display:flex;flex-direction:column;overflow:hidden}#photo-panel-single.hidden{display:none!important}#photo-panel-back{background:#00000080;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3);cursor:pointer;transition:all var(--transition-fast);align-self:flex-start;margin:var(--space-3) var(--space-5);flex-shrink:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}#photo-panel-back:hover{background:#000000b3;border-color:var(--blue-400)}#photo-panel-single-frame{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 var(--space-5) var(--space-5);overflow:hidden}#photo-panel-single-img{max-width:100%;max-height:75vh;object-fit:contain;border-radius:var(--radius-lg);box-shadow:var(--shadow-elevated)}.photo-nav-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:5;background:#00000080;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-md);color:var(--text-primary);font-size:28px;line-height:1;width:40px;height:56px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:.7}.photo-nav-btn:hover{background:#000000bf;border-color:var(--blue-400);opacity:1}.photo-nav-btn.hidden{display:none}.photo-nav-prev{left:var(--space-3)}.photo-nav-next{right:var(--space-3)}#photo-panel-single-caption{font-size:var(--font-size-sm);color:var(--text-secondary);text-shadow:0 1px 4px rgba(0,0,0,.6);margin-top:var(--space-3);text-align:center}.view-mode-toggle{display:flex;align-items:center;gap:0;margin-left:var(--space-2)}.view-mode-btn{background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-muted);padding:3px 8px;cursor:pointer;font-size:.65rem;transition:all var(--transition-fast);white-space:nowrap;height:24px;display:flex;align-items:center;letter-spacing:.3px}.view-mode-btn:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm);border-right:none}.view-mode-btn:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.view-mode-btn:hover{color:var(--text-primary)}.view-mode-btn.active{border-color:var(--blue-500);background:var(--blue-500-alpha);color:var(--text-primary)}.view-mode-btn.disabled,.ratio-btn.disabled{opacity:.4;pointer-events:none;cursor:default}#photo-panel-intro{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);animation:fadeInPanel .8s ease}#photo-panel-intro.hidden{display:none!important}.intro-icon{font-size:3.5rem;animation:travelBounce 3s ease-in-out infinite}.intro-title{font-size:var(--font-size-lg);font-weight:var(--font-bold);color:var(--text-primary);text-shadow:0 2px 8px rgba(0,0,0,.6);text-align:center;max-width:90%}.intro-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);text-shadow:0 1px 4px rgba(0,0,0,.6);text-align:center;max-width:80%;line-height:1.5}#photo-panel-travelling{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);animation:fadeInPanel .5s ease}#photo-panel-travelling.hidden{display:none!important}.travelling-icon{font-size:3rem;animation:travelBounce 2s ease-in-out infinite}.travelling-text{font-size:var(--font-size-sm);color:var(--text-secondary);text-shadow:0 1px 4px rgba(0,0,0,.6);text-transform:uppercase;letter-spacing:1px}.travelling-destination{font-size:var(--font-size-lg);font-weight:var(--font-bold);color:var(--text-primary);text-shadow:0 2px 8px rgba(0,0,0,.6);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;padding:0 var(--space-2);max-width:90%}.travelling-distance{font-size:var(--font-size-sm);color:var(--text-muted);text-shadow:0 1px 4px rgba(0,0,0,.6)}@keyframes fadeInPanel{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes travelBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}#photo-panel-journey-photo{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-4);overflow:hidden;animation:fadeInPanel .4s ease}#photo-panel-journey-photo.hidden{display:none!important}#journey-photo-frame{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.journey-photo-layer{position:absolute;max-width:100%;max-height:calc(100% - 40px);object-fit:contain;border-radius:var(--radius-lg);box-shadow:var(--shadow-elevated);opacity:0;transition:opacity var(--crossfade-duration, .8s) ease}.journey-photo-layer.active{opacity:1;z-index:1}.journey-photo-layer.no-animate{transition:none}#journey-photo-caption{font-size:var(--font-size-sm);color:var(--text-secondary);text-shadow:0 1px 4px rgba(0,0,0,.6);margin-top:var(--space-3);text-align:center}@media(max-width:1199px){#photo-panel{display:none!important}}#app.compact-sidebar{grid-template-columns:180px 1fr}#app.compact-sidebar #sidebar{padding:var(--space-2)}#app.compact-sidebar .stop-photos-preview,#app.compact-sidebar .drag-handle{display:none}#app.compact-sidebar .stop-card{grid-template-columns:1fr;padding:var(--space-2)}#app.compact-sidebar .stop-preview-row{margin-top:0}#app.compact-sidebar .stop-edit-btn,#app.compact-sidebar .stop-delete-btn{display:none}#app.compact-sidebar .stop-card:hover .stop-edit-btn,#app.compact-sidebar .stop-card:hover .stop-delete-btn{display:flex}@media(max-width:900px){#app:not(.compact-sidebar){grid-template-columns:220px 1fr}#app:not(.compact-sidebar) .stop-photos-preview{display:none}}#fullscreen-journey-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:9;display:flex;align-items:center;justify-content:center;background:#0006;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:opacity .5s ease;opacity:1}#fullscreen-journey-overlay.hidden{display:none;opacity:0}.fs-overlay-content{text-align:center;padding:var(--space-6)}#fs-overlay-icon{font-size:3rem;margin-bottom:var(--space-3)}#fs-overlay-title{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}#fs-overlay-subtitle{font-size:var(--font-size-sm);color:var(--text-muted)}
