:root{--accent-hue: 220;--c-accent: hsl(var(--accent-hue), 88%, 62%);--c-accent-dim: hsl(var(--accent-hue), 88%, 62%, .14);--c-pick: hsl(var(--accent-hue), 88%, 62%);--top-bar-h: 52px;--filter-bar-h: 36px;--rail-w: 44px;--left-w: 240px;--right-w: 280px;--radius: 6px;--radius-lg: 10px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "SF Mono", "Consolas", monospace;--transition: .15s ease}:root,[data-theme=dark]{--c-bg: #111111;--c-surface: #1a1a1a;--c-surface2: #232323;--c-border: #2e2e2e;--c-border2: #3a3a3a;--c-text: #e8e8e8;--c-text2: #909090;--c-text3: #555555;--c-reject: #e05252;--c-danger: #e05252;--c-success: #4caf7a;--c-warning: #e0a84f;--shadow: 0 4px 20px rgba(0,0,0,.5);--shadow-lg: 0 12px 48px rgba(0,0,0,.6)}[data-theme=light]{--c-bg: #f0f0ec;--c-surface: #ffffff;--c-surface2: #f5f5f2;--c-border: #e0e0db;--c-border2: #d0d0ca;--c-text: #1a1a1a;--c-text2: #555550;--c-text3: #999990;--c-reject: #d93a3a;--c-danger: #d93a3a;--c-success: #2e9c5e;--c-warning: #c88b20;--shadow: 0 4px 20px rgba(0,0,0,.08);--shadow-lg: 0 12px 48px rgba(0,0,0,.12);--c-accent-dim: hsl(var(--accent-hue), 80%, 55%, .1)}[data-density=compact]{--top-bar-h: 44px;--filter-bar-h: 30px;--rail-w: 40px;--left-w: 220px;--right-w: 260px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font);background:var(--c-bg);color:var(--c-text);font-size:13px;transition:background .2s,color .2s}button{cursor:pointer;border:none;background:none;color:inherit;font:inherit}input,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}img{display:block}ul,ol{list-style:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--c-border2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--c-text3)}.app-shell{--people-w: var(--left-w);display:grid;grid-template-rows:var(--top-bar-h) auto minmax(0,1fr);grid-template-columns:var(--left-w) 0 minmax(0,1fr) var(--right-w);grid-template-areas:"topbar  topbar  topbar  topbar" "filters filters filters filters" "left    people  grid    right";height:100%;overflow:hidden}.app-shell.people-open{grid-template-columns:var(--left-w) var(--people-w) minmax(0,1fr) var(--right-w)}.app-shell.right-hidden{grid-template-columns:var(--left-w) 0 minmax(0,1fr) 0}.app-shell.right-hidden.people-open{grid-template-columns:var(--left-w) var(--people-w) minmax(0,1fr) 0}.app-shell.left-hidden{grid-template-columns:0 0 minmax(0,1fr) var(--right-w)}.app-shell.left-hidden.people-open{grid-template-columns:0 var(--people-w) minmax(0,1fr) var(--right-w)}.app-shell.left-hidden.right-hidden{grid-template-columns:0 0 minmax(0,1fr) 0}.app-shell.left-hidden.right-hidden.people-open{grid-template-columns:0 var(--people-w) minmax(0,1fr) 0}.panel-rail{grid-area:rail;display:flex;flex-direction:column;align-items:center;gap:8px;padding:10px 5px;background:var(--c-surface);border-right:1px solid var(--c-border);overflow:hidden;z-index:7}.panel-rail-btn{width:100%;min-height:56px;border-radius:10px;border:1px solid transparent;background:transparent;color:var(--c-text3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition)}.panel-rail-btn:hover{background:var(--c-surface2);color:var(--c-text2);border-color:var(--c-border2)}.panel-rail-btn.active{background:var(--c-accent-dim);color:var(--c-accent);border-color:var(--c-accent)}.panel-rail-icon{font-size:15px;line-height:1}.panel-rail-label{font-size:8.5px;font-weight:850;letter-spacing:.02em;line-height:1;writing-mode:vertical-rl;text-transform:uppercase}.app-shell.full-width-experience{grid-template-columns:1fr;grid-template-areas:"topbar" "filters" "grid"}.app-shell.full-width-experience>[style*="grid-area: main"],.app-shell.full-width-experience>[style*="grid-area:main"]{grid-area:grid!important}.top-bar{grid-area:topbar;display:flex;align-items:center;gap:8px;padding:0 12px;background:var(--c-surface);border-bottom:1px solid var(--c-border);z-index:10}.top-bar-logo{height:36px;width:auto;object-fit:contain;display:block;margin-right:4px;flex-shrink:0}.top-bar-sep{width:1px;height:20px;background:var(--c-border2);flex-shrink:0}.top-bar-spacer{flex:1}.view-tabs{display:flex;gap:2px;background:var(--c-surface2);border:1px solid var(--c-border);border-radius:var(--radius);padding:2px}.view-tab{padding:4px 10px;border-radius:4px;font-size:12px;color:var(--c-text3);transition:background var(--transition),color var(--transition);display:flex;align-items:center;gap:5px}.view-tab:hover{color:var(--c-text2)}.view-tab.active{background:var(--c-surface);color:var(--c-accent);box-shadow:0 1px 3px #00000026}[data-theme=light] .view-tab.active{box-shadow:0 1px 4px #0000001a}.theme-toggle{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);color:var(--c-text2);font-size:15px;transition:background var(--transition),color var(--transition)}.theme-toggle:hover{background:var(--c-surface2);color:var(--c-text)}.filter-bar{grid-area:filters;display:flex;align-items:flex-start;flex-wrap:wrap;gap:6px;padding:0 12px;min-height:var(--filter-bar-h);max-height:76px;background:var(--c-surface);border-bottom:1px solid var(--c-border);overflow-x:hidden;overflow-y:auto;z-index:9}.filter-bar::-webkit-scrollbar{height:0}.filter-pill{display:flex;align-items:center;gap:4px;padding:2px 8px 2px 10px;background:var(--c-accent-dim);border:1px solid var(--c-accent);border-radius:20px;color:var(--c-accent);font-size:11.5px;white-space:nowrap;flex-shrink:0}.filter-pill button{display:flex;align-items:center;opacity:.7;font-size:13px;line-height:1;padding:0 1px}.filter-pill.pinned{border-color:var(--c-accent)!important;background:var(--c-accent-dim)!important;color:var(--c-accent)!important;box-shadow:0 0 0 1px var(--c-accent)}.filter-clear{font-size:11.5px;color:var(--c-text3);padding:2px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0;border:1px solid var(--c-border);transition:color var(--transition),border-color var(--transition)}.filter-clear:hover{color:var(--c-text2);border-color:var(--c-border2)}.left-panel{grid-area:left;display:flex;flex-direction:column;background:var(--c-surface);border-right:1px solid var(--c-border);overflow:hidden;position:relative;z-index:6;box-shadow:8px 0 18px #00000029}.panel-label{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--c-text3);padding:6px 12px 3px}.panel-section{border-bottom:1px solid var(--c-border)}.panel-row{display:flex;align-items:center;gap:6px;padding:5px 10px;font-size:12.5px;color:var(--c-text2);cursor:pointer;transition:background var(--transition),color var(--transition);-webkit-user-select:none;user-select:none}.panel-row:hover{background:var(--c-surface2);color:var(--c-text)}.panel-row.active{background:var(--c-accent-dim);color:var(--c-accent)}.panel-row-count{margin-left:auto;font-size:10.5px;color:var(--c-text3);font-variant-numeric:tabular-nums}.panel-row-icon{font-size:13px;flex-shrink:0}.panel-row-chevron{font-size:9px;color:var(--c-text3);transition:transform var(--transition);flex-shrink:0}.panel-row-chevron.open{transform:rotate(90deg)}.right-panel{grid-area:right;position:relative;display:flex;flex-direction:column;background:var(--c-surface);border-left:1px solid var(--c-border);overflow:hidden}.right-panel-close-btn{position:absolute;top:8px;right:8px;z-index:20;width:28px;height:28px;border-radius:9px;border:1px solid var(--c-border2);background:var(--c-surface2);color:var(--c-text2);font-size:13px;font-weight:900;box-shadow:0 4px 14px #0000003d}.right-panel-close-btn:hover{color:var(--c-text);border-color:var(--c-accent);background:var(--c-surface)}.meta-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--c-border);font-size:12px;font-weight:500;color:var(--c-text2);background:var(--c-surface)}.meta-body{flex:1;overflow-y:auto}.meta-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--c-text3);font-size:12.5px;text-align:center;padding:20px;line-height:1.8}.meta-group{border-bottom:1px solid var(--c-border)}.meta-group-label{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--c-text3);padding:6px 12px 3px}.meta-row{display:flex;gap:8px;padding:4px 12px;align-items:baseline}.meta-key{font-size:11px;color:var(--c-text3);min-width:70px;flex-shrink:0;padding-top:1px}.meta-val{font-size:12px;color:var(--c-text2);word-break:break-word}.grid-area{grid-area:grid;overflow-y:auto;overflow-x:hidden;background:var(--c-bg);position:relative;min-height:0}.grid-thumb{position:relative;overflow:hidden;cursor:pointer;border-radius:3px;flex-shrink:0;transition:outline var(--transition)}.grid-thumb:hover .thumb-overlay{opacity:1}.grid-thumb.selected{outline:2px solid var(--c-accent);outline-offset:-1px}.thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000026;opacity:0;transition:opacity var(--transition);pointer-events:none}.thumb-overlay.selected{opacity:1;background:#4f8ef726}.thumb-check{position:absolute;top:5px;left:5px;width:16px;height:16px;border-radius:3px;border:1.5px solid rgba(255,255,255,.6);background:#0000004d;opacity:0;transition:opacity var(--transition);pointer-events:none}.grid-thumb:hover .thumb-check{opacity:1}.grid-thumb.selected .thumb-check{opacity:1;background:var(--c-accent);border-color:var(--c-accent)}.thumb-flag{position:absolute;top:4px;right:4px;font-size:9px;font-weight:700;padding:1px 4px;border-radius:3px;color:#fff}.thumb-flag.pick{background:var(--c-pick)}.thumb-flag.reject{background:var(--c-reject)}.thumb-stars{position:absolute;bottom:4px;right:4px;font-size:9px;color:gold;text-shadow:0 1px 2px rgba(0,0,0,.6);letter-spacing:-1px}.viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000ed;z-index:100;display:flex;align-items:center;justify-content:center;overflow:hidden}[data-theme=light] .viewer-overlay{background:#141414f2}.viewer-img{max-width:100%;max-height:100%;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none}.viewer-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:#ffffff1a;color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;transition:background var(--transition);z-index:5}.viewer-btn:hover{background:#fff3}.viewer-btn.prev{left:16px}.viewer-btn.next{right:16px}.viewer-close{width:32px;height:32px;border-radius:50%;background:#ffffff1a;color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background var(--transition);flex-shrink:0}.viewer-close:hover{background:#ffffff40}.viewer-info{position:absolute;bottom:0;left:0;right:0;padding:10px 16px;background:linear-gradient(transparent,#000000b3);color:#ffffffd9;font-size:12px;z-index:5}.btn{padding:5px 11px;border-radius:var(--radius);font-size:12.5px;font-weight:500;transition:background var(--transition),filter var(--transition)}.btn-primary{background:var(--c-accent);color:#fff}.btn-primary:hover{filter:brightness(1.1)}.btn-ghost{color:var(--c-text2);border:1px solid var(--c-border)}.btn-ghost:hover{background:var(--c-surface2);color:var(--c-text);border-color:var(--c-border2)}.search-input{flex:1;max-width:320px;padding:5px 10px 5px 30px;background:var(--c-bg);border:1px solid var(--c-border2);border-radius:20px;color:var(--c-text);font-size:12.5px;outline:none;transition:border var(--transition)}.search-input:focus{border-color:var(--c-accent)}.search-wrap{position:relative;flex:1;max-width:320px}.search-icon{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--c-text3);font-size:13px;pointer-events:none}.badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:10px;font-size:10.5px;font-weight:600}.badge-blue{background:var(--c-accent-dim);color:var(--c-accent)}.badge-neutral{background:var(--c-surface2);color:var(--c-text2)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--c-bg)}.auth-card{width:360px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow)}.auth-title{font-size:20px;font-weight:600;margin-bottom:4px}.auth-sub{color:var(--c-text2);font-size:13px;margin-bottom:24px}.form-group{margin-bottom:14px}.form-label{display:block;font-size:12px;color:var(--c-text2);margin-bottom:5px}.form-input{width:100%;padding:8px 11px;background:var(--c-bg);border:1px solid var(--c-border2);border-radius:var(--radius);color:var(--c-text);font-size:13px;outline:none;transition:border var(--transition)}.form-input:focus{border-color:var(--c-accent)}.form-error{color:var(--c-danger);font-size:11.5px;margin-top:4px}.form-submit{width:100%;padding:9px;background:var(--c-accent);color:#fff;border-radius:var(--radius);font-size:13px;font-weight:500;margin-top:8px;transition:filter var(--transition)}.form-submit:hover{filter:brightness(1.1)}.form-submit:disabled{opacity:.5;cursor:not-allowed}.auth-link{text-align:center;margin-top:16px;font-size:12.5px;color:var(--c-text2)}.auth-link a{color:var(--c-accent)}.coll-selector{position:relative}.coll-trigger{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--c-text);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.coll-trigger:hover{background:var(--c-surface2)}.coll-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:220px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:4px;box-shadow:var(--shadow-lg);z-index:50}.coll-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius);cursor:pointer;font-size:13px;color:var(--c-text2)}.coll-item:hover{background:var(--c-surface2);color:var(--c-text)}.coll-item.active{color:var(--c-accent)}.coll-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.coll-divider{height:1px;background:var(--c-border);margin:4px 0}.import-toast{position:fixed;bottom:20px;right:20px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:12px 16px;width:320px;box-shadow:0 4px 12px #00000024;z-index:50;contain:paint}.import-toast-title{font-size:12.5px;font-weight:500;margin-bottom:6px}.import-progress-bar{height:4px;background:var(--c-border);border-radius:999px;overflow:hidden;margin-bottom:4px}.import-progress-fill{height:100%;background:var(--c-accent);border-radius:999px;transition:width .3s ease}.import-toast-sub{font-size:11px;color:var(--c-text2)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--c-text3);text-align:center;padding:40px}.empty-icon{font-size:40px;opacity:.4}.empty-title{font-size:15px;color:var(--c-text2);font-weight:500}.empty-sub{font-size:12.5px;line-height:1.7}.spinner{border:2px solid var(--c-border2);border-top-color:var(--c-accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sync-dot{width:7px;height:7px;border-radius:50%;background:var(--c-success)}.sync-dot.pending{background:var(--c-warning);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.timeline-view{display:flex;flex-direction:column;height:100%;overflow:hidden}.timeline-scrubber{flex-shrink:0;height:48px;border-bottom:1px solid var(--c-border);background:var(--c-surface);display:flex;align-items:center;overflow-x:auto;gap:2px;padding:0 12px}.timeline-scrubber::-webkit-scrollbar{height:0}.timeline-month{display:flex;flex-direction:column;align-items:center;padding:0 8px;flex-shrink:0;cursor:pointer;border-radius:var(--radius);transition:background var(--transition)}.timeline-month:hover{background:var(--c-surface2)}.timeline-month.active{background:var(--c-accent-dim)}.timeline-month-label{font-size:9.5px;color:var(--c-text3);text-transform:uppercase;letter-spacing:.05em}.timeline-month-count{font-size:11px;color:var(--c-text2);font-weight:500}.timeline-month.active .timeline-month-label,.timeline-month.active .timeline-month-count{color:var(--c-accent)}.timeline-groups{flex:1;overflow-y:auto;padding:0}.timeline-group{margin-bottom:0;border-bottom:1px solid var(--c-border)}.timeline-group-header{position:sticky;top:0;z-index:5;padding:6px 14px 5px;background:var(--c-surface);border-bottom:1px solid var(--c-border);display:flex;align-items:baseline;gap:8px}.timeline-group-date{font-size:12.5px;font-weight:600;color:var(--c-text)}.timeline-group-count{font-size:11px;color:var(--c-text3)}.timeline-group-photos{display:flex;flex-wrap:wrap;gap:2px;padding:6px 10px 8px}.map-view{position:relative;height:100%;background:var(--c-bg)}.map-container{width:100%;height:100%}.map-no-gps{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--c-text3);font-size:13px}.leaflet-container{background:var(--c-bg)!important}[data-theme=light] .leaflet-container{background:#e8e4dc!important}.leaflet-popup-content-wrapper{background:var(--c-surface)!important;border:1px solid var(--c-border)!important;color:var(--c-text)!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-lg)!important}.leaflet-popup-tip{background:var(--c-surface)!important}.marker-cluster-custom{background:var(--c-accent);border:2px solid rgba(255,255,255,.3);border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;box-shadow:0 2px 8px #00000059}.grid-area.timeline-mode .group-header{position:sticky;top:0;z-index:10;background:var(--c-bg);border-bottom:2px solid var(--c-accent);padding:10px 8px 8px;margin-bottom:8px;display:flex;align-items:baseline;gap:10}.grid-area.timeline-mode .group-header .group-header-label{font-size:20px!important;font-weight:800!important;color:var(--c-accent)!important;letter-spacing:-.03em}.grid-area.timeline-mode .photo-group{border-left:3px solid var(--c-accent);margin-left:2px;padding-left:10px;margin-bottom:32px}.panel-row:focus{outline:1px solid var(--c-accent);outline-offset:-1px;background:var(--c-surface2)}body.import-performance-mode *,body.import-performance-mode *:before,body.import-performance-mode *:after{transition:none!important;animation-duration:.001ms!important;animation-iteration-count:1!important}body.import-performance-mode .grid-thumb:hover .thumb-overlay,body.import-performance-mode .grid-thumb:hover .thumb-check{opacity:0!important}body.import-performance-mode .grid-thumb.selected .thumb-check{opacity:1!important}body.import-performance-mode .panel-rail-btn:hover,body.import-performance-mode .panel-row:hover,body.import-performance-mode .coll-item:hover,body.import-performance-mode .timeline-month:hover,body.import-performance-mode .btn-ghost:hover,body.import-performance-mode .viewer-btn:hover,body.import-performance-mode .viewer-close:hover{background:inherit!important;filter:none!important}body.import-performance-mode .import-toast,body.import-performance-mode .coll-menu,body.import-performance-mode .context-menu{box-shadow:none!important;filter:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}body.import-performance-mode img,body.import-performance-mode .import-progress-fill{transition:none!important}body.import-performance-mode .import-toast{background:var(--c-surface)!important}
