:root{--bg:#fff;--surface:#fff;--surface-2:#fdf5f8;--text:#1a1218;--text-dim:#7a6c73;--text-faint:#c2b7bd;--border:#f0e5ea;--border-soft:#f8eff3;--accent:#f4c2d7;--accent-ink:#5a2a3e;--danger:#c84a4a;--placeholder:#faeef3;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--hairline:1px;--sidebar-w:248px;--font-sans:var(--font-inter),-apple-system,BlinkMacSystemFont,"SF Pro Text",system-ui,sans-serif;--font-serif:var(--font-cormorant),Georgia,"Times New Roman",serif;--font-mono:ui-monospace,"SF Mono",Menlo,monospace}*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0;overflow-x:hidden}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:15px;line-height:1.5;letter-spacing:-.005em;min-height:100vh}button{cursor:pointer}button,input,textarea{font-family:inherit;font-size:inherit;color:inherit;background:transparent;border:0;padding:0}input,textarea{outline:none}a{color:inherit;text-decoration:none}img,video{display:block;max-width:100%}*{scrollbar-width:none;-ms-overflow-style:none}::-webkit-scrollbar{display:none;width:0;height:0}:focus{outline:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar{border-right:var(--hairline) solid var(--border);background:var(--bg);padding:28px 16px 24px;display:flex;flex-direction:column;gap:24px;position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;overflow-y:auto;z-index:10}.brand{font-family:var(--font-serif);font-weight:300;font-size:36px;line-height:1;letter-spacing:-.02em;padding:0 12px;color:var(--text);display:inline-flex;align-items:baseline;gap:6px}.brand .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block;transform:translateY(-4px)}.sidebar-section{display:flex;flex-direction:column;gap:1px}.sidebar-label{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);padding:0 12px 8px}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:10px;color:var(--text-dim);font-size:14px;font-weight:500;letter-spacing:-.005em;transition:background .12s,color .12s;position:relative}.nav-item.active,.nav-item:hover{color:var(--text);background:var(--surface-2)}.nav-item.active:before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:2px;background:var(--accent);border-radius:2px}.nav-item .icon{width:18px;height:18px;flex-shrink:0;opacity:.85}.nav-item.active .icon{opacity:1}.nav-badge{margin-left:auto;width:8px;height:8px;border-radius:50%;background:var(--accent)}.sidebar-foot{margin-top:auto;padding:8px 4px 0;border-top:var(--hairline) solid var(--border-soft)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px 8px;border-radius:10px}.sidebar-user:hover{background:var(--surface-2)}.sidebar-user-name{font-size:13px;font-weight:500}.sidebar-user-sub{font-size:11px;color:var(--text-dim)}.main{display:flex;flex-direction:column;min-width:0;grid-column:2/-1;padding-top:env(safe-area-inset-top,0)}.topbar{height:64px;display:flex;align-items:center;gap:16px;padding:0 32px;border-bottom:var(--hairline) solid var(--border);background:var(--bg);position:-webkit-sticky;position:sticky;top:0;z-index:5}.topbar-title{font-size:22px;font-weight:600;letter-spacing:-.015em}.topbar-spacer{flex:1 1}.topbar-search{display:flex;align-items:center;gap:8px;background:var(--surface-2);border-radius:999px;padding:8px 14px;width:320px;max-width:40vw;color:var(--text-dim)}.topbar-search input{flex:1 1;font-size:14px}.content{flex:1 1;padding:28px 32px 64px;min-width:0}.content-wide{padding:28px 32px 80px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:44px;padding:0 20px;border-radius:12px;font-size:14px;font-weight:600;letter-spacing:-.005em;transition:transform 80ms ease,opacity .12s,background .12s}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:var(--accent-ink)}.btn-primary:hover{opacity:.92}.btn-ghost{border:var(--hairline) solid var(--border);background:transparent;color:var(--text)}.btn-ghost:hover{background:var(--surface-2)}.btn-text{color:var(--text-dim);padding:0 12px;height:36px;font-weight:500}.btn-text:hover{color:var(--text)}.btn-danger{color:var(--danger)}.btn-block{width:100%}.btn-sm{height:32px;padding:0 12px;font-size:13px;border-radius:8px}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:12px;font-weight:500;letter-spacing:.02em;color:var(--text-dim);padding-left:2px}.input{height:48px;padding:0 14px;border-radius:12px;border:var(--hairline) solid var(--border);background:var(--surface);font-size:15px;color:var(--text);width:100%;transition:border-color .12s}.input:focus-visible{outline:none;border-color:var(--accent)}.input.with-prefix{padding-left:36px}.input-wrap{position:relative;display:flex;align-items:center}.input-prefix{position:absolute;left:14px;color:var(--text-dim);font-size:15px;pointer-events:none}textarea.input{padding:14px;min-height:88px;resize:none;line-height:1.5}.card{background:var(--surface);border:var(--hairline) solid var(--border);border-radius:var(--radius-lg);padding:28px}.row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;cursor:pointer;transition:background .12s}.row+.row{border-top:var(--hairline) solid var(--border-soft)}.row:hover{background:var(--surface-2)}.row-label{font-size:14px;font-weight:500}.row-value{font-size:13px;color:var(--text-dim)}.row-arrow{color:var(--text-faint);margin-left:8px}.row-danger .row-label{color:var(--danger)}.group{background:var(--surface);border:var(--hairline) solid var(--border);border-radius:var(--radius-md);overflow:hidden}.group-title{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);padding:24px 4px 8px}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--placeholder);color:var(--text);font-weight:600;letter-spacing:-.01em;-webkit-user-select:none;-moz-user-select:none;user-select:none;border:var(--hairline) solid var(--border);flex-shrink:0}.avatar.ringed{box-shadow:0 0 0 2px var(--accent);border-color:var(--surface)}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:20px 0 12px}.section-head h2{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0}.section-head .count{font-size:12px;color:var(--text-dim)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:2px;gap:2px}.photo-grid.tight{gap:2px}.photo-tile{aspect-ratio:1;background:#ececec;position:relative;overflow:hidden;cursor:pointer;transition:opacity .12s}.photo-tile:before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='1.2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='5' width='18' height='14' rx='2'/><circle cx='9' cy='10' r='1.4'/><path d='M3 17l5-5 4 4 3-3 6 6'/></svg>");background-repeat:no-repeat;background-position:50%;opacity:.45;pointer-events:none}.photo-tile.has-img:before{display:none}.photo-tile.no-key{background:#dcdcdc}.photo-tile.no-key:before{display:none}.tile-no-key{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:rgba(0,0,0,.55);pointer-events:none}.tile-no-key-label{font-size:10px;font-weight:500;letter-spacing:.02em;color:rgba(0,0,0,.55)}.select-topbar{height:56px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 12px;border-bottom:var(--hairline) solid var(--border);background:var(--bg);position:-webkit-sticky;position:sticky;top:0;z-index:20}.select-cancel{background:transparent;border:none;color:var(--accent-ink);font-size:14px;font-weight:500;padding:8px 4px;cursor:pointer}.select-count{font-size:15px;font-weight:600;color:var(--text)}.select-topbar-actions{display:flex;align-items:center;gap:4px}.select-topbar-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s,opacity .12s}@media (hover:hover){.select-topbar-btn:hover:not(:disabled){background:var(--surface-2)}}.select-topbar-btn:disabled{opacity:.4;cursor:not-allowed}.select-topbar-btn.danger{color:var(--danger)}.select-action-btn{height:36px;padding:0 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:13px;font-weight:600;white-space:nowrap;cursor:pointer;transition:background .12s,opacity .12s,transform 80ms;-webkit-tap-highlight-color:rgba(0,0,0,.08);touch-action:manipulation}@media (hover:hover){.select-action-btn:hover:not(:disabled){background:var(--surface-2)}}.select-action-btn:active{transform:scale(.96)}.select-action-btn:disabled{opacity:.45;cursor:not-allowed}.select-action-btn.danger{color:var(--danger);border-color:rgba(220,70,70,.35)}.pending-tile{pointer-events:none}.pending-badge{position:absolute;top:6px;right:6px;display:flex;align-items:center;justify-content:center}.pending-ring{width:16px;height:16px;border-radius:50%;border:2px solid hsla(0,0%,100%,.4);border-top-color:#fff;animation:pending-spin .8s linear infinite;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}@keyframes pending-spin{to{transform:rotate(1turn)}}.pending-failed{width:18px;height:18px;border-radius:50%;background:var(--danger);color:#fff;font-weight:700;font-size:12px;box-shadow:0 1px 2px rgba(0,0,0,.4)}.pending-failed,.tile-pin-badge{display:flex;align-items:center;justify-content:center}.tile-pin-badge{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:999px;background:linear-gradient(135deg,#ec4899,#7c3aed);z-index:3;pointer-events:none;box-shadow:0 2px 6px rgba(0,0,0,.35)}.insta-tile.tile-drop-hover{outline:2px dashed #ec4899;outline-offset:-2px;transform:scale(.97)}.insta-tile.tile-thumb-hidden .tile-img{filter:blur(28px) saturate(.6) brightness(.7);transform:scale(1.1)}.insta-tile.tile-thumb-hidden .photo-tile:before{display:none}.tile-hidden-glyph{inset:0;color:hsla(0,0%,100%,.92);pointer-events:none;z-index:2;text-shadow:0 1px 4px rgba(0,0,0,.5)}.media-nav-arrow,.tile-hidden-glyph{position:absolute;display:flex;align-items:center;justify-content:center}.media-nav-arrow{top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:none;background:rgba(20,20,22,.55);color:#fff;font-size:28px;line-height:1;cursor:pointer;z-index:5;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:background .12s,transform .12s}.media-nav-arrow.left{left:8px}.media-nav-arrow.right{right:8px}.media-nav-arrow:active{transform:translateY(-50%) scale(.92)}@media (hover:hover){.media-nav-arrow:hover{background:rgba(20,20,22,.78)}}@media (hover:none){.media-nav-arrow{width:52px;height:52px;font-size:32px;background:rgba(20,20,22,.72)}.media-nav-arrow.left{left:10px}.media-nav-arrow.right{right:10px}}.media-headerbtn{width:38px;height:38px;border-radius:999px;background:hsla(0,0%,100%,.08);color:#fafafa;border:1px solid hsla(0,0%,100%,.12);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s,transform .12s}.media-headerbtn:active{transform:scale(.92)}.media-headerbtn>*{pointer-events:none}.media-headerbtn.active{background:#fafafa;color:#0e0e10;border-color:#fafafa}@media (hover:hover){.media-headerbtn:hover{background:hsla(0,0%,100%,.14)}.media-headerbtn.active:hover{background:#fafafa}}.media-fs{position:fixed;inset:0;z-index:300;background:#000;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.media-fs img,.media-fs video{cursor:default;transition:transform .24s cubic-bezier(.2,.7,.2,1)}.media-fs-close{position:absolute;top:max(12px,env(safe-area-inset-top,0));right:12px;width:44px;height:44px;border-radius:999px;background:rgba(0,0,0,.5);color:#fff;border:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1}.media-fs-close>*{pointer-events:none}.media-editpanel{position:fixed;right:16px;top:80px;width:min(280px,calc(100vw - 32px));max-height:calc(100dvh - 120px);overflow-y:auto;background:rgba(20,20,22,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid hsla(0,0%,100%,.08);border-radius:16px;padding:16px;color:#fafafa;z-index:80;box-shadow:0 12px 40px rgba(0,0,0,.5);scrollbar-width:none}.media-editpanel::-webkit-scrollbar{display:none}.media-editpanel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.media-editpanel-head h4{margin:0;font-size:14px;font-weight:600;letter-spacing:.02em}.media-editpanel-close{width:32px;height:32px;border-radius:999px;background:transparent;color:hsla(0,0%,100%,.7);border:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.media-editpanel-close>*{pointer-events:none}.media-editpanel-section{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:hsla(0,0%,100%,.45);margin:14px 0 6px}.media-editpanel-section:first-of-type{margin-top:8px}.media-editpanel-auto{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:hsla(0,0%,100%,.92);color:#0e0e10;border:none;border-radius:12px;font-size:13px;font-weight:600;cursor:pointer;margin-bottom:4px}.media-editpanel-auto>svg{pointer-events:none}.media-editpanel-ai{width:100%;padding:10px 12px;background:linear-gradient(135deg,#ff7a59,#b259ff);color:#fff;border:none;border-radius:12px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .12s}.media-editpanel-ai:disabled{opacity:.5;cursor:not-allowed}.media-editpanel-actions{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px;margin-top:14px}.media-editpanel-revert,.media-editpanel-save{padding:10px;border-radius:10px;font-size:13px;font-weight:600;border:none;cursor:pointer;transition:background .12s}.media-editpanel-save{background:var(--accent,#fafafa);color:var(--accent-ink,#0e0e10)}.media-editpanel-save:disabled{background:hsla(0,0%,100%,.18);color:hsla(0,0%,100%,.5);cursor:not-allowed}.media-editpanel-revert{background:hsla(0,0%,100%,.08);color:#fafafa;border:1px solid hsla(0,0%,100%,.1)}.media-editpanel-revert:disabled{opacity:.5;cursor:not-allowed}@media (hover:hover){.media-editpanel-revert:hover:not(:disabled){background:hsla(0,0%,100%,.14)}}.edit-slider{margin-bottom:12px}.edit-slider-row{display:flex;justify-content:space-between;font-size:12px;color:hsla(0,0%,100%,.78);margin-bottom:6px}.edit-slider-val{color:hsla(0,0%,100%,.55);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.edit-slider input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:hsla(0,0%,100%,.12);border-radius:2px;outline:none;margin:0}.edit-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#fafafa;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.4);border:none}.edit-slider input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fafafa;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.4);border:none}.subtab-select-btn{border:none;background:transparent;color:var(--accent-ink);font-size:13px;font-weight:500;padding:6px 12px;margin-right:4px;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.subtab-select-btn:active{opacity:.6}.insta-tile{position:relative;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-moz-user-select:none;user-select:none;-webkit-user-select:none}.insta-tile>*{pointer-events:none}.insta-tile.tile-selected .photo-tile{filter:brightness(.92)}.insta-tick{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;border:2px solid #fff;background:transparent;display:flex;align-items:center;justify-content:center;pointer-events:none;box-shadow:0 1px 6px rgba(0,0,0,.55);transition:background .14s,border-color .14s;z-index:5}.insta-tick.on{background:var(--accent);border-color:#fff}.select-tick-hit{position:absolute;top:0;right:0;width:56px;height:56px;border:none;background:transparent;padding:0;margin:0;cursor:pointer;z-index:10;display:flex;align-items:flex-start;justify-content:flex-end;-webkit-tap-highlight-color:rgba(255,255,255,.3);touch-action:manipulation}.select-tick-hit>*{pointer-events:none}.select-tick-circle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;margin:6px 6px 0 0;border-radius:50%;border:2px solid hsla(0,0%,100%,.95);background:rgba(0,0,0,.32);box-shadow:0 1px 4px rgba(0,0,0,.45);transition:background .14s,border-color .14s,transform .12s}.select-tick-hit.on .select-tick-circle{background:var(--accent);border-color:var(--accent)}.select-tick-hit:active .select-tick-circle{transform:scale(.92)}.select-tick:hover{transform:scale(1.08)}.select-tick.on:before{background:var(--accent);border-color:var(--accent)}.select-tick.on{color:var(--accent-ink)}.tile-selected .photo-tile{outline:2px solid var(--accent);outline-offset:-2px}.album-pick-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:14px;cursor:pointer;text-align:left;width:100%}@media (hover:hover){.album-pick-row:hover:not(:disabled){background:var(--surface)}}.album-pick-row:disabled{opacity:.5;cursor:not-allowed}.picker-backdrop{position:fixed;inset:0;background:rgba(14,14,16,.5);z-index:60;display:flex;align-items:flex-end;justify-content:center;animation:backdrop-in .18s ease-out both}.picker-panel{background:var(--surface);border-top-left-radius:20px;border-top-right-radius:20px;width:100%;max-width:520px;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -8px 30px rgba(0,0,0,.18);animation:sheet-in .22s cubic-bezier(.2,.85,.25,1) both}.picker-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 10px;border-bottom:var(--hairline) solid var(--border)}.picker-head h3{margin:0;font-size:16px;font-weight:600}.picker-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--surface-2);font-size:20px;line-height:1;cursor:pointer;color:var(--text-dim)}.picker-list{display:flex;flex-direction:column}.picker-row{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:56px;padding:14px 18px;border:none;background:var(--surface);color:var(--text);font-size:15px;font-weight:500;text-align:left;cursor:pointer;border-bottom:var(--hairline) solid var(--border);-webkit-tap-highlight-color:rgba(244,194,215,.4);touch-action:manipulation;-moz-user-select:none;user-select:none;-webkit-user-select:none}.picker-row>*{pointer-events:none}.picker-row:last-child{border-bottom:none}.picker-row:active{background:var(--surface-2)}@media (hover:hover){.picker-row:hover{background:var(--surface-2)}}.picker-tag{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}@media (min-width:800px){.picker-backdrop{align-items:center}.picker-panel{border-radius:20px;max-width:420px;margin-bottom:0}}.upload-banner{position:fixed;top:calc(8px + env(safe-area-inset-top, 0));left:50%;transform:translateX(-50%);width:min(420px,calc(100vw - 24px));background:rgba(20,20,22,.92);color:#fff;border-radius:12px;padding:10px 14px;z-index:110;box-shadow:0 8px 24px rgba(0,0,0,.25);animation:pair-toast-in .22s cubic-bezier(.2,.7,.2,1)}.upload-banner-row{display:flex;justify-content:space-between;align-items:baseline;font-size:12.5px;font-weight:500;letter-spacing:.005em;margin-bottom:8px}.upload-banner-pct{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;opacity:.7}.upload-banner-bar{height:3px;border-radius:2px;background:hsla(0,0%,100%,.18);overflow:hidden}.upload-banner-bar-fill{height:100%;border-radius:2px;transition:width .22s ease}.pair-toast{position:fixed;left:50%;bottom:calc(96px + env(safe-area-inset-bottom, 0));transform:translateX(-50%);padding:10px 16px;border-radius:999px;font-size:13px;font-weight:500;background:rgba(20,20,22,.92);color:#fff;box-shadow:0 8px 24px rgba(0,0,0,.25);z-index:100;animation:pair-toast-in .22s cubic-bezier(.2,.7,.2,1);max-width:calc(100vw - 32px);text-align:center}.pair-toast.err{background:rgba(180,40,40,.95)}@keyframes pair-toast-in{0%{opacity:0;transform:translate(-50%,6px)}to{opacity:1;transform:translate(-50%)}}@media (min-width:800px){.pair-toast{bottom:32px}}.photo-tile.loading{background:linear-gradient(110deg,var(--placeholder) 30%,hsla(0,0%,100%,.06) 50%,var(--placeholder) 70%);background-size:200% 100%;animation:tile-shimmer 1.4s ease-in-out infinite}@keyframes tile-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@media (prefers-reduced-motion:reduce){.photo-tile.loading{animation:none}}.photo-tile:hover{opacity:.88}.photo-tile .badge{position:absolute;top:8px;left:8px;width:20px;height:20px;border-radius:50%;background:hsla(0,0%,100%,.85);color:#0e0e10;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.photo-tile.video:after{content:"";position:absolute;bottom:8px;right:8px;width:0;height:0;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:8px solid hsla(0,0%,100%,.85)}.photo-tile.video.loading{background:#2a2a2e;animation:none}.photo-tile.video.loading:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 24 24' fill='none' stroke='%23bbb' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'><polygon points='5 3 19 12 5 21 5 3'/></svg>");opacity:.65}.albums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:24px;gap:24px}.album-card{cursor:pointer}.album-thumb{aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;grid-gap:1px;gap:1px;background:var(--border-soft);position:relative}.album-thumb>div{background:var(--placeholder)}.album-thumb-cover{aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;position:relative;background:#ececec}.album-thumb-cover.album-thumb-mosaic{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;grid-gap:1px;gap:1px;background:var(--border-soft)}.album-thumb-cell{background:#ececec;overflow:hidden}.album-locked-overlay{position:absolute;inset:0;background:rgba(14,14,16,.45);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;color:var(--accent)}.album-name{font-size:14px;font-weight:600;margin-top:10px;letter-spacing:-.005em}.album-count{font-size:12px;color:var(--text-dim);margin-top:2px}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px}.auth-card{width:100%;max-width:420px;display:flex;flex-direction:column;gap:24px}.auth-brand{font-weight:300;font-size:64px;line-height:1;letter-spacing:-.03em}.auth-brand,.auth-tag{font-family:var(--font-serif);text-align:center;margin:0}.auth-tag{font-size:14px;color:var(--text-dim);font-style:italic;font-weight:400;letter-spacing:.01em}.auth-h1{font-size:24px;font-weight:600;letter-spacing:-.015em}.auth-h1,.auth-sub{margin:0;text-align:center}.auth-sub{font-size:13px}.auth-fine,.auth-sub{color:var(--text-dim)}.auth-fine{font-size:11px;line-height:1.55;text-align:center;padding:0 16px}.divider{display:flex;align-items:center;gap:12px;color:var(--text-faint);font-size:11px;letter-spacing:.1em;text-transform:uppercase;margin:4px 0}.divider:after,.divider:before{content:"";flex:1 1;height:var(--hairline);background:var(--border)}.invite-code{font-family:var(--font-mono);font-size:56px;font-weight:600;letter-spacing:.04em;color:var(--accent-ink);background:var(--surface-2);border:var(--hairline) solid var(--border);border-radius:var(--radius-md);padding:24px 32px;text-align:center;-webkit-user-select:all;-moz-user-select:all;user-select:all}.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;animation:pulse 1.6s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.35;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.pin-shell{display:flex;flex-direction:column;align-items:center;gap:32px}.pin-dots{display:flex;gap:14px}.pin-dot{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--text-dim);transition:background .12s,border-color .12s}.pin-dot.filled{background:var(--text);border-color:var(--text)}.pin-pad{display:grid;grid-template-columns:repeat(3,80px);grid-gap:16px;gap:16px}.pin-key{width:80px;height:80px;border-radius:50%;border:var(--hairline) solid var(--border);font-size:26px;font-weight:400;letter-spacing:-.02em;display:flex;align-items:center;justify-content:center;background:var(--surface);transition:background .1s,transform 80ms;-webkit-tap-highlight-color:rgba(244,194,215,.3);touch-action:manipulation;-moz-user-select:none;user-select:none;-webkit-user-select:none;cursor:pointer}.pin-key>*{pointer-events:none}@media (hover:hover){.pin-key:hover{background:var(--surface-2)}}.pin-key:active{transform:scale(.95);background:var(--surface-2)}.pin-key.ghost{border-color:transparent;background:transparent}.capture-stage{position:relative;background:#000;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:16/9;max-width:720px;margin:0 auto}.capture-stage video{width:100%;height:100%;object-fit:cover;display:block}.capture-empty{inset:0;justify-content:center;color:var(--text-faint);font-size:13px}.capture-empty,.capture-hud{position:absolute;display:flex;align-items:center}.capture-hud{left:16px;top:16px;gap:8px;background:rgba(14,14,16,.55);color:#fafafa;font-size:12px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;padding:6px 10px;border-radius:999px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.rec-dot{width:8px;height:8px;border-radius:50%;background:var(--danger);animation:pulse 1.2s ease-in-out infinite}.capture-controls{gap:24px;margin-top:24px}.capture-controls,.capture-shutter{display:flex;align-items:center;justify-content:center}.capture-shutter{width:72px;height:72px;border-radius:50%;border:3px solid var(--text);background:transparent;transition:transform 80ms}.capture-shutter:active{transform:scale(.94)}.capture-shutter .inner{width:56px;height:56px;border-radius:50%;background:var(--danger);transition:border-radius .2s,width .2s,height .2s}.capture-shutter.recording .inner{width:28px;height:28px;border-radius:6px}.capture-meta{font-size:13px;color:var(--text-dim);margin-top:12px;display:flex;align-items:center;justify-content:center;gap:12px}.capture-fs{position:fixed;z-index:200;color:#fff;flex-direction:column;overflow:hidden}.capture-fs,.capture-fs-media{inset:0;background:#000;display:flex}.capture-fs-media{position:absolute;align-items:center;justify-content:center}.capture-fs-media img,.capture-fs-media video{width:100%;height:100%;object-fit:cover;background:#000}.capture-fs-media video[controls]{object-fit:contain}.capture-fs-overlay{position:relative;z-index:1;color:hsla(0,0%,100%,.7);font-size:14px}.capture-fs-spinner{position:relative;z-index:1;display:flex;align-items:center;justify-content:center}.capture-fs-spinner span{width:32px;height:32px;border-radius:50%;border:3px solid hsla(0,0%,100%,.18);border-top-color:hsla(0,0%,100%,.85);animation:pending-spin .8s linear infinite}.capture-fs-topbar{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;padding:max(16px,env(safe-area-inset-top,0)) 16px 16px;gap:12px}.capture-fs-iconbtn{width:44px;height:44px;border-radius:999px;background:rgba(0,0,0,.45);color:#fff;display:inline-flex;align-items:center;justify-content:center;border:none;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.capture-fs-iconbtn:disabled{opacity:.4;cursor:not-allowed}.capture-fs-iconbtn>*{pointer-events:none}.capture-fs-rec{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:rgba(0,0,0,.55);color:#fff;font-size:13px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600}.capture-fs-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;color:#fff;background:rgba(220,38,38,.9);padding:10px 16px;border-radius:12px;font-size:13px;max-width:80vw;text-align:center}.capture-fs-modepicker{position:relative;z-index:2;display:flex;justify-content:center;align-items:center;gap:6px;margin-top:auto;margin-bottom:24px;padding:4px;background:rgba(0,0,0,.4);border-radius:999px;align-self:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.capture-fs-modepicker button{padding:6px 18px;border-radius:999px;background:transparent;color:hsla(0,0%,100%,.65);border:none;font-size:13px;font-weight:500;cursor:pointer}.capture-fs-modepicker button.active{background:hsla(0,0%,100%,.95);color:#111}.capture-fs-bottombar{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:0 32px calc(28px + env(safe-area-inset-bottom, 0));gap:16px}.capture-fs-shutter{width:76px;height:76px;border-radius:50%;background:hsla(0,0%,100%,.18);border:4px solid #fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .12s}.capture-fs-shutter:active{transform:scale(.94)}.capture-fs-shutter .inner{width:60px;height:60px;border-radius:50%;background:#fff;transition:width .18s,height .18s,border-radius .18s,background .18s}.capture-fs-shutter.recording .inner{width:28px;height:28px;border-radius:6px;background:#ef4444}.capture-fs-textbtn{background:transparent;color:#fff;font-weight:500;padding:10px 14px}.capture-fs-savebtn,.capture-fs-textbtn{border:none;font-size:15px;cursor:pointer}.capture-fs-savebtn{background:#fff;color:#111;border-radius:999px;padding:10px 22px;font-weight:600}body:has(.capture-fs) .fab-morph,body:has(.capture-fs) .ios-install-banner,body:has(.capture-fs) .mobile-nav,body:has(.capture-fs) .sidebar{display:none!important}.capture-mode{padding:3px;gap:2px}.capture-flip,.capture-mode{display:inline-flex;background:var(--surface-2);border-radius:999px}.capture-flip{width:36px;height:36px;color:var(--text);align-items:center;justify-content:center;border:none;cursor:pointer;transition:transform .18s cubic-bezier(.2,.7,.2,1),background .12s}.capture-flip:active{transform:rotate(180deg)}.capture-flip:disabled{opacity:.4;cursor:not-allowed}.capture-flip>*{pointer-events:none}.capture-mode button{padding:6px 16px;font-size:13px;font-weight:500;border-radius:999px;color:var(--text-dim)}.capture-mode button.active{background:var(--surface);color:var(--text)}.profile-head{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 0 8px}.profile-name{font-size:28px;font-weight:600;letter-spacing:-.02em;margin:0}.profile-handle{font-size:14px;color:var(--text-dim);margin:0}.profile-bio{font-size:14px;max-width:480px;text-align:center;margin:6px 0 0;line-height:1.55;color:var(--text)}.stats{display:grid;grid-template-columns:repeat(3,1fr);border:var(--hairline) solid var(--border);border-radius:var(--radius-md);margin:24px auto 0;max-width:520px;background:var(--surface)}.stats>div{padding:18px 12px;text-align:center}.stats>div+div{border-left:var(--hairline) solid var(--border-soft)}.stat-num{font-size:22px;font-weight:600;letter-spacing:-.01em}.stat-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}.rail{margin-top:32px}.rail-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}.rail-head h3{font-size:15px;font-weight:600;margin:0;letter-spacing:-.005em}.rail-head a{font-size:13px;color:var(--text-dim)}.rail-track{grid-gap:8px;gap:8px}.rail-track .photo-tile{width:120px;height:120px;aspect-ratio:1;border-radius:10px}.notif-list{display:flex;flex-direction:column;gap:0}.notif-row{display:flex;align-items:center;gap:14px;padding:16px 0;border-bottom:var(--hairline) solid var(--border-soft);position:relative}.notif-row.unread:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:var(--accent)}.notif-body{flex:1 1;min-width:0}.notif-text{font-size:14px}.notif-text strong{font-weight:600}.notif-time{font-size:12px;color:var(--text-dim);margin-top:2px}.notif-actions{display:flex;gap:6px}.sheet-backdrop{position:fixed;inset:0;background:rgba(14,14,16,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;display:flex;align-items:center;justify-content:center}.sheet{background:var(--surface);border:var(--hairline) solid var(--border);border-radius:var(--radius-xl);padding:32px;width:100%;max-width:420px;box-shadow:0 0 0 1px var(--border-soft)}.sheet h3{font-size:17px;font-weight:600;margin:0 0 6px}.sheet p{font-size:13px;color:var(--text-dim);margin:0 0 20px;line-height:1.5}.sheet-actions{display:flex;flex-direction:column-reverse;gap:8px}.h1{font-size:28px;letter-spacing:-.02em}.h1,.h2{font-weight:600;margin:0}.h2{font-size:20px;letter-spacing:-.015em}.muted{color:var(--text-dim)}.center{text-align:center}.stack-12{gap:12px}.stack-12,.stack-16{display:flex;flex-direction:column}.stack-16{gap:16px}.stack-24{display:flex;flex-direction:column;gap:24px}.row-flex{display:flex;align-items:center;gap:12px}.between{justify-content:space-between}.wrap{flex-wrap:wrap}.spacer{flex:1 1}.hidden{display:none!important}.mobile-nav{position:fixed;left:0;right:0;bottom:0;height:64px;padding-bottom:env(safe-area-inset-bottom,0);background:var(--surface);border-top:var(--hairline) solid var(--border);display:none;z-index:40}.mobile-nav-track{display:flex;width:100%;height:100%}.mobile-nav-track .mobile-nav-item{flex:1 1;min-width:0}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text-dim);font-size:10px;font-weight:500;letter-spacing:-.005em;position:relative}.mobile-nav-item .icon{width:22px;height:22px;opacity:.85}.mobile-nav-item.active{color:var(--text)}.mobile-nav-item.active .icon{opacity:1}.mobile-nav-item.active:after{content:"";position:absolute;top:6px;width:28px;height:3px;border-radius:2px;background:var(--accent)}.fab{position:fixed;right:18px;bottom:calc(76px + env(safe-area-inset-bottom, 0));width:56px;height:56px;border-radius:50%;background:var(--accent);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(90,72,104,.35),0 0 0 1px var(--border);z-index:30;transition:transform .12s}.fab:hover{transform:scale(1.04)}.fab:active{transform:scale(.96)}@media (max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.mobile-nav{display:block}.main{grid-column:1/-1}.topbar{padding:0 16px;height:56px;gap:10px;overflow:hidden}.topbar-title{font-size:18px;flex-shrink:0;max-width:35vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-spacer{display:none}.topbar-search{width:auto;max-width:none;flex:1 1;min-width:0}.topbar-search input{min-width:0;width:100%}.topbar .btn{flex-shrink:0}.content{padding:16px 16px 96px}.content-wide{padding:12px 0 96px}.photo-grid{gap:2px}.albums-grid,.photo-grid{grid-template-columns:repeat(3,1fr)}.albums-grid{gap:12px;padding:0 16px}.album-name{font-size:12px}.album-count{font-size:11px}.notif-list{padding:0 4px}.sheet{padding:24px;max-width:calc(100vw - 32px)}.sheet-backdrop{align-items:flex-end;padding-bottom:12px}.sheet{border-radius:20px}.invite-code{font-size:36px;padding:18px 16px}}@media (max-width:480px){.photo-grid{grid-template-columns:repeat(3,1fr);gap:1px}.albums-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding:0 14px}}.subtabs{display:flex;gap:4px;padding:8px 16px 0;border-bottom:var(--hairline) solid var(--border);background:var(--bg);position:-webkit-sticky;position:sticky;top:56px;z-index:4}.subtab{font-size:14px;font-weight:500;color:var(--text-dim);padding:12px 14px;position:relative;letter-spacing:-.005em}.subtab.active{color:var(--text)}.subtab.active:after{content:"";position:absolute;left:14px;right:14px;bottom:-1px;height:2px;background:var(--accent);border-radius:2px}.memory-hero{border-radius:var(--radius-lg);background:var(--placeholder);aspect-ratio:16/10;background-size:cover;background-position:50%;margin:0 0 12px;border:var(--hairline) solid var(--border)}.memory-meta{display:flex;flex-direction:column;gap:2px;margin-bottom:28px}.memory-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.memory-title{font-size:18px;font-weight:600;letter-spacing:-.01em}.memory-chip{display:inline-flex;align-items:center;background:var(--surface-2);border:var(--hairline) solid var(--border);border-radius:999px;padding:2px 10px;font-size:11px;color:var(--text-dim)}.memory-date{font-size:13px;color:var(--text-dim)}.memory-grid{display:grid;grid-gap:10px;gap:10px;grid-template-columns:1fr 1fr}.memory-card{display:flex;flex-direction:column;gap:6px}.memory-card .thumb{aspect-ratio:1;background:var(--placeholder);border-radius:var(--radius-md);border:var(--hairline) solid var(--border-soft)}.memory-card .name{font-size:13px;font-weight:600;letter-spacing:-.005em}.memory-card .sub{font-size:11px;color:var(--text-dim)}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);background:var(--surface);border:var(--hairline) solid var(--border);border-radius:var(--radius-md);margin:16px 0 24px;overflow:hidden}.profile-stat{padding:14px 8px;text-align:center}.profile-stat+.profile-stat{border-left:var(--hairline) solid var(--border-soft)}.profile-stat-num{font-size:18px;font-weight:600;letter-spacing:-.01em}.profile-stat-label{font-size:11px;color:var(--text-dim);margin-top:2px;letter-spacing:.02em;text-transform:uppercase}.rail-track{display:grid;grid-auto-flow:column;grid-auto-columns:120px;grid-gap:6px;gap:6px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:4px}.rail-track>*{scroll-snap-align:start}.album-thumb.has-cover{background:var(--placeholder);background-size:cover;background-position:50%}.save-toast{position:fixed;left:50%;bottom:calc(100px + env(safe-area-inset-bottom, 0));transform:translateX(-50%);display:flex;align-items:center;gap:8px;background:var(--text);color:var(--bg);padding:10px 18px;border-radius:999px;font-size:13px;font-weight:600;letter-spacing:-.005em;box-shadow:0 8px 24px rgba(14,14,16,.18);z-index:60;animation:toast-in .2s ease-out}.save-toast-tick{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--accent);color:var(--accent-ink);font-size:11px;font-weight:700}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,6px)}to{opacity:1;transform:translate(-50%)}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}.tap{transition:transform .12s cubic-bezier(.2,.7,.2,1),opacity .12s}.tap:active{transform:scale(.97)}.tap:hover{opacity:.94}.btn{transition:transform .1s cubic-bezier(.2,.7,.2,1),background .12s,color .12s,opacity .12s,box-shadow .16s}.btn:not([disabled]):active{transform:scale(.97)}.btn:not([disabled]):hover{transform:translateY(-.5px)}.mobile-nav-item{transition:color .16s,transform .12s cubic-bezier(.2,.7,.2,1)}.mobile-nav-item:active{transform:scale(.94)}.mobile-nav-item.active .icon{animation:nav-bounce .28s cubic-bezier(.2,.9,.3,1.4)}@keyframes nav-bounce{0%{transform:translateY(0) scale(1)}35%{transform:translateY(-2px) scale(1.08)}to{transform:translateY(0) scale(1)}}.sheet-backdrop{animation:backdrop-in .18s ease-out both}.sheet,.sheet-card,.sheet-content{animation:sheet-in .22s cubic-bezier(.2,.85,.25,1) both}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes sheet-in{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.album-thumb img,.tile-img,img[data-fade]{opacity:0;transition:opacity .32s ease}.album-thumb img.loaded,.tile-img.loaded,img[data-fade].loaded{opacity:1}.album-card{transition:transform .16s cubic-bezier(.2,.7,.2,1),box-shadow .16s}@media (hover:hover){.album-card:hover{transform:translateY(-2px)}}.album-card:active{transform:scale(.985)}.avatar{transition:transform .16s ease}@media (hover:hover){.avatar:hover{transform:scale(1.04)}}.heart-pop{animation:heart-pop .38s cubic-bezier(.2,.9,.3,1.4)}@keyframes heart-pop{0%{transform:scale(1)}35%{transform:scale(1.35)}60%{transform:scale(.95)}to{transform:scale(1)}}.page-fade-in{animation:page-fade-in .22s ease-out both}@keyframes page-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.skeleton{position:relative;overflow:hidden;background:var(--surface-2,rgba(0,0,0,.05))}.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.45) 50%,transparent);animation:shimmer 1.6s infinite;transform:translateX(-100%)}@keyframes shimmer{to{transform:translateX(100%)}}.fade-in{animation:fade-in .24s ease-out both}@keyframes fade-in{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}.notif-row.unread:after{animation:dot-pulse 1.6s ease-in-out infinite}@keyframes dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.85)}}