:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;width:100%;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.app-root{min-height:100vh;width:100%;position:relative;overflow:hidden}.app-background-layer{position:fixed;inset:0;z-index:0;pointer-events:none;width:100%;height:100%}.app-main{position:relative;z-index:1}.app-root.theme-bg-classic{background:radial-gradient(circle at 0% 0%,rgba(255,255,255,.25),transparent 55%),radial-gradient(circle at 100% 100%,rgba(0,0,0,.12),transparent 55%),linear-gradient(135deg,#e8e6e1,#d6d3cd)}.app-root.theme-bg-dark{background:radial-gradient(circle at 20% 0%,rgba(255,255,255,.18),transparent 55%),radial-gradient(circle at 100% 100%,rgba(0,0,0,.6),transparent 60%),linear-gradient(145deg,#27211b,#1a1410)}.app-root.theme-bg-neon{background:repeating-linear-gradient(to right,rgba(0,255,200,.12) 0px,rgba(0,255,200,.12) 1px,transparent 1px,transparent 32px),repeating-linear-gradient(to bottom,rgba(0,255,200,.12) 0px,rgba(0,255,200,.12) 1px,transparent 1px,transparent 32px),radial-gradient(circle at 10% 0%,rgba(255,0,200,.35),transparent 55%),radial-gradient(circle at 90% 100%,rgba(0,180,255,.4),transparent 55%),radial-gradient(circle at 50% 120%,rgba(255,255,255,.18),transparent 55%),linear-gradient(145deg,#050510,#050510)}.display-mode-active{cursor:pointer}.display-mode-active .app-main{transform-origin:center center;will-change:transform}.display-mode-overlay{position:fixed;inset:0;z-index:9999;background:transparent;cursor:pointer}.display-mode-notification{position:fixed;bottom:40px;left:50%;transform:translate(-50%);z-index:10000;pointer-events:none;animation:slideInUp .5s ease-out,fadeOut .5s ease-in 3.5s forwards}.notification-content{background:#000000d9;color:#fff;padding:16px 24px;border-radius:12px;display:flex;align-items:center;gap:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0000004d}.notification-icon{font-size:20px;line-height:1}.notification-text{font-size:14px;line-height:1.3;text-align:left}.notification-text strong{font-weight:600}@keyframes slideInUp{0%{transform:translate(-50%,100%);opacity:0}to{transform:translate(-50%);opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.site-header{position:fixed;top:0;left:0;right:0;height:56px;display:flex;align-items:center;padding:0 12px;z-index:1000;contain:layout style}.site-header.header-inactive{pointer-events:none;opacity:.4}.header-surface{position:fixed;top:8px;left:8px;display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:12px;opacity:.7;transform:scale(1);transform-origin:left top;transition:transform .26s cubic-bezier(.2,.8,0,1),opacity .18s ease;z-index:1000}.header-surface:before{content:"";position:absolute;inset:0;background:#ffffffbf;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:12px;z-index:-1;pointer-events:none}.header-surface:hover,.header-surface.open{opacity:1;transform:scale(1.3);overflow:visible}.header-surface.open:before{right:-100px}.header-bar{position:relative;z-index:2;display:flex;align-items:center;gap:12px}.header-logo{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px}.header-logo img{width:100%;height:100%;display:block}.menu-button{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:transparent;border:none;cursor:pointer;padding:0;transition:transform .2s ease}.menu-button:hover{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.menu-button .hamburger{position:relative;width:22px;height:2px;background:#111;border-radius:2px;transition:background .2s ease}.menu-button .hamburger:before,.menu-button .hamburger:after{content:"";position:absolute;left:0;width:22px;height:2px;background:#111;border-radius:2px;transition:transform .28s cubic-bezier(.2,.8,0,1)}.menu-button .hamburger:before{top:-7px}.menu-button .hamburger:after{top:7px}.menu-button[aria-expanded=true] .hamburger{background:transparent}.menu-button[aria-expanded=true] .hamburger:before{transform:rotate(45deg);top:0}.menu-button[aria-expanded=true] .hamburger:after{transform:rotate(-45deg);top:0}@media(prefers-color-scheme:dark){.header-surface:before{background:#1e1e1ebf}.menu-button .hamburger,.menu-button .hamburger:before,.menu-button .hamburger:after{background:#e0e0e0}.menu-button[aria-expanded=true] .hamburger{background:transparent}.menu-items{color:#e0e0e0}}.menu-items{position:relative;height:40px;padding:0;display:flex;align-items:center;gap:16px;color:#111;max-width:0;opacity:0;overflow:visible;transition:max-width .42s cubic-bezier(.2,.8,0,1),opacity .3s ease,padding .42s cubic-bezier(.2,.8,0,1)}.menu-items.visible{max-width:350px;opacity:1;padding:0 12px;overflow:visible}.menu-item{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;height:40px;width:70px;cursor:pointer;z-index:1;pointer-events:auto;overflow:visible;flex-shrink:0}.menu-item.onboarding-dimmed{opacity:.28;filter:grayscale(.1);transition:opacity .2s ease}.menu-item.onboarding-focused{opacity:1}.menu-item.onboarding-pulse{animation:onboarding-menu-pulse 1.2s ease-in-out infinite}.dropdown-item--coffee{display:flex;align-items:center;gap:8px}.dropdown-item--coffee .coffee-heart-icon{color:#ff4d4d;font-size:16px;animation:coffee-heart-pulse 1.15s ease-in-out infinite}@keyframes coffee-heart-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}@media(prefers-reduced-motion:reduce){.dropdown-item--coffee .coffee-heart-icon{animation:none}}@keyframes onboarding-menu-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.menu-item-button{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background:none;border:none;cursor:pointer;padding:0;position:relative}.dropdown-menu{position:absolute;top:calc(100% + 12px);left:50%;transform:translate(-50%) translateZ(0);background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:8px;padding:4px;min-width:140px;box-shadow:0 4px 12px #0000001a;z-index:1002;animation:dropdownFadeIn .2s ease;will-change:transform,opacity}@keyframes dropdownFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.dropdown-item{display:block;padding:8px 12px;font-size:11px;font-weight:600;color:#111;text-decoration:none;border-radius:6px;transition:background .12s ease;white-space:nowrap}.dropdown-item:hover{background:#0000000f}.dropdown-item.active{background:#0000001a;font-weight:700}.dropdown-divider{height:1px;background:#0000001a;margin:4px 0}.dropdown-item-icon{display:flex;align-items:center;gap:8px}.dropdown-item-icon svg{font-size:12px}.menu-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:20px;transition:transform .16s ease;pointer-events:none;margin-bottom:4px}.menu-icon.material-symbols-outlined{color:#111;font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24}.menu-label{position:absolute;bottom:4px;left:50%;transform:translate(-50%);font-size:11px;line-height:1.1;color:#111;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .16s ease;z-index:10;font-weight:600}.menu-item.show-label .menu-label{opacity:1!important}.menu-item.show-label .menu-icon{transform:translateY(-6px)!important}.header-backdrop{position:fixed;inset:0;background:transparent;z-index:999}@media(max-width:1024px){.header-surface{flex-direction:column;align-items:flex-start;padding:6px;transition:transform .26s cubic-bezier(.2,.8,0,1),opacity .18s ease,padding .26s ease}.header-surface.open{padding:8px}.header-surface.open:before{right:0}.header-bar{width:100%;justify-content:flex-start}.header-surface.open .header-bar{justify-content:space-between}.menu-items{display:none;flex-direction:column;height:auto;max-height:0;max-width:none;width:100%;padding:0;gap:4px;margin-top:0;align-items:flex-start}.menu-items.visible{display:flex;max-height:300px;max-width:none;padding:8px;margin-top:8px;animation:slideDown .42s cubic-bezier(.2,.8,0,1)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.menu-item{width:100%;height:auto;flex-direction:row;justify-content:flex-start;gap:0;padding:0;align-items:center;z-index:auto;position:relative}.menu-item-button{flex-direction:row;padding:8px;height:44px;flex-shrink:0;justify-content:flex-start;align-items:center;gap:10px;text-align:left}.dropdown-menu{position:absolute;left:auto;right:-4px;top:calc(100% + 4px);transform:none;margin-left:0;width:auto;min-width:140px;max-width:calc(100vw - 24px);z-index:9999;animation:dropdownSlideDown .2s ease}@keyframes dropdownSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.menu-icon{margin-bottom:0;margin-right:0;z-index:1}.menu-label{position:static;transform:none;opacity:1!important;font-size:11px;font-weight:600;z-index:1}.menu-item.show-label .menu-icon{transform:none!important}.dropdown-item.active{background:#0000001a;font-weight:700}}@media(prefers-color-scheme:dark){.menu-items,.menu-item,.menu-icon,.material-symbols-outlined,.menu-label{color:#edf2f7!important}.dropdown-menu{background:#1e1e1ef2!important;border:1px solid rgba(255,255,255,.1);color:#edf2f7!important}.dropdown-item{color:#edf2f7!important}.dropdown-item:hover,.dropdown-item.active{background:#ffffff1a!important}.menu-button .hamburger,.menu-button .hamburger:before,.menu-button .hamburger:after{background:#edf2f7!important}.menu-button[aria-expanded=true] .hamburger{background:transparent!important}}.login-container{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;z-index:6000;background-image:url(/loginbg.png);background-size:cover;background-position:center;background-repeat:no-repeat;overflow:hidden}.login-container:before{content:"";position:absolute;inset:0;background:#0006;pointer-events:none}.login-box{position:relative;z-index:1;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;padding:32px;width:100%;max-width:420px;box-shadow:0 16px 40px #00000026}.login-logo{display:flex;align-items:center;justify-content:center;margin-bottom:8px}.login-box h1{margin:0 0 6px;font-size:24px}.login-box p{margin:0 0 16px;color:#666;font-weight:500}.login-form{display:flex;flex-direction:column;gap:12px}.login-label{display:flex;flex-direction:column;gap:6px;font-weight:600}.login-label input{padding:12px 14px;font-size:14px;border-radius:10px;border:2px solid rgba(0,0,0,.12)}.login-error{background:#ffe6e6;color:#a40000;border:1px solid #ffb3b3;padding:10px 12px;border-radius:10px}.login-info{background:#e7f7e7;color:#0a6b2a;border:1px solid #b3e6b3;padding:10px 12px;border-radius:10px}.login-button{margin-top:4px;padding:12px 18px;font-weight:700;color:#fff;background:#111;border:none;border-radius:10px;cursor:pointer}.login-button:hover{background:#333}.login-actions{display:flex;gap:12px;align-items:center}.login-secondary-actions{display:flex;align-items:center;justify-content:center;margin-top:4px}.login-link{background:transparent;border:none;color:#333;text-decoration:underline;cursor:pointer;padding:8px 0}@media(prefers-color-scheme:dark){.login-box{background:#1e1e1ef2;color:#e0e0e0}.login-box h1{color:#fff}.login-box p{color:#aeaeae}.login-label input{background:#ffffff14;color:#fff;border-color:#fff3}.login-link{color:#bbb}}.create-first-shelf-container{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;z-index:5000;contain:layout style paint;will-change:opacity}.create-first-shelf-box{position:relative;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;padding:40px;max-width:480px;width:100%;box-shadow:0 8px 24px #0000001a;text-align:center}.close-button{position:absolute;top:16px;right:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#0000000d;border:none;border-radius:8px;font-size:18px;line-height:1;color:#666;cursor:pointer;z-index:2;padding:0;transition:background .2s ease,color .2s ease}.close-button:hover{background:#0000001a;color:#111}@media(prefers-color-scheme:dark){.create-first-shelf-box{background:#1e1e1ef2;color:#e0e0e0}.create-first-shelf-box h1{color:#fff}.create-first-shelf-box p{color:#aeaeae}.create-first-icon-picker button{background:#ffffff1a;color:#fff;border-color:#fff3}.create-first-icon-picker button:hover{background:#fff3}.shelf-input-group label{color:#ccc}.shelf-input-group input{background:#ffffff1a;color:#fff;border-color:#fff3}.close-button{background:#ffffff1a;color:#ddd}.close-button:hover{background:#fff3;color:#fff}}.create-first-shelf-box h1{font-size:28px;font-weight:700;color:#111;margin:0 0 12px}.create-first-shelf-box p{font-size:14px;font-weight:600;color:#666;margin:0 0 32px;line-height:1.5}.create-first-shelf-box form{display:flex;flex-direction:column;gap:16px}.create-first-shelf-box input{padding:14px 16px;font-size:14px;font-weight:600;border:2px solid rgba(0,0,0,.1);border-radius:10px;background:#ffffffe6;color:#111;transition:border-color .2s ease,background .2s ease}.create-first-shelf-box input:focus{outline:none;border-color:#111;background:#fff}.create-first-shelf-box form button{padding:14px 24px;font-size:14px;font-weight:600;color:#fff;background:#111;border:none;border-radius:10px;cursor:pointer;transition:background .2s ease,opacity .2s ease}.create-first-shelf-box form button:hover:not(:disabled){background:#333}.create-first-shelf-box form button:disabled{opacity:.4;cursor:not-allowed}@media(max-width:600px){.create-first-shelf-box{padding:32px 24px}.create-first-shelf-box h1{font-size:24px}.create-first-shelf-box p{font-size:13px}}.manage-objects-container{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;z-index:2000;background:#0000004d;contain:layout style paint;will-change:opacity}.manage-objects-box{position:relative;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;padding:40px;max-width:900px;width:100%;max-height:80vh;min-height:520px;box-shadow:0 8px 24px #0000001a;display:flex;flex-direction:column}.manage-objects-box,.manage-objects-box *{box-sizing:border-box}.manage-objects-box .close-button{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:8px;border:none;background:#0000000a;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;line-height:1;color:#333;padding:0;transition:background .16s ease,transform .16s ease}.manage-objects-box .onboarding-pulse{animation:onboarding-pulse 1.1s ease-in-out infinite}@keyframes onboarding-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.09)}}.manage-objects-box .close-button:hover{background:#0000001a;animation:close-pulse 1.4s ease-in-out infinite}@media(prefers-color-scheme:dark){.manage-objects-box{background:#1e1e1ef2;color:#e0e0e0}.manage-objects-box h1{color:#fff}.manage-objects-box p{color:#aeaeae}.manage-objects-box .close-button{background:#ffffff1a;color:#fff}.manage-objects-box .close-button:hover{background:#fff3}.manage-search input{background:#ffffff1a;color:#fff;border-color:#fff3}.manage-search .search-icon{color:#ffffff80}.manage-search .search-clear-btn{background:#ffffff1a;color:#ffffffb3}.manage-search .search-clear-btn:hover{background:#fff3;color:#fff}}@keyframes close-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}.manage-objects-box h1{font-size:28px;font-weight:700;color:#111;margin:0 0 8px}.manage-objects-box>p{font-size:14px;font-weight:600;color:#666;margin:0 0 24px}.manage-search{margin:-8px 0 20px;display:flex;flex-shrink:0}.manage-search--mobile{display:none}.manage-search .search-with-icon{position:relative;width:100%;max-width:420px}.manage-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#00000059;pointer-events:none}.manage-search input{width:100%;padding:10px 38px;font-size:13px;font-weight:600;border:2px solid rgba(0,0,0,.1);border-radius:10px;background:#ffffffe6;transition:border-color .2s ease}.manage-search .search-clear-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:none;border-radius:8px;background:#0000000d;color:#0000008c;cursor:pointer;padding:0;line-height:1;font-size:16px;transition:background .2s ease,color .2s ease}.manage-search .search-clear-btn:hover{background:#0000001a;color:#000000bf}.manage-search input:focus{outline:none;border-color:#111}.manage-content{display:flex;gap:24px;flex:1;overflow:hidden}.folders-sidebar{width:200px;flex-shrink:0;display:flex;flex-direction:column;gap:12px}.folders-header{display:flex;align-items:center;justify-content:space-between}.folders-header h3{font-size:14px;font-weight:700;color:#111;margin:0}.folders-select-row{display:none}.folder-row{display:flex;align-items:center;gap:6px}.folder-row.has-delete{position:relative}.folder-row .folder-item{flex:1}.folder-row.has-delete .folder-item{padding-right:46px}.folder-item-icon{margin-right:8px;flex-shrink:0}.folder-item-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-delete-btn{width:34px;height:34px;border-radius:8px;border:none;background:#0000000a;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1;padding:0;transition:background .16s ease,opacity .14s ease;flex-shrink:0}.folder-row.has-delete .folder-delete-btn{position:absolute;right:0;top:0;bottom:0;height:auto;opacity:0;pointer-events:none}.folder-row.has-delete:hover .folder-delete-btn,.folder-row.has-delete .folder-delete-btn.is-visible{opacity:1;pointer-events:auto}.folder-delete-btn:hover{background:#0000001a}.folders-select{width:100%;height:40px;padding:8px 12px;font-size:13px;font-weight:600;border:2px solid rgba(0,0,0,.1);border-radius:10px;background:#ffffffe6;color:#111}.folders-select:focus{outline:none;border-color:#111}.new-folder-btn{margin-top:8px;width:100%;height:36px;border-radius:8px;border:none;background:#0000000a;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#333;padding:0;transition:background .16s ease}.new-folder-btn:hover{background:#0000001a}.new-folder-btn-wrap{position:relative}.first-folder-tooltip{margin-top:10px;width:100%;position:relative;background:#000000d9;color:#fffffff2;border-radius:10px;padding:12px 30px 12px 12px;box-shadow:0 10px 30px #00000059;animation:first-folder-tip-in .22s ease-out;transform:translateY(0);transition:transform .18s ease,box-shadow .18s ease}.first-folder-tooltip:hover{transform:translateY(-2px);box-shadow:0 14px 34px #00000061}.first-folder-tooltip:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid rgba(0,0,0,.85)}@keyframes first-folder-tip-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.first-folder-tooltip-text{font-size:12px;font-weight:600;line-height:1.3;flex:1}.first-folder-tooltip-close{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:6px;border:none;background:transparent;color:#ffffffe6;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;font-size:12px;padding:0}.first-folder-tooltip-close:hover{color:#fff;background:#ffffff14}.new-folder-label{display:inline-block}.new-folder-btn:hover .new-folder-label{animation:close-pulse 1.4s ease-in-out infinite}.new-folder-input{display:flex;gap:4px}.new-folder-input input{flex:1;padding:6px 8px;font-size:12px;font-weight:600;border:2px solid rgba(0,0,0,.1);border-radius:6px;background:#ffffffe6;color:#111}.new-folder-input input:focus{outline:none;border-color:#111}.new-folder-input button{width:28px;height:28px;border:none;background:#111;color:#fff;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;line-height:1}.new-folder-confirm-btn{width:28px;height:28px;border:none;background:#111;color:#fff;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;line-height:1;padding:0}.new-folder-confirm-btn svg{color:#fff!important}.new-folder-confirm-btn svg path{fill:#fff!important;stroke:#fff!important}.folders-list{display:flex;flex-direction:column;gap:4px;overflow-y:auto}.folder-divider{height:1px;background:#0000001a;margin:6px 4px;flex-shrink:0}.folder-item{padding:8px 12px;font-size:13px;font-weight:600;color:#111;background:transparent;border:none;border-radius:8px;text-align:left;cursor:pointer;transition:background .12s ease}.folder-item:hover{background:#0000000f}.folder-item.active{background:#0000001a}.objects-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;border:2px dashed transparent;border-radius:12px;transition:all .2s ease}.objects-main.drag-over{border-color:#3b82f6;background:#3b82f605;transform:scale(.998)}.objects-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.upload-controls{display:inline-flex;align-items:center;gap:10px}.manage-view-toggle-switch{position:relative;height:40px;width:92px;border-radius:8px;border:1px solid rgba(0,0,0,.1);background:#ffffffe6;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:0 6px;cursor:pointer;transition:background .12s ease;margin-top:10px}.manage-view-toggle-switch:hover{background:#00000008}.manage-view-icon{position:relative;z-index:2;display:inline-flex;align-items:center;justify-content:center;color:#0000008c}.manage-view-toggle-switch.is-icons .manage-view-icon:first-child{color:#111}.manage-view-toggle-switch.is-list .manage-view-icon:last-child{color:#111}.manage-view-thumb{position:absolute;top:4px;left:4px;width:calc(50% - 4px);height:calc(100% - 8px);border-radius:6px;background:#00000014;z-index:1;transition:transform .16s cubic-bezier(.2,.8,0,1)}.manage-view-toggle-switch.is-list .manage-view-thumb{transform:translate(100%)}.library-count{position:absolute;right:20px;bottom:20px;z-index:6;pointer-events:none;font-size:12px;font-weight:700;color:#0009;background:#0000000a;border:1px solid rgba(0,0,0,.08);padding:6px 10px;border-radius:10px;line-height:1;white-space:nowrap}.library-count.near-limit{color:#ef4444f2;background:#ef444414;border-color:#ef444440}.library-count.at-limit{color:#ef4444f2;background:#ef44441f;border-color:#ef444459}.move-notification.error-notification{background:#ef4444f2;animation:notification-slide-up .3s ease,notification-fade-out .28s ease 3.6s forwards}@keyframes notification-fade-out{to{opacity:0;transform:translate(-50%) translateY(10px)}}.objects-header h3{font-size:16px;font-weight:700;color:#111;margin:0}.upload-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:40px;padding:0 20px;font-size:13px;font-weight:600;line-height:1;color:#fff;background:#111;border:1px solid transparent;border-radius:8px;margin-top:10px;cursor:pointer;transition:background .16s ease;white-space:nowrap}.upload-icon{flex-shrink:0;vertical-align:middle;margin:0!important;padding:0!important;display:block}.upload-button svg{display:block;margin:0!important}.upload-button .button-text{display:inline-block;vertical-align:middle}.upload-button.disabled{opacity:.5;cursor:not-allowed}.upload-button:hover{background:#333}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#999;position:relative}.empty-drop-zone{background:#00000003;border:2px dashed rgba(0,0,0,.1);border-radius:14px;padding:32px 24px;transition:all .3s ease;min-width:280px;text-align:center}.empty-drop-zone:hover{border-color:#3b82f6;background:#3b82f605;transform:translateY(-2px)}.upload-icon{font-size:48px;margin-bottom:16px;opacity:.7;transition:transform .3s ease}.empty-drop-zone:hover .upload-icon{transform:scale(1.1)}.drag-hint{margin-top:16px;padding:8px 16px;background:#3b82f61a;border-radius:20px;color:#3b82f6;font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px}.drag-hint-icon{animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}60%{transform:translateY(-2px)}}.objects-container{flex:1;overflow:hidden;display:flex;flex-direction:column}.drag-overlay{position:absolute;inset:0;background:#3b82f6f2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:12px;display:flex;align-items:center;justify-content:center;z-index:100;animation:dragOverlayFadeIn .2s ease}.drag-overlay-content{text-align:center;color:#fff;padding:32px;border-radius:16px;background:#ffffff1a;border:2px dashed rgba(255,255,255,.3)}.drag-icon{font-size:64px;margin-bottom:16px;animation:dragIconPulse 1s ease-in-out infinite alternate}.drag-text{font-size:18px;font-weight:700;margin:0 0 8px;color:#fff}.drag-subtext{font-size:14px;margin:0;opacity:.9;color:#fff}.folder-confirm-overlay{position:absolute;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:20;padding:20px}.folder-confirm-dialog{width:100%;max-width:420px;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(0,0,0,.08);box-shadow:0 18px 60px #00000040;padding:18px}.folder-confirm-title{font-size:16px;font-weight:800;color:#111;margin:0 0 8px}.folder-confirm-body{font-size:13px;font-weight:600;color:#000000b3;line-height:1.35}.folder-confirm-folder{margin-top:6px;color:#111}.folder-confirm-warning{margin-top:8px}.folder-confirm-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}.folder-confirm-cancel,.folder-confirm-delete{height:36px;padding:0 14px;border-radius:10px;border:none;font-size:13px;font-weight:700;cursor:pointer}.folder-confirm-cancel{background:#0000000f;color:#111}.folder-confirm-cancel:hover{background:#0000001a}.folder-confirm-delete{background:#ef4444f2;color:#fff}.folder-confirm-delete:hover{background:#ef4444}@keyframes dragOverlayFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes dragIconPulse{0%{transform:scale(1)}to{transform:scale(1.1)}}.empty-state p{margin:0;font-size:14px;font-weight:600}.empty-hint{font-size:12px!important;margin-top:4px!important}.objects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px;overflow-y:auto;padding:4px}.objects-grid.list{display:flex;flex-direction:column;gap:10px}.objects-grid.list .object-card{flex-direction:row;align-items:center;gap:10px;padding:10px}.objects-grid.list .object-image{width:44px;height:44px;aspect-ratio:auto;flex-shrink:0}.objects-grid.list .object-info{flex:1}.objects-grid.list .object-name{font-size:13px}.object-card{display:flex;flex-direction:column;gap:8px;background:#fffc;border-radius:12px;padding:12px;transition:transform .12s ease,box-shadow .12s ease}.object-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.object-image{aspect-ratio:1;background:#00000005;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden}.object-image img{width:100%;height:100%;object-fit:contain}.object-info{display:flex;align-items:center;justify-content:space-between;gap:8px}.object-name{font-size:11px;font-weight:600;color:#111;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.delete-object-btn{background:none;border:none;font-size:14px;cursor:pointer;opacity:.5;transition:opacity .12s ease;padding:2px}.delete-object-btn:hover{opacity:1}.object-card.dragging{opacity:.4;transform:scale(.95);cursor:grabbing}.folder-item.drag-hover{background:#3b82f626;border-color:#3b82f680;transform:scale(1.02)}.move-notification{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#22c55ef2;color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;box-shadow:0 4px 12px #00000026;animation:notification-slide-up .3s ease;z-index:10;contain:layout style paint;will-change:transform,opacity}@keyframes notification-slide-up{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:768px){.manage-objects-container{padding:0}.manage-objects-box{width:100%;height:100vh;height:100dvh;max-width:none;max-height:none;min-height:0;border-radius:0;padding:20px;padding-top:calc(20px + env(safe-area-inset-top));padding-right:calc(20px + env(safe-area-inset-right));padding-bottom:calc(20px + env(safe-area-inset-bottom));padding-left:calc(20px + env(safe-area-inset-left))}.manage-objects-box .close-button{top:calc(16px + env(safe-area-inset-top));right:calc(16px + env(safe-area-inset-right))}.library-count{right:calc(20px + env(safe-area-inset-right));bottom:calc(20px + env(safe-area-inset-bottom))}.manage-content{flex-direction:column}.manage-search--desktop{display:none}.manage-search--mobile{display:flex;margin:0 0 12px}.folders-sidebar{width:100%}.folders-select-row{display:flex;align-items:center;gap:8px}.folders-list{display:none}.manage-search .search-with-icon{max-width:none}.objects-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.upload-button .button-text,.download-packs-button .button-text{display:none!important}.upload-button,.download-packs-button{padding:10px 12px!important;min-width:auto!important;width:40px!important;height:40px!important}.upload-icon,.download-packs-icon{margin:0!important}}@media(prefers-color-scheme:dark){.manage-search input{background:#282828f2!important;border-color:#ffffff26!important;color:#fff!important}.manage-search input:focus{border-color:#718096!important}.manage-search .search-icon{color:#fff9!important}.manage-search .search-clear-btn{background:#ffffff1a;color:#ffffffb3}.manage-search .search-clear-btn:hover{background:#fff3;color:#fff}.manage-objects-box h1,.manage-objects-box h2,.manage-objects-box h3,.folders-header h3,.object-name,.folder-item-text{color:#edf2f7!important}.manage-objects-box p,.object-count{color:#a0aec0!important}.manage-objects-box .close-button{background:#ffffff1a;color:#edf2f7}.manage-objects-box .close-button:hover{background:#fff3}.folder-delete-btn,.delete-object-btn{background:#ffffff1a!important;color:#edf2f7!important}.folder-delete-btn:hover,.delete-object-btn:hover{background:#ffffff40!important;color:#fff!important}.folder-item:hover{background:#ffffff0d}.object-card{background:#28282899!important;border:1px solid rgba(255,255,255,.1)}.object-card:hover{background:#323232cc!important;border-color:#fff3}.object-image{background:#0000004d!important;border:1px solid rgba(255,255,255,.05)}.new-folder-btn{background:#ffffff26!important;color:#edf2f7!important;border:1px solid rgba(255,255,255,.2)!important}.new-folder-btn:hover{background:#ffffff40!important;border-color:#ffffff59!important;color:#fff!important}.new-folder-label{color:#edf2f7!important}.folder-item{color:#edf2f7!important;background:transparent!important}.folder-item:hover{background:#ffffff14!important}.folder-item.active{background:#4299e140!important;color:#90cdf4!important}.folder-item-icon{color:#a0aec0!important}.folder-divider{background:#ffffff1a!important}.folders-select{background:#282828f2!important;border-color:#ffffff26!important;color:#edf2f7!important}.folders-select:focus{border-color:#718096!important}.new-folder-input input{background:#282828f2!important;border-color:#ffffff26!important;color:#fff!important}.new-folder-input button{background:#ffffff26!important;color:#edf2f7!important;border:1px solid rgba(255,255,255,.2)!important}.new-folder-input button:hover{background:#ffffff40!important}.manage-view-toggle-switch{background:#282828e6!important;border-color:#fff3!important}.manage-view-toggle-switch:hover{background:#323232e6!important}.manage-view-icon{color:#ffffff80!important}.manage-view-toggle-switch.is-icons .manage-view-icon:first-child,.manage-view-toggle-switch.is-list .manage-view-icon:last-child{color:#fff!important}.manage-view-thumb{background:#ffffff26!important}.upload-button{background:#ffffff26!important;color:#fff!important;border:1px solid rgba(255,255,255,.25)!important}.upload-button:hover:not(.disabled){background:#ffffff40!important;border-color:#ffffff59!important}.upload-button.disabled{opacity:.4!important}.first-folder-tooltip{background:#000000e6!important;color:#fff!important;border:1px solid rgba(255,255,255,.2)}.first-folder-tooltip:before{border-bottom-color:#000000e6!important}.library-count{background:#282828f2!important;color:#edf2f7!important;border:1px solid rgba(255,255,255,.1)}.objects-empty{color:#a0aec0!important}.objects-empty h3{color:#cbd5e0!important}.empty-state,.empty-state p{color:#a0aec0!important}.empty-drop-zone{background:#ffffff05!important;border-color:#ffffff26!important}.empty-drop-zone:hover{border-color:#3b82f6!important;background:#3b82f614!important}.upload-icon{color:#a0aec0!important}.drag-hint{background:#3b82f633!important;color:#90cdf4!important}.objects-header h3{color:#edf2f7!important}.download-packs-button{background:#ffffff26!important;border-color:#ffffff40!important;color:#fff!important}.download-packs-button:hover{background:#ffffff40!important;border-color:#ffffff59!important}.download-packs-dialog{background:#1e1e1efa!important;border:1px solid rgba(255,255,255,.15)!important}.download-packs-title{color:#fff!important}.download-packs-subtitle{color:#a0aec0!important}.pack-card{background:#ffffff0d!important;border-color:#ffffff26!important}.pack-card-active:hover{border-color:#3b82f6!important;background:#3b82f626!important}.pack-name{color:#edf2f7!important}.pack-description{color:#a0aec0!important}.pack-action{background:#3b82f633!important;color:#90cdf4!important}.pack-card-active:hover .pack-action{background:#3b82f6!important;color:#fff!important}.pack-card-disabled{opacity:.5!important}.pack-coming-soon-banner{background:#eab308e6!important}.download-packs-close{background:#ffffff1f!important;color:#fff!important}.download-packs-close:hover{background:#fff3!important}.folder-confirm-dialog{background:#1e1e1efa!important;border-color:#ffffff26!important}.folder-confirm-title{color:#fff!important}.folder-confirm-body{color:#a0aec0!important}.folder-confirm-folder{color:#edf2f7!important}.folder-confirm-cancel{background:#ffffff1a!important;color:#fff!important}.folder-confirm-cancel:hover{background:#ffffff26!important}.folder-confirm-delete{background:#ef4444!important}.folder-confirm-delete:hover{background:#dc2626!important}}.download-packs-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:40px;padding:0 20px;border-radius:8px;border:1px solid rgba(0,0,0,.1);background:#f7fafc;color:#2d3748;font-size:13px;font-weight:600;line-height:1;cursor:pointer;transition:all .16s ease;white-space:nowrap;margin-top:10px}.download-packs-icon{flex-shrink:0;vertical-align:middle;margin:0;padding:0}.download-packs-button .button-text{display:inline-block;vertical-align:middle}.download-packs-button:hover{background:#edf2f7;border-color:#00000026;transform:translateY(-1px)}.download-packs-button:active{transform:translateY(0)}.download-packs-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#00000080;z-index:3000;padding:20px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.download-packs-dialog{position:relative;background:#fffffffa;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;padding:40px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.download-packs-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:8px;border:none;background:#00000014;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;line-height:1;color:#1a202c;padding:0;transition:all .16s ease}.download-packs-close:hover{background:#00000026;transform:scale(1.05)}.download-packs-title{font-size:24px;font-weight:600;color:#1a202c;margin:0 0 8px}.download-packs-subtitle{font-size:14px;color:#718096;margin:0 0 32px}.download-packs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px}.pack-card{position:relative;background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:20px;display:flex;flex-direction:column;align-items:center;text-align:center;transition:all .2s ease;text-decoration:none;color:inherit;overflow:hidden}.pack-card-active{cursor:pointer}.pack-card-active:hover{transform:translateY(-4px);border-color:#3b82f6;box-shadow:0 8px 24px #3b82f633}.pack-card-disabled{cursor:not-allowed;opacity:.6}.pack-coming-soon-banner{position:absolute;top:12px;right:-32px;background:linear-gradient(135deg,#f59e0b,#eab308);color:#fff;font-size:11px;font-weight:600;padding:4px 40px;transform:rotate(45deg);box-shadow:0 2px 8px #00000026;text-transform:uppercase;letter-spacing:.5px}.pack-image{width:100%;aspect-ratio:1;margin-bottom:16px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);overflow:hidden}.pack-image img{width:100%;height:100%;object-fit:cover;border-radius:8px}.pack-placeholder{font-size:48px;line-height:1}.pack-info{width:100%}.pack-name{font-size:16px;font-weight:600;color:#1a202c;margin:0 0 4px}.pack-description{font-size:13px;color:#718096;margin:0 0 12px}.pack-action{display:inline-block;background:#3b82f6;color:#fff;font-size:13px;font-weight:500;padding:6px 16px;border-radius:6px;transition:background .16s ease}.pack-card-active:hover .pack-action{background:#2563eb}@media(max-width:768px){.download-packs-dialog{padding:24px}.download-packs-title{font-size:20px}.download-packs-grid{grid-template-columns:1fr;gap:16px}.pack-card{padding:16px}}.sidebar-backdrop{position:fixed;inset:0;background:#0000004d;z-index:1500;animation:fadeIn .2s ease;pointer-events:none}.sidebar-backdrop.is-active{pointer-events:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.object-library-sidebar{position:fixed;top:0;right:0;width:320px;height:100vh;height:100dvh;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:-4px 0 24px #0000001a;z-index:1600;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s cubic-bezier(.2,.8,0,1);contain:layout style paint;will-change:transform;pointer-events:none}.object-library-sidebar,.object-library-sidebar *{box-sizing:border-box}.object-library-sidebar.open{transform:translate(0);pointer-events:auto}.object-library-sidebar.open.dragging{transform:translate(calc(100% - 22px))}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid rgba(0,0,0,.1)}.sidebar-header h3{font-size:18px;font-weight:700;color:#111;margin:0}.close-sidebar-btn{width:34px;height:34px;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;padding:0;background:#0000000d;border:none;border-radius:8px;font-size:18px;color:#000000a6;cursor:pointer;transition:background .2s ease,color .2s ease}.close-sidebar-btn svg{color:inherit}.close-sidebar-btn svg path{fill:currentColor}.close-sidebar-btn:hover{background:#0000001a;color:#111}.sidebar-search{padding:16px 20px;border-bottom:1px solid rgba(0,0,0,.1)}.sidebar-search-row{display:flex;align-items:center;gap:10px}.sidebar-search-row .search-with-icon{flex:1;min-width:0}.sidebar-search .search-with-icon{position:relative}.sidebar-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#00000059;pointer-events:none}.sidebar-search input{width:100%;padding:10px 38px;font-size:13px;font-weight:600;border:2px solid rgba(0,0,0,.1);border-radius:8px;background:#ffffffe6;transition:border-color .2s ease}.sidebar-search .search-clear-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:none;border-radius:7px;background:#0000000d;color:#0000008c;cursor:pointer;padding:0;line-height:1;font-size:16px;transition:background .2s ease,color .2s ease}.sidebar-search .search-clear-btn:hover{background:#0000001a;color:#000000bf}.sidebar-search input:focus{outline:none;border-color:#111}.sidebar-controls-row{padding:10px 20px;border-bottom:1px solid rgba(0,0,0,.1);display:flex;align-items:center;justify-content:space-between;gap:10px}.sidebar-folder-dropdown{flex:1;min-width:0;position:relative}.sidebar-folder-dropdown:after{content:"";position:absolute;right:12px;top:50%;width:7px;height:7px;border-right:2px solid rgba(0,0,0,.55);border-bottom:2px solid rgba(0,0,0,.55);transform:translateY(-60%) rotate(45deg);pointer-events:none}.sidebar-folder-dropdown-btn{width:100%;height:34px;padding:8px 34px 8px 12px;font-size:13px;font-weight:700;border:2px solid rgba(0,0,0,.1);border-radius:8px;background:#ffffffe6;color:#111;cursor:pointer;display:flex;align-items:center;justify-content:flex-start;transition:border-color .2s ease,background .12s ease}.sidebar-folder-dropdown-btn:hover{border-color:#0000002e;background:#00000005}.sidebar-folder-dropdown-btn:focus{outline:none;border-color:#111}.sidebar-folder-dropdown-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-folder-dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fffffffa;border:1px solid rgba(0,0,0,.1);border-radius:10px;box-shadow:0 12px 30px #0000001f;padding:6px;z-index:20;max-height:240px;overflow-y:auto}.sidebar-folder-dropdown-item{width:100%;text-align:left;padding:10px;border:none;border-radius:8px;background:transparent;color:#111;font-size:13px;font-weight:700;cursor:pointer}.sidebar-folder-dropdown-item:hover{background:#0000000d}.sidebar-folder-dropdown-item.active{background:#111;color:#fff}.sidebar-view-toggle-switch{position:relative;height:34px;width:92px;border-radius:8px;border:1px solid rgba(0,0,0,.1);background:#ffffffe6;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:0 6px;cursor:pointer;transition:background .12s ease}.sidebar-view-toggle-switch:hover{background:#00000008}.sidebar-view-icon{position:relative;z-index:2;display:inline-flex;align-items:center;justify-content:center;color:#0000008c}.sidebar-view-toggle-switch.is-icons .sidebar-view-icon:first-child{color:#111}.sidebar-view-toggle-switch.is-list .sidebar-view-icon:last-child{color:#111}.sidebar-view-thumb{position:absolute;top:4px;left:4px;width:calc(50% - 4px);height:calc(100% - 8px);border-radius:6px;background:#00000014;z-index:1;transition:transform .16s cubic-bezier(.2,.8,0,1)}.sidebar-view-toggle-switch.is-list .sidebar-view-thumb{transform:translate(100%)}.sidebar-folder{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;font-size:12px;font-weight:600;color:#111;background:transparent;border:1px solid rgba(0,0,0,.1);border-radius:6px;cursor:pointer;transition:background .12s ease}.sidebar-folder-icon{flex-shrink:0}.sidebar-folder-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-folder:hover{background:#0000000d}.sidebar-folder.active{background:#111;color:#fff;border-color:#111}.sidebar-objects{flex:1;min-height:0;overflow-y:auto;padding:16px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-content:start;justify-items:stretch}.sidebar-objects.icons .sidebar-object{display:flex;flex-direction:column;width:100%}.sidebar-objects.icons .sidebar-object-image{width:100%;height:130px;aspect-ratio:auto;align-self:stretch}.sidebar-objects.list{display:flex;flex-direction:column;gap:10px}.sidebar-objects.list .sidebar-object{display:flex;align-items:center;gap:10px;padding:10px;cursor:grab}.sidebar-objects.list .sidebar-object-image{width:44px;height:44px;aspect-ratio:auto;margin-bottom:0;flex-shrink:0}.sidebar-objects.list .sidebar-object-name{text-align:left;font-size:13px}.sidebar-empty{grid-column:1 / -1;text-align:center;padding:40px 20px;color:#999}.sidebar-empty p{font-size:13px;font-weight:600;margin:0}.sidebar-object{background:#fffc;border-radius:10px;padding:12px;cursor:grab;width:100%;transition:transform .12s ease,box-shadow .12s ease}.sidebar-object:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.sidebar-object:active{cursor:grabbing}.sidebar-object-image{aspect-ratio:1;background:#00000005;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:8px}.sidebar-object-image img{width:100%;height:100%;object-fit:contain;pointer-events:none}.sidebar-object-name{font-size:11px;font-weight:600;color:#111;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-footer{padding:14px 20px 18px;border-top:1px solid rgba(0,0,0,.1)}.sidebar-add-more-btn{width:100%;height:40px;border-radius:10px;border:none;background:#111;color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:background .16s ease}.sidebar-add-more-btn:hover{background:#333}.sidebar-add-more-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.object-library-sidebar{width:100%;max-width:none}.object-library-sidebar.open.dragging{transform:translate(100%)}}@media(prefers-color-scheme:dark){.object-library-sidebar{background:#1e1e1ef2!important;box-shadow:-4px 0 24px #0006}.sidebar-backdrop{background:#00000080}.sidebar-header{border-bottom-color:#ffffff1f!important}.sidebar-header h3{color:#fff!important}.close-sidebar-btn{background:#ffffff1a!important;color:#e0e0e0!important}.close-sidebar-btn:hover{background:#fff3!important;color:#fff!important}.sidebar-search{border-bottom-color:#ffffff1f!important}.sidebar-search input{background:#282828f2!important;border-color:#ffffff26!important;color:#fff!important}.sidebar-search input:focus{border-color:#718096!important}.sidebar-search input::placeholder{color:#fff6!important}.sidebar-search .search-icon{color:#ffffff80!important}.sidebar-search .search-clear-btn{background:#ffffff1a!important;color:#ffffffb3!important}.sidebar-search .search-clear-btn:hover{background:#fff3!important;color:#fff!important}.sidebar-controls-row{border-bottom-color:#ffffff1f!important}.sidebar-folder-dropdown-btn{background:#282828e6!important;border-color:#fff3!important;color:#fff!important}.sidebar-folder-dropdown-btn:hover{background:#323232e6!important;border-color:#ffffff4d!important}.sidebar-folder-dropdown-btn:focus{border-color:#718096!important}.sidebar-folder-dropdown:after{border-right-color:#ffffffb3!important;border-bottom-color:#ffffffb3!important}.sidebar-folder-dropdown-menu{background:#232323fa!important;border-color:#ffffff26!important;box-shadow:0 12px 30px #00000080}.sidebar-folder-dropdown-item{color:#edf2f7!important}.sidebar-folder-dropdown-item:hover{background:#ffffff1a!important}.sidebar-folder-dropdown-item.active{background:#fff3!important;color:#fff!important}.sidebar-view-toggle-switch{background:#282828e6!important;border-color:#fff3!important}.sidebar-view-toggle-switch:hover{background:#323232e6!important}.sidebar-view-icon{color:#ffffff80!important}.sidebar-view-toggle-switch.is-icons .sidebar-view-icon:first-child,.sidebar-view-toggle-switch.is-list .sidebar-view-icon:last-child{color:#fff!important}.sidebar-view-thumb{background:#ffffff26!important}.sidebar-folder{background:#282828cc!important;border-color:#ffffff26!important;color:#edf2f7!important}.sidebar-folder:hover{background:#323232e6!important;border-color:#ffffff40!important}.sidebar-folder.active{background:#fff3!important;color:#fff!important;border-color:#ffffff4d!important}.sidebar-folder-icon{color:#a0aec0!important}.sidebar-folder.active .sidebar-folder-icon{color:#fff!important}.sidebar-object{background:#282828cc!important;border:1px solid rgba(255,255,255,.1)}.sidebar-object:hover{background:#323232e6!important;border-color:#fff3;box-shadow:0 6px 16px #0006}.sidebar-object:active{background:#2d2d2de6!important}.sidebar-object-image{background:#0000004d!important;border:1px solid rgba(255,255,255,.05)}.sidebar-object-name{color:#edf2f7!important}.sidebar-empty,.sidebar-empty p{color:#a0aec0!important}.sidebar-footer{border-top-color:#ffffff1f!important}.sidebar-add-more-btn{background:#ffffff26!important;color:#fff!important;border:1px solid rgba(255,255,255,.25)!important}.sidebar-add-more-btn:hover:not(:disabled){background:#ffffff40!important;border-color:#ffffff59!important}.sidebar-add-more-btn:disabled{opacity:.4!important;background:#ffffff0d!important;border-color:#ffffff1a!important;color:#718096!important}.sidebar-objects::-webkit-scrollbar{width:8px}.sidebar-objects::-webkit-scrollbar-track{background:#0003;border-radius:4px}.sidebar-objects::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.sidebar-objects::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.sidebar-folder-dropdown-menu::-webkit-scrollbar{width:6px}.sidebar-folder-dropdown-menu::-webkit-scrollbar-track{background:#0003}.sidebar-folder-dropdown-menu::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar-folder-dropdown-menu::-webkit-scrollbar-thumb:hover{background:#ffffff4d}}.shelf-canvas{padding:140px 0 40px;min-height:100vh;width:100%}.shelf-header{width:100%;max-width:none;margin:0 auto 32px;padding:0 20px;display:flex;align-items:center;justify-content:space-between}.shelf-header h2{font-size:32px;font-weight:700;color:#111;margin:0}.add-object-btn{padding:12px 24px;font-size:14px;font-weight:600;color:#fff;background:#111;border:none;border-radius:10px;cursor:pointer;transition:background .2s ease}.add-object-btn:hover{background:#333}.shelf-container{width:100%;max-width:none;margin:0 auto;min-height:400px;position:relative;transition:background .2s ease}.shelf-container.drag-over{background:#0000000d;border-radius:16px}.shelf-grid{display:grid;grid-template-columns:repeat(20,1fr);gap:10px;min-height:400px}.shelf-row-container{grid-column:1 / -1;display:flex;flex-direction:column;margin-bottom:10px}.shelf-row-objects{display:grid;--slot-width: 132px;--slot-height: 144px;--mask-headroom: 200px;--slot-gap: 10px;grid-template-columns:repeat(var(--columns-per-row, 10),var(--slot-width));gap:var(--slot-gap);align-items:end;min-height:calc(var(--slot-height) + 30px);margin-bottom:0;position:relative;z-index:2;perspective:900px;padding:0 40px;--row-mask-percent: 0%;--row-mask-feather: 0%}.empty-shelf-state,.empty-shelf{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.empty-shelf-state h2{font-size:28px;font-weight:700;color:#111;margin:0 0 8px}.empty-shelf-state p,.empty-shelf p{font-size:14px;font-weight:600;color:#666;margin:0 0 24px}.add-first-btn{padding:12px 24px;font-size:14px;font-weight:600;color:#fff;background:#111;border:none;border-radius:10px;cursor:pointer;transition:background .2s ease}.add-first-btn:hover{background:#333}.objects-display{grid-column:1 / -1;display:grid;grid-template-columns:repeat(20,1fr);gap:10px;position:relative}.shelf-row-indicator{height:20px;background:linear-gradient(to bottom,#0000000d,#0000001a);border-radius:4px;box-shadow:0 2px 8px #0000001a;margin-bottom:10px}.shelf-row-indicator-overlay{position:absolute;left:0;right:0;top:0;margin-bottom:0}.shelf-3d-canvas{height:100%;width:100%}.shelf-3d-canvas.is-hidden{opacity:0;pointer-events:none}.placement-preview{position:relative;grid-row:1;align-self:end;width:100%;pointer-events:none;opacity:.55;z-index:3;display:flex;align-items:flex-end;justify-content:center}.placement-preview img{width:100%;height:auto;display:block}.shelf-debug-red-line{position:absolute;left:0;right:0}.add-row-btn{display:flex;align-items:center;justify-content:center;width:60px;height:60px;margin:30px auto;background:#fff;border:2px dashed #ccc;border-radius:50%;cursor:pointer;transition:all .2s ease;padding:0}.add-row-btn:hover{background:#f5f5f5;border-color:#999;transform:scale(1.05)}.add-row-icon{font-size:28px;font-weight:300;color:#999;line-height:1;transition:color .2s ease}.add-row-btn:hover .add-row-icon{color:#333}.shelf-object{position:relative;cursor:pointer;transition:none;grid-column:span 1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;z-index:10;min-height:80px;width:100%;box-sizing:border-box;height:var(--slot-height, 144px);overflow:visible}.shelf-object-mask{position:absolute;left:0;right:0;bottom:0;width:100%;height:calc(var(--slot-height, 144px) + var(--mask-headroom, 200px));-webkit-mask-image:linear-gradient(to top,transparent 0%,transparent var(--row-mask-percent),black calc(var(--row-mask-percent) + var(--row-mask-feather)),black 100%);mask-image:linear-gradient(to top,transparent 0%,transparent var(--row-mask-percent),black calc(var(--row-mask-percent) + var(--row-mask-feather)),black 100%);pointer-events:none}.shelf-object-visual{position:absolute;left:0;right:0;bottom:0;height:var(--slot-height, 144px);display:flex;align-items:flex-end;justify-content:center;translate:0 0;transform-origin:bottom center;transition:transform .2s ease,translate .16s ease}.shelf-object:hover .shelf-object-visual{translate:0 -6px}.shelf-object-frame{width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center}.shelf-object-img{width:100%;height:100%;display:block;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1));transition:filter .2s ease,transform .2s ease;max-width:100%;object-fit:contain;transform-origin:bottom center}.shelf-object:hover .shelf-object-img,.shelf-object.selected .shelf-object-img{filter:drop-shadow(0 8px 16px rgba(0,0,0,.2))}.shelf-object.selected{z-index:100}.shelf-object.dragging{opacity:.3;z-index:5}.shelf-object.ghost-object{z-index:200}.object-controls{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:12px;width:200px;max-width:200px;box-sizing:border-box;background:#ffffffb8;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:10px;padding:12px 12px 10px;border:1px solid rgba(255,255,255,.5);box-shadow:0 10px 30px #0000002e;white-space:nowrap;z-index:100;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;transform:translate(-50%) translateY(10px)}.shelf-object.selected .object-controls{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0)}.object-hover-label{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:10px;width:200px;max-width:200px;box-sizing:border-box;padding:8px 10px;border-radius:10px;background:#ffffffb8;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);box-shadow:0 10px 30px #0000001f;font-size:12px;font-weight:700;color:#111;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;z-index:90;opacity:0;transition:opacity .16s ease,transform .16s ease}.shelf-object:hover .object-hover-label{opacity:1;transform:translate(-50%) translateY(0)}.object-name{font-size:12px;font-weight:700;color:#111;margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.control-buttons{display:flex;flex-direction:column;gap:8px}.scale-control{display:flex;flex-direction:column;align-items:stretch;gap:6px;font-size:11px;font-weight:600;color:#666}.scale-control-header{display:flex;align-items:center;justify-content:space-between;gap:8px;color:#000000a6}.scale-control input[type=range]{flex:1;min-width:0;width:auto;height:10px;accent-color:#111}.scale-control input[type=range]::-webkit-slider-thumb{transform:scale(1.25)}.object-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:center}.object-icon-btn{width:100%;height:36px;border-radius:10px;border:none;background:#0000000f;color:#111;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:background .14s ease,transform .14s ease}.object-icon-btn:hover{background:#0000001f;transform:translateY(-1px)}.object-icon-btn:active{transform:translateY(0)}.object-icon-btn.active{background:#0000002e}.object-icon-btn.danger{background:#e74c3c24;color:#e74c3c}.object-icon-btn.danger:hover{background:#e74c3c33}.remove-btn{padding:6px 12px;font-size:11px;font-weight:600;color:#fff;background:#e74c3c;border:none;border-radius:6px;cursor:pointer;transition:background .2s ease}.remove-btn:hover{background:#c0392b}.empty-slot{position:relative;grid-row:1;height:calc(var(--slot-height, 144px) + 10px);border-radius:8px;pointer-events:auto;z-index:1;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;opacity:0;width:100%}.empty-slot:hover{background:#0000000d;opacity:1}.empty-slot.dragging-mode{opacity:1;background:#0000000d;border:2px dashed rgba(0,0,0,.2);pointer-events:none}.empty-slot.placing-mode{opacity:1;background:#0000000d;border:2px dashed rgba(0,0,0,.2);pointer-events:auto}.empty-slot .add-icon{font-size:48px;font-weight:300;color:#0000004d;transition:all .2s ease;line-height:1}.empty-slot:hover .add-icon{color:#0009;transform:scale(1.1)}.empty-slot.dragging-mode .add-icon,.empty-slot.placing-mode .add-icon{display:none}.slot-indicator{position:absolute;top:0;bottom:20px;border:2px dashed rgba(0,0,0,.2);border-radius:8px;background:#0000000d;pointer-events:none;z-index:1;transition:opacity .2s ease;display:flex;align-items:center;justify-content:center}.slot-label{font-size:14px;font-weight:700;color:#0009;background:#fffc;padding:4px 8px;border-radius:4px}.cell-highlight{position:relative;grid-row:1;align-self:start;width:100%;height:calc(var(--slot-height, 144px) + 10px);border-radius:8px;pointer-events:none;z-index:250;transition:all .1s ease}.cell-highlight.empty{background:#3b82f64d;border:3px solid rgba(59,130,246,.8);box-shadow:0 0 20px #3b82f666}.cell-highlight.occupied{background:#ef44444d;border:3px solid rgba(239,68,68,.8);box-shadow:0 0 20px #ef444466}@media(max-width:1024px){.shelf-header h2{font-size:24px}.shelf-grid,.objects-display{grid-template-columns:repeat(10,1fr)}.shelf-object{grid-column:span 2}}@media(max-width:600px){.shelf-canvas{padding:100px 0 40px}.shelf-header{flex-direction:column;align-items:flex-start;gap:16px}.shelf-grid,.objects-display{grid-template-columns:repeat(5,1fr)}.ghost-object{opacity:.5;pointer-events:none;z-index:1000}.ghost-object img{filter:drop-shadow(0 8px 16px rgba(0,0,0,.3))}}.ghost-object{opacity:.4;pointer-events:none;z-index:1000;position:relative}.ghost-object img{filter:drop-shadow(0 8px 16px rgba(0,0,0,.3))}.shelf-canvas.display-mode{padding-top:40px}.shelf-canvas.display-mode .shelf-object{pointer-events:none}.shelf-canvas.display-mode .add-object-btn,.shelf-canvas.display-mode .empty-slot,.shelf-canvas.display-mode .row-add-btn,.shelf-canvas.display-mode .row-delete-btn,.shelf-canvas.display-mode .object-action-menu{display:none!important}.onboarding-tooltip{position:fixed;max-width:280px;background:#000000d9;color:#fffffff2;border-radius:10px;padding:12px 30px 12px 12px;box-shadow:0 10px 30px #00000059;z-index:2000;animation:onboarding-tip-in .22s ease-out,onboarding-tip-bop 4.8s ease-in-out infinite;will-change:transform}.onboarding-tooltip:hover{box-shadow:0 14px 34px #00000061}@keyframes onboarding-tip-in{0%{opacity:0}to{opacity:1}}@keyframes onboarding-tip-bop{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@media(prefers-reduced-motion:reduce){.onboarding-tooltip{animation:none}}.onboarding-tooltip:before{content:"";position:absolute;width:0;height:0}.onboarding-tooltip[data-placement=bottom]:before{top:-8px;left:var(--arrow-x, 24px);transform:translate(-50%);border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid rgba(0,0,0,.85)}.onboarding-tooltip[data-placement=top]:before{bottom:-8px;left:var(--arrow-x, 24px);transform:translate(-50%);border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid rgba(0,0,0,.85)}.onboarding-tooltip[data-placement=left]:before{right:-8px;top:var(--arrow-y, 24px);transform:translateY(-50%);border-top:8px solid transparent;border-bottom:8px solid transparent;border-left:8px solid rgba(0,0,0,.85)}.onboarding-tooltip[data-placement=right]:before{left:-8px;top:var(--arrow-y, 24px);transform:translateY(-50%);border-top:8px solid transparent;border-bottom:8px solid transparent;border-right:8px solid rgba(0,0,0,.85)}.onboarding-tooltip-text{font-size:15px;font-weight:600;line-height:1.3}.onboarding-inline-menu-icon{display:inline-block;width:18px;height:14px;border-radius:5px;position:relative;top:2px;margin:0 4px}.onboarding-inline-menu-icon:before,.onboarding-inline-menu-icon:after,.onboarding-inline-menu-icon span{content:"";position:absolute;left:0;right:0;height:2px;background:#fffffff2;border-radius:2px}.onboarding-inline-menu-icon:before{top:1px}.onboarding-inline-menu-icon span{top:6px}.onboarding-inline-menu-icon:after{top:11px}.onboarding-tooltip-actions{margin-top:10px;display:flex;gap:8px;justify-content:flex-end}.onboarding-tooltip-action{height:30px;border-radius:8px;border:none;outline:none;box-shadow:none;background:#ffffff14;color:#fffffff2;font-size:12.5px;font-weight:700;padding:0 10px;cursor:pointer}.onboarding-tooltip-action:focus,.onboarding-tooltip-action:focus-visible{outline:none;box-shadow:none}.onboarding-tooltip-action:hover:not(:disabled){background:#ffffff24}.onboarding-tooltip-action:disabled{opacity:.45;cursor:not-allowed}.onboarding-tooltip-action--primary{background:#ffffff2e}.onboarding-tooltip-action--primary:hover:not(:disabled){background:#ffffff3d}.onboarding-tooltip-close{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:6px;border:none;background:transparent;color:#ffffffe6;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;font-size:12px;padding:0}.onboarding-tooltip-close:hover{color:#fff;background:#ffffff14}
