:root{--font-sans:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Helvetica Neue","Segoe UI",Roboto,Arial,sans-serif;--font-mono:ui-monospace,"SF Mono",SFMono-Regular,Menlo,Monaco,"Cascadia Mono","Roboto Mono",Consolas,monospace;--font-serif:ui-serif,"New York","Times New Roman",Times,serif;--bg:#05050a;--surface:#13131a;--surface2:#1c1c26;--surface3:#262634;--border:hsla(0,0%,100%,.08);--border2:hsla(0,0%,100%,.14);--glass-bg:rgba(22,22,32,.55);--glass-bg-soft:rgba(22,22,32,.35);--glass-border:hsla(0,0%,100%,.08);--glass-blur:blur(32px) saturate(180%);--accent:#38bdf8;--accent-strong:#0ea5e9;--accent-dim:rgba(56,189,248,.15);--accent-mid:rgba(56,189,248,.35);--heart-user:#ec4899;--heart-user-dim:rgba(236,72,153,.18);--heart-featured:#fbbf24;--heart-featured-dim:rgba(251,191,36,.18);--text:#e8e8f0;--text-mid:#a0a0b8;--text-dim:#60607a;--red:#f87171;--green:#4ade80;--radius:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:22px;--spring:cubic-bezier(0.32,0.72,0,1);--spring-fast:cubic-bezier(0.4,0,0.2,1);--spring-slow:cubic-bezier(0.23,1,0.32,1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:dark;text-rendering:optimizeLegibility}body{background:radial-gradient(ellipse at top left,rgba(56,189,248,.08) 0,transparent 45%),radial-gradient(ellipse at bottom right,rgba(129,140,248,.06) 0,transparent 45%),var(--bg);background-attachment:fixed;color:var(--text);font-family:var(--font-sans);font-weight:400;line-height:1.5;letter-spacing:-.011em;font-feature-settings:"kern","liga","calt","ss01";min-height:100vh;overflow:hidden}button{cursor:pointer;border:none;font-family:inherit;font-size:14px;font-weight:500;border-radius:var(--radius);transition:all .18s var(--spring-fast);white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:7px;color:inherit}button:disabled{opacity:.4;cursor:not-allowed}input,select,textarea{background:hsla(0,0%,100%,.04);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:inherit;font-size:14px;padding:9px 12px;outline:none;transition:all .18s var(--spring-fast);width:100%}input:focus,select:focus,textarea:focus{border-color:var(--accent);background:hsla(0,0%,100%,.06);box-shadow:0 0 0 3px var(--accent-dim)}input::placeholder,textarea::placeholder{color:var(--text-dim)}.btn-primary{background:var(--accent);color:#03111c;padding:9px 18px;font-weight:600}.btn-primary:hover:not(:disabled){background:#7dd3fc}.btn-ghost{background:hsla(0,0%,100%,.04);color:var(--text-mid);border:1px solid var(--glass-border);padding:8px 14px}.btn-ghost:hover:not(:disabled){background:hsla(0,0%,100%,.08);color:var(--text);border-color:var(--border2)}.btn-danger{background:hsla(0,91%,71%,.08);color:var(--red);border:1px solid hsla(0,91%,71%,.25);padding:7px 14px;font-size:13px}.btn-danger:hover:not(:disabled){background:hsla(0,91%,71%,.15)}.btn-sm{padding:6px 12px;font-size:13px}.btn-icon{width:32px;height:32px;padding:0;background:transparent;color:var(--text-mid)}.btn-icon:hover:not(:disabled){background:hsla(0,0%,100%,.08);color:var(--text)}.glass{background:var(--glass-bg)}.glass,.glass-soft{backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border)}.glass-soft{background:var(--glass-bg-soft)}.card{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-md);overflow:hidden;transition:all .2s var(--spring-fast)}.card:hover{border-color:var(--border2)}.sidebar-nav{display:flex;flex-direction:column;padding:8px;gap:2px}.sidebar-nav-item{display:flex;align-items:center;gap:11px;padding:8px 12px;border-radius:var(--radius);cursor:pointer;color:var(--text-mid);font-size:13.5px;font-weight:500;transition:all .15s var(--spring-fast);-webkit-user-select:none;-moz-user-select:none;user-select:none;border:none;background:transparent;width:100%;text-align:left;justify-content:flex-start}.sidebar-nav-item:hover{background:hsla(0,0%,100%,.05);color:var(--text)}.sidebar-nav-item.active{background:var(--accent);color:#03111c;font-weight:600}.sidebar-nav-item.active .icon-svg{color:#03111c}.sidebar-nav-item .icon-svg{width:18px;height:18px;flex-shrink:0;opacity:.85}.sidebar-nav-item.active .icon-svg{opacity:1}.sidebar-section-title{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.07em;padding:14px 14px 6px}.sidebar-project-row{display:flex;align-items:center;gap:8px;padding:7px 12px;margin:0 4px;border-radius:var(--radius);cursor:pointer;color:var(--text-mid);font-size:13px;transition:all .15s var(--spring-fast);border:none;background:transparent;width:calc(100% - 8px);text-align:left;position:relative}.sidebar-project-row:hover{background:hsla(0,0%,100%,.04);color:var(--text)}.sidebar-project-row.active{background:var(--accent-dim);color:var(--accent);font-weight:500}.sidebar-project-row .actions{display:none;gap:2px;margin-left:auto}.sidebar-project-row.active .actions,.sidebar-project-row:hover .actions{display:inline-flex}.sidebar-project-row .actions button{background:transparent;color:inherit;opacity:.6;padding:2px 4px;font-size:12px;min-width:0}.sidebar-project-row .actions button:hover{opacity:1}.toolbar{display:flex;align-items:center;gap:12px;padding:10px 16px;min-height:52px}.segmented{display:inline-flex;background:hsla(0,0%,100%,.06);padding:3px;border-radius:10px;border:1px solid var(--glass-border);gap:2px}.segmented button{background:transparent;color:var(--text-mid);padding:5px 14px;border-radius:7px;font-size:13px;font-weight:500;min-height:26px;transition:all .2s var(--spring-fast)}.segmented button:hover:not(.active){color:var(--text);background:hsla(0,0%,100%,.04)}.segmented button.active{background:hsla(0,0%,100%,.95);color:#000;box-shadow:0 1px 3px rgba(0,0,0,.2),0 1px 2px rgba(0,0,0,.12)}.search-field{display:flex;align-items:center;gap:8px;background:hsla(0,0%,100%,.06);border:1px solid var(--glass-border);border-radius:10px;padding:5px 12px;min-width:240px;transition:all .18s var(--spring-fast)}.search-field:focus-within{border-color:var(--accent-mid);background:hsla(0,0%,100%,.09);box-shadow:0 0 0 3px var(--accent-dim)}.search-field input{background:transparent;border:none;padding:4px 0;font-size:13px;outline:none;width:100%}.search-field input:focus{box-shadow:none}.search-field .search-icon{color:var(--text-dim);flex-shrink:0;width:14px;height:14px}.zoom-control{display:inline-flex;align-items:center;background:hsla(0,0%,100%,.06);border:1px solid var(--glass-border);border-radius:10px;overflow:hidden}.zoom-control button{background:transparent;color:var(--text-mid);padding:5px 10px;border-radius:0;font-size:14px;font-weight:500;min-width:30px;min-height:26px}.zoom-control button:hover:not(:disabled){color:var(--text);background:hsla(0,0%,100%,.05)}.photo-grid{display:grid;grid-gap:3px;gap:3px;grid-template-columns:repeat(auto-fill,minmax(var(--cell-size,200px),1fr));transition:grid-template-columns .3s var(--spring)}.photo-cell{position:relative;aspect-ratio:1;background:#000;border-radius:6px;overflow:hidden;cursor:pointer;transition:transform .2s var(--spring-fast);border:2px solid transparent}.photo-cell:hover{transform:scale(.985)}.photo-cell.selected{border-color:var(--accent)}.photo-cell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s var(--spring-slow)}.photo-cell:hover img{transform:scale(1.02)}.photo-cell .overlay{position:absolute;inset:0;background:rgba(0,0,0,.35);opacity:0;transition:opacity .18s var(--spring-fast);display:flex;align-items:center;justify-content:center}.photo-cell:hover .overlay{opacity:1}.photo-cell.selected:hover .overlay{background:rgba(56,189,248,.18)}.photo-cell .check-btn{width:38px;height:38px;border-radius:50%;background:rgba(0,0,0,.5);border:2px solid hsla(0,0%,100%,.65);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;font-size:17px;display:flex;align-items:center;justify-content:center;transition:all .2s var(--spring-fast)}.photo-cell.selected .check-btn{background:var(--accent);border-color:var(--accent);color:#000}.photo-cell .selected-badge{left:6px;background:var(--accent);color:#000;width:22px;height:22px;font-size:12px;font-weight:700;box-shadow:0 2px 6px rgba(0,0,0,.4)}.heart-badge,.photo-cell .selected-badge{position:absolute;top:6px;border-radius:50%;display:flex;align-items:center;justify-content:center}.heart-badge{width:26px;height:26px;font-size:14px;line-height:1;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:transform .2s var(--spring-fast),background .2s var(--spring-fast),opacity .18s var(--spring-fast),color .2s var(--spring-fast);cursor:pointer;border:none;color:hsla(0,0%,100%,.85);opacity:0;pointer-events:none;padding:0}.heart-badge.active,.photo-cell:hover .heart-badge{opacity:1;pointer-events:auto}.heart-badge.featured{right:6px}.heart-badge.user{right:38px}.heart-badge.active.featured{color:var(--heart-featured);background:color-mix(in srgb,var(--heart-featured) 22%,rgba(0,0,0,.55))}.heart-badge.active.user{color:var(--heart-user);background:color-mix(in srgb,var(--heart-user) 22%,rgba(0,0,0,.55))}.heart-badge:hover{background:rgba(0,0,0,.78)}.heart-badge.active:hover,.heart-badge:hover{transform:scale(1.12)}.heart-badge svg{width:14px;height:14px;display:block}.location-header{display:flex;align-items:baseline;gap:10px;padding:14px 2px 10px}.location-header .name{font-size:15px;font-weight:600;color:var(--text)}.location-header .count{font-family:var(--font-mono);font-size:11px;color:var(--text-dim)}.location-header .desc{font-size:12px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1}.category-header{display:flex;align-items:center;gap:10px;padding:6px 2px;margin-bottom:4px;position:-webkit-sticky;position:sticky;top:0;z-index:5;background:linear-gradient(180deg,rgba(22,22,32,.95) 70%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.category-header .title{font-family:var(--font-sans);font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.022em}.category-header .count{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);background:hsla(0,0%,100%,.06);padding:2px 8px;border-radius:10px;border:1px solid var(--glass-border)}.category-block{margin-bottom:40px}.location-block{margin-bottom:24px}.location-tile{position:relative;aspect-ratio:16/10;border-radius:10px;overflow:hidden;cursor:pointer;background:#000;transition:transform .25s var(--spring);border:1px solid var(--glass-border)}.location-tile:hover{transform:translateY(-2px);border-color:var(--border2)}.location-tile img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--spring-slow)}.location-tile:hover img{transform:scale(1.05)}.location-tile .tile-gradient{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.85) 0,rgba(0,0,0,.3) 40%,transparent 70%)}.location-tile .tile-info{position:absolute;bottom:0;left:0;right:0;padding:12px 14px;color:#fff}.location-tile .tile-info .name{font-size:14px;font-weight:600;margin-bottom:2px}.location-tile .tile-info .meta{font-family:var(--font-mono);font-size:10px;opacity:.7}.collection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-gap:14px;gap:14px}.collection-tile{position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;background:linear-gradient(135deg,var(--surface2),var(--surface));transition:transform .28s var(--spring),box-shadow .28s var(--spring);border:1px solid var(--glass-border)}.collection-tile:hover{transform:translateY(-3px) scale(1.015);border-color:var(--border2);box-shadow:0 12px 32px rgba(0,0,0,.45)}.collection-tile img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--spring-slow);filter:saturate(1.05)}.collection-tile:hover img{transform:scale(1.08)}.collection-tile .tile-gradient{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.9) 0,rgba(0,0,0,.45) 35%,transparent 65%)}.collection-tile .tile-info{position:absolute;bottom:0;left:0;right:0;padding:16px 18px;color:#fff}.collection-tile .tile-info .kind-chip{display:inline-block;font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;padding:2px 8px;border-radius:10px;background:hsla(0,0%,100%,.14);color:hsla(0,0%,100%,.85);margin-bottom:8px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.collection-tile .tile-info .tag{display:block;font-size:20px;font-weight:700;letter-spacing:-.02em;line-height:1.15;margin-bottom:4px;text-transform:capitalize;background:transparent;border:none;padding:0;color:#fff}.collection-tile .tile-info .count{font-family:var(--font-mono);font-size:11px;color:hsla(0,0%,100%,.7)}.collection-tile[data-kind=style]{--kind-color:#38bdf8}.collection-tile[data-kind=element]{--kind-color:#a78bfa}.collection-tile[data-kind=mood]{--kind-color:#f472b6}.collection-tile .tile-info .kind-chip{color:var(--kind-color,hsla(0,0%,100%,.85));background:color-mix(in srgb,var(--kind-color,#fff) 18%,transparent)}.collection-detail-header{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding:4px 2px 0}.collection-detail-header .back{width:36px;height:36px;border-radius:50%;background:hsla(0,0%,100%,.06);border:1px solid var(--glass-border);display:inline-flex;align-items:center;justify-content:center;color:var(--text);cursor:pointer;transition:all .18s var(--spring-fast);flex-shrink:0}.collection-detail-header .back:hover{background:hsla(0,0%,100%,.1);border-color:var(--border2);transform:translateX(-2px)}.collection-detail-header .kind-chip{display:inline-block;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:3px 10px;border-radius:12px;background:color-mix(in srgb,var(--kind-color,#fff) 14%,transparent);color:var(--kind-color,var(--text-mid));border:1px solid color-mix(in srgb,var(--kind-color,#fff) 30%,transparent)}.collection-detail-header .title{font-family:var(--font-sans);font-size:26px;font-weight:700;letter-spacing:-.022em;text-transform:capitalize}.collection-detail-header .count{font-family:var(--font-mono);font-size:11px;color:var(--text-dim);margin-left:auto}.favorites-section{margin-bottom:32px}.favorites-section-header{display:flex;align-items:baseline;gap:12px;margin-bottom:14px;padding:4px 2px 0}.favorites-section-header .icon{font-size:20px;line-height:1;align-self:center}.favorites-section-header .icon.featured{color:var(--heart-featured)}.favorites-section-header .icon.user{color:var(--heart-user)}.favorites-section-header .title{font-family:var(--font-sans);font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.favorites-section-header .count{font-family:var(--font-mono);font-size:11px;color:var(--text-dim)}.favorites-section-header .hint{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);margin-left:auto;letter-spacing:.04em}.favorites-empty{padding:24px;border-radius:var(--radius-lg);border:1px dashed var(--glass-border);font-size:13px;background:hsla(0,0%,100%,.02)}.coming-soon,.favorites-empty{color:var(--text-dim);text-align:center}.coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;height:100%;padding:40px}.coming-soon .icon{font-size:56px;opacity:.35}.coming-soon .title{font-family:var(--font-sans);font-size:28px;font-weight:700;color:var(--text-mid);letter-spacing:-.024em}.coming-soon .subtitle{font-size:13px;color:var(--text-dim);max-width:440px;line-height:1.6}.coming-soon .phase-badge{display:inline-block;font-family:var(--font-mono);font-size:10px;padding:4px 10px;border-radius:20px;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent-mid);text-transform:uppercase;letter-spacing:.08em}.project-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:var(--radius-lg)}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .3s var(--spring) both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .22s var(--spring-fast) both}@keyframes spin{to{transform:rotate(1turn)}}.spinner{width:16px;height:16px;border:2px solid hsla(0,0%,100%,.15);border-top:2px solid var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.08);border-radius:5px;border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,100%,.18);background-clip:content-box}.badge,.mono{font-family:var(--font-mono)}.badge{display:inline-flex;align-items:center;font-size:10px;font-weight:500;padding:2px 8px;border-radius:20px;background:hsla(0,0%,100%,.08);color:var(--text-mid);vertical-align:middle}.badge-accent{background:var(--accent-dim);color:var(--accent)}.tag{display:inline-block;font-family:var(--font-mono);font-size:10px;padding:3px 8px;border-radius:6px;background:hsla(0,0%,100%,.06);color:var(--text-mid);border:1px solid var(--glass-border)}.tag-accent{background:var(--accent-dim);color:var(--accent);border-color:var(--accent-mid)}.overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.progress-bar{height:3px;background:hsla(0,0%,100%,.06);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .4s ease}.app-shell{height:100vh;gap:8px;padding:8px}.app-shell,.app-shell>aside{display:flex;overflow:hidden}.app-shell>aside{flex-shrink:0;width:248px;flex-direction:column;border-radius:var(--radius-lg)}.app-shell>main{flex:1 1;display:flex;flex-direction:column;gap:8px;min-width:0}.app-shell header.toolbar-bar{flex-shrink:0;border-radius:var(--radius-lg)}.app-shell .content-pane{flex:1 1;border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.app-shell .content-pane .scroll{flex:1 1;overflow-y:auto;padding:20px 24px}.loc-pin{width:44px;height:44px;border-radius:50%;padding:2px;cursor:pointer;background:var(--accent);box-shadow:0 0 0 2px rgba(0,0,0,.55),0 6px 14px rgba(0,0,0,.55);transition:transform .2s var(--spring-fast),box-shadow .2s var(--spring-fast)}.loc-pin:hover{transform:scale(1.08);z-index:2;box-shadow:0 0 0 2px rgba(0,0,0,.7),0 8px 20px rgba(56,189,248,.45)}.loc-pin-inner{width:100%;height:100%;border-radius:50%;background-size:cover;background-position:50%;border:1.5px solid hsla(0,0%,100%,.9)}.loc-pin[data-accent=active]{background:var(--heart-featured)}.loc-pin[data-accent=edit]{background:#fff;cursor:-webkit-grab;cursor:grab}.loc-pin[data-accent=edit]:active{cursor:-webkit-grabbing;cursor:grabbing}.maplibregl-ctrl-group{background:rgba(22,22,32,.85)!important;border:1px solid var(--glass-border)!important;backdrop-filter:blur(14px)!important;-webkit-backdrop-filter:blur(14px)!important}.maplibregl-ctrl-group button{background:transparent!important;color:var(--text)!important;filter:invert(1) hue-rotate(180deg)}.maplibregl-ctrl-attrib{background:rgba(0,0,0,.45)!important;color:var(--text-dim)!important}.maplibregl-ctrl-attrib a{color:var(--text-mid)!important}