:root{--bg:#f6f7f8;--ink:#141517;--muted:#777d87;--panel:#ffffffdb;--line:#1415171a;--line-strong:#1415172e;--shadow:0 18px 50px #181c2429;--radius:18px;color:var(--ink);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}[hidden]{display:none!important}body{min-width:320px;min-height:100svh;margin:0;overflow:hidden}button,input{font:inherit}button{cursor:pointer}svg{stroke-width:2px;width:17px;height:17px;display:block}.shell{background:radial-gradient(circle, #14151729 1px, transparent 1.4px), var(--bg);background-size:22px 22px;width:100vw;height:100svh;position:relative;overflow:hidden}.canvas{z-index:1;cursor:grab;touch-action:none;position:absolute;inset:0;overflow:hidden}.shell.is-dragging-card .canvas{z-index:30}.canvas.is-panning{cursor:grabbing}.world{transform-origin:0 0;will-change:transform;width:1px;height:1px;position:absolute;top:0;left:0}.chrome{z-index:20;opacity:0;pointer-events:none;align-items:center;gap:8px;width:min(930px,100vw - 24px);transition:opacity .18s,transform .18s;display:flex;position:fixed;top:18px;left:50%;transform:translate(-50%)}.shell[data-view=focus] .chrome{opacity:1;pointer-events:auto;width:auto;top:14px;left:auto;right:14px;transform:none}.shell[data-view=focus] .add-form,.shell[data-view=focus] .search,.shell[data-view=focus] .zoom{display:none}.shell[data-view=focus] .views{position:static}.shell:hover .chrome,.shell.show-chrome .chrome,.chrome:focus-within{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}.add-form,.search,.zoom,.admin-controls,.status,.empty-state{border:1px solid var(--line);background:var(--panel);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:999px;box-shadow:0 10px 36px #181c2417}.shell.is-readonly .add-form{display:none}.admin-controls{align-items:center;gap:4px;padding:4px;display:flex}.admin-button{min-width:38px;min-height:38px;color:var(--ink);background:0 0;border:0;border-radius:999px;padding:0 10px;font-size:12px;font-weight:600}.admin-button:hover{background:#1415170f}.load-error{z-index:40;background:#f6f7f8eb;place-items:center;display:grid;position:fixed;inset:0}.load-error div{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow);text-align:center;justify-items:center;gap:12px;padding:24px 28px;display:grid}.load-error p{margin:0}.login-panel{width:min(360px,100vw - 32px)}.add-form,.search{align-items:center;gap:8px;min-height:44px;padding:0 8px 0 14px;display:flex}.add-form{isolation:isolate;border-radius:22px;flex:1.05;transition:border-radius .18s,box-shadow .18s;position:relative}.add-form:has(.tag-dropdown[aria-hidden=false]){border-bottom-right-radius:0;border-bottom-left-radius:0;box-shadow:0 18px 50px #181c241f}.search{flex:.85}.add-form input,.search input{width:100%;min-width:0;color:var(--ink);background:0 0;border:0;outline:0}.add-form input::placeholder,.search input::placeholder{color:#8b929d}.add-form>button,.zoom button,.empty-state button{background:var(--ink);color:#fff;border:0;border-radius:999px;flex:none;place-items:center;width:32px;height:32px;display:grid}.add-form.is-loading button{opacity:.45}.tag-dropdown{z-index:35;border:1px solid var(--line);background:var(--panel);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);opacity:0;pointer-events:none;border-top:0;border-radius:0 0 22px 22px;max-height:0;padding:0 8px;transition:max-height .22s cubic-bezier(.19,1,.22,1),opacity .15s,padding .22s cubic-bezier(.19,1,.22,1),transform .22s cubic-bezier(.19,1,.22,1),box-shadow .18s;position:absolute;top:calc(100% - 1px);left:-1px;right:-1px;overflow:hidden;transform:translateY(-10px);box-shadow:0 18px 50px #181c2400}.tag-dropdown[aria-hidden=false]{opacity:1;pointer-events:auto;max-height:310px;padding:11px 8px 8px;transform:translateY(0);box-shadow:0 18px 50px #181c2424}.tag-menu-button{border:1px solid var(--line);width:100%;min-height:34px;color:var(--ink);background:#ffffffd1;border-radius:999px;justify-content:space-between;align-items:center;gap:8px;padding:0 5px 0 12px;display:flex}.tag-menu-button span:first-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.tag-menu-button span:last-child{background:#14151714;border-radius:999px;flex:none;place-items:center;width:24px;height:24px;display:grid}.tag-menu-button[aria-expanded=true] span:last-child{rotate:45deg}.tag-menu{gap:8px;padding-top:8px;display:grid}.add-tag-list{gap:3px;max-height:150px;display:grid;overflow:auto}.add-tag-list button{min-height:32px;color:var(--ink);text-align:left;background:0 0;border:0;border-radius:10px;padding:0 10px}.add-tag-list button.active{background:var(--ink);color:#fff}.custom-tag{border:1px solid var(--line);background:#fff;border-radius:999px;align-items:center;gap:6px;min-height:36px;padding:0 4px 0 11px;display:flex}.custom-tag input{border:0;outline:0;width:100%;min-width:0}.custom-tag button{background:var(--ink);color:#fff;border:0;border-radius:999px;flex:none;place-items:center;width:28px;height:28px;display:grid}.zoom{gap:3px;padding:5px;display:flex}.zoom button,.views button{color:var(--ink);background:0 0}.zoom button:hover,.views button:hover,.views button.active,.card-buttons a:hover,.card-buttons button:hover{background:#14151712}.views{border:1px solid var(--line);background:var(--panel);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:999px;gap:3px;padding:5px;display:flex;box-shadow:0 10px 36px #181c2417}.views button{border:0;border-radius:999px;place-items:center;width:32px;height:32px;display:grid}.site-card{aspect-ratio:1.42;border-radius:var(--radius);width:340px;transform:translate3d(var(--x), var(--y), 0);-webkit-user-select:none;user-select:none;transition:box-shadow .18s,scale .18s;position:absolute;top:0;left:0}.site-card.is-dragging{z-index:35;cursor:grabbing;scale:1.02}.shell.is-locked .site-card{cursor:default}.shell.is-locked .site-card .card-shot{box-shadow:0 8px 24px #181c241a}.card-shot{border:1px solid var(--line-strong);border-radius:inherit;color:#fff;background:#e8ebef;width:100%;height:100%;transition:box-shadow .18s,transform .18s,border-color .18s;display:block;position:relative;overflow:hidden;box-shadow:0 10px 32px #181c241f}.site-card:hover .card-shot,.site-card.is-dragging .card-shot{box-shadow:var(--shadow);border-color:#14151742}.site-card img,.fallback{width:100%;height:100%;position:absolute;inset:0}.site-card img{z-index:1;object-fit:cover;object-position:top;background:#eceff2;transition:scale .42s,filter .18s}.site-card:hover img{filter:saturate(1.04)contrast(1.02);scale:1.025}.fallback{color:#7e8792;text-align:center;place-items:center;padding:24px;font-size:22px;font-weight:650;display:grid}.image-missing img{display:none}.label,.card-buttons{z-index:2;opacity:0;transition:opacity .16s,transform .16s;position:absolute}.label{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0c0d0fb8;border-radius:14px;gap:2px;min-width:0;padding:10px 12px;display:grid;bottom:10px;left:10px;right:10px;transform:translateY(6px)}.label strong,.label small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.label strong{font-size:14px;line-height:1.2}.label small{color:#ffffffb3;font-size:11px;line-height:1.3}.card-buttons{gap:6px;display:flex;top:10px;right:10px;transform:translateY(-4px)}.card-buttons button,.card-buttons a{color:#fff;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0c0d0fad;border:0;border-radius:999px;place-items:center;width:34px;height:34px;text-decoration:none;display:grid}.site-card:hover .label,.site-card:hover .card-buttons,.site-card:focus-within .label,.site-card:focus-within .card-buttons{opacity:1;transform:translateY(0)}.delete-zone{z-index:25;color:#b42318;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);opacity:0;pointer-events:none;background:radial-gradient(circle at 50% 0,#dc262629,#0000 56%),#ffffffd1;border:1px dashed #dc262661;border-radius:28px;place-items:center;height:clamp(120px,20vh,210px);transition:border-color .16s,color .16s,opacity .18s,transform .18s,background .18s;display:grid;position:fixed;bottom:18px;left:18px;right:18px;transform:translateY(36px)scale(.98);box-shadow:0 18px 60px #181c2424}.delete-zone div{justify-items:center;gap:5px;display:grid}.delete-zone svg{width:24px;height:24px}.delete-zone strong{font-size:17px;line-height:1.1}.delete-zone small{color:#b42318b8;font-size:12px}.delete-zone[aria-hidden=false]{opacity:1;transform:translateY(0)scale(1)}.delete-zone.is-hot{color:#fff;background:radial-gradient(circle at 50% 0,#ffffff38,#0000 58%),#dc2626;border-color:#dc2626db;transform:translateY(-4px)scale(1.01)}.delete-zone.is-hot small{color:#ffffffbd}.modal{z-index:40;pointer-events:none;background:#10121600;place-items:center;padding:20px;transition:background .16s;display:grid;position:fixed;inset:0}.modal[aria-hidden=false]{pointer-events:auto;background:#1012162e}.modal-panel{border:1px solid var(--line);width:min(420px,100%);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);opacity:0;background:#fffffff0;border-radius:22px;gap:14px;padding:18px;transition:opacity .16s,transform .16s;display:grid;transform:translateY(12px)scale(.98)}.modal[aria-hidden=false] .modal-panel{opacity:1;transform:translateY(0)scale(1)}.modal-head{justify-content:space-between;align-items:center;gap:14px;display:flex}.modal-head p{margin:0;font-size:18px;font-weight:650}.modal-head button{width:34px;height:34px;color:var(--ink);background:#1415170f;border:0;border-radius:999px;place-items:center;display:grid}.modal label{color:var(--muted);gap:7px;font-size:12px;display:grid}.modal input{border:1px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:12px;outline:0;padding:11px 12px}.modal input:focus{border-color:#4a7aff80;box-shadow:0 0 0 3px #4a7aff29}.modal-actions{gap:8px;margin-top:2px;display:flex}.save-button,.danger-button{border:0;border-radius:999px;flex:1;min-height:42px}.save-button{background:var(--ink);color:#fff}.danger-button{color:#b42318;background:#dc262614}.status{z-index:30;min-width:88px;min-height:34px;color:var(--muted);text-align:center;opacity:0;pointer-events:none;margin:0;padding:7px 14px;font-size:13px;transition:opacity .16s;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}.status:not(:empty){opacity:1}.empty-state{z-index:3;align-items:center;gap:10px;min-height:44px;padding:6px 6px 6px 16px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.empty-state p{color:var(--muted);margin:0}.empty-state button{width:auto;padding:0 13px}.list-view,.collection-view,.focus-view{padding:92px 22px 28px;position:absolute;inset:0;overflow:auto}.list-view{align-content:start;gap:8px;width:min(920px,100%);margin:0 auto;display:grid}.list-row{border:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffb8;border-radius:18px;grid-template-columns:72px minmax(0,1fr) minmax(120px,.7fr) 34px 34px 34px;align-items:center;gap:12px;min-height:72px;padding:7px 9px 7px 7px;display:grid}.list-row img{object-fit:cover;object-position:top;background:#e8ebef;border-radius:13px;width:72px;height:56px}.list-row div{gap:3px;min-width:0;display:grid}.list-row strong,.list-row span,.list-row small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.list-row span,.list-row small{color:var(--muted);font-size:12px}.list-row button,.list-row a{width:34px;height:34px;color:var(--ink);background:#1415170f;border:0;border-radius:999px;place-items:center;display:grid}.list-row a{text-decoration:none}.collection-view{grid-template-columns:repeat(2,minmax(280px,1fr));gap:18px;max-width:1120px;margin:0 auto;display:grid}.collection-card{align-content:start;gap:10px;display:grid}.collection-shot{aspect-ratio:1.5;border:1px solid var(--line-strong);border-radius:var(--radius);background:#e8ebef;width:100%;padding:0;display:block;overflow:hidden;box-shadow:0 10px 32px #181c241a}.collection-shot img{object-fit:cover;object-position:top;width:100%;height:100%}.collection-card div{gap:3px;padding:0 4px;display:grid}.collection-card strong{font-size:14px}.collection-card span{color:var(--muted);font-size:12px;line-height:1.35}.focus-view{padding:0;overflow:hidden}.focus-frame{background:#e8ebef;border:0;border-radius:0;width:100%;height:100%;position:relative;overflow:hidden}.focus-frame iframe,.focus-snapshot{width:100%;height:100%;position:absolute;inset:0}.focus-frame iframe{z-index:2;background:#fff;border:0}.focus-snapshot{z-index:1;object-fit:contain;object-position:top;background:#fff}.focus-bar{z-index:22;border:1px solid var(--line);background:var(--panel);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:999px;align-items:center;gap:8px;min-height:48px;padding:6px;display:flex;position:fixed;bottom:18px;left:50%;transform:translate(-50%);box-shadow:0 10px 36px #181c241a}.focus-bar div{text-align:center;min-width:170px;padding:0 8px;display:grid}.focus-bar strong{text-overflow:ellipsis;white-space:nowrap;max-width:220px;overflow:hidden}.focus-bar span{color:var(--muted);font-size:11px}.focus-bar button,.focus-bar a{background:var(--ink);color:#fff;border:0;border-radius:999px;place-items:center;width:36px;height:36px;padding:0;text-decoration:none;display:grid}button:focus-visible,a:focus-visible,input:focus-visible{outline-offset:2px;outline:3px solid #4a7aff47}@media (width<=760px){.chrome{opacity:1;pointer-events:auto;flex-wrap:wrap;width:calc(100vw - 20px);top:10px}.add-form,.search{flex:100%}.zoom{display:none}.site-card{width:265px}.collection-view{grid-template-columns:1fr;padding-top:116px}.list-view{padding-top:116px}.list-row{grid-template-columns:64px minmax(0,1fr) 34px 34px}.list-row small,.list-row button[data-focus]{display:none}.focus-view{padding:0}.focus-bar{justify-content:space-between;width:calc(100vw - 20px)}.focus-bar div{min-width:0}}
