*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html,body,#root{height:100%}body{background:#fff;color:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,system-ui,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}input,textarea,select{font:inherit;background:none;border:none;outline:none;color:inherit}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}:root{--bg: #ffffff;--bg1: #f7f7f5;--bg2: #f1f1ef;--bg3: #e9e9e7;--b: #e3e3e1;--b2: #c8c8c6;--t: #1a1a1a;--t2: #37352f;--t3: #706f6c;--t4: #9b9b9a;--mono: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--b);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--b2)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-bar{0%,to{transform:scaleY(1)}50%{transform:scaleY(2.5)}}.card-preview{background:#fff;border:1px solid var(--b);border-radius:12px;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;transition:border-color .2s,transform .2s,box-shadow .2s;box-shadow:0 1px 2px #0000000d,0 0 0 0 transparent}.card-preview:hover{border-color:var(--b2);transform:translateY(-2px);box-shadow:0 8px 28px #00000017}.tag-pill{font-family:var(--mono);font-size:10px;letter-spacing:.03em;background:var(--bg2);border:1px solid var(--b);color:var(--t3);padding:2px 7px;border-radius:4px;transition:all .15s;display:inline-flex;align-items:center;gap:4px;cursor:pointer;line-height:1.4}.tag-pill:hover,.tag-pill.active{background:var(--t);border-color:var(--t);color:#fff}.tag-pill button{background:none;border:none;cursor:pointer;color:inherit;line-height:1;padding:0}.project-chip{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;padding:2px 7px;border-radius:3px;background:var(--bg2);color:var(--t3);border:1px solid var(--b)}.project-chip-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.btn-primary{background:var(--t);color:#fff;font-weight:500;font-size:13px;letter-spacing:.01em;padding:8px 18px;border-radius:8px;cursor:pointer;transition:background .15s,transform .15s;display:inline-block;text-align:center;white-space:nowrap}.btn-primary:hover:not(:disabled){background:#000;transform:translateY(-1px)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{background:none;border:1px solid var(--b);color:var(--t3);font-size:13px;padding:8px 18px;border-radius:8px;cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap}.btn-ghost:hover{border-color:var(--b2);color:var(--t2)}.shimmer{background:linear-gradient(90deg,#f1f1ef 25%,#e9e9e7,#f1f1ef 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.page-loading{min-height:100vh;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.loading-icon{width:30px;height:30px;border-radius:8px;background:var(--t);display:flex;align-items:center;justify-content:center}.loading-bar{width:4px;height:22px;background:var(--b);border-radius:99px;overflow:hidden}.loading-bar-fill{width:100%;height:40%;background:var(--t);border-radius:99px;animation:pulse-bar .8s ease-in-out infinite}.gallery-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.gallery-header{position:sticky;top:0;z-index:30;background:#fffffff0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--b)}.gallery-header-inner{display:flex;align-items:center;gap:10px;padding:0 16px;height:52px}.header-logo{display:flex;align-items:center;gap:8px;flex-shrink:0}.header-logo-icon{width:26px;height:26px;border-radius:7px;background:var(--t);display:flex;align-items:center;justify-content:center}.header-logo-text{font-size:15px;font-weight:700;color:var(--t);letter-spacing:-.02em}.header-separator{width:1px;height:20px;background:var(--b);flex-shrink:0}.header-search{flex:1;max-width:360px;position:relative}.header-search-icon{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--t4);pointer-events:none;display:flex}.header-search input{width:100%;background:var(--bg1);border:1px solid var(--b);border-radius:8px;padding:6px 12px 6px 30px;font-size:13px;color:var(--t);transition:border-color .15s,background .15s}.header-search input:focus{border-color:var(--b2);background:#fff}.header-search input::placeholder{color:var(--t4)}.view-controls{display:flex;align-items:center;gap:1px;background:var(--bg1);border:1px solid var(--b);border-radius:8px;padding:3px}.view-btn{padding:4px 10px;border-radius:5px;font-size:11px;font-weight:500;letter-spacing:.01em;transition:all .15s;color:var(--t4)}.view-btn:hover{color:var(--t3)}.view-btn.active{background:var(--t);color:#fff}.grid-controls{display:flex;align-items:center;gap:1px;background:var(--bg1);border:1px solid var(--b);border-radius:8px;padding:3px}.grid-btn{padding:4px 10px;border-radius:5px;font-size:12px;font-family:var(--mono);transition:all .15s;color:var(--t4)}.grid-btn:hover{color:var(--t3)}.grid-btn.active{background:var(--t);color:#fff}.doc-count{font-family:var(--mono);font-size:11px;color:var(--t4);white-space:nowrap;flex-shrink:0}.logout-btn{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--t3);margin-left:auto;padding:5px 10px;border-radius:6px;transition:background .15s,color .15s;flex-shrink:0}.logout-btn:hover{background:var(--bg1);color:var(--t2)}.logout-email{display:none}@media (min-width: 640px){.logout-email{display:inline}}.gallery-body{display:flex;flex:1;position:relative;min-height:0}.sidebar{flex-shrink:0;border-right:1px solid var(--b);background:var(--bg1);overflow:hidden;transition:width .22s ease}.sidebar.open{width:216px}.sidebar.closed{width:0}.sidebar-inner{padding:16px 12px;width:216px;overflow-y:auto;height:100%}.sidebar-section{margin-bottom:28px}.sidebar-label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--t4);margin-bottom:6px;padding:0 6px;display:block}.sidebar-nav{display:flex;flex-direction:column;gap:1px}.sidebar-item{width:100%;display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-radius:6px;font-size:13px;text-align:left;transition:all .15s;color:var(--t3);cursor:pointer}.sidebar-item:hover{color:var(--t2);background:var(--bg2)}.sidebar-item.active{background:var(--t);color:#fff;font-weight:500}.sidebar-item-count{font-family:var(--mono);font-size:10px;color:var(--t4);flex-shrink:0}.sidebar-item.active .sidebar-item-count{color:#fff6}.sidebar-item-label{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.sidebar-item-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.sidebar-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-tags{display:flex;flex-wrap:wrap;gap:6px}.sidebar-toggle{position:absolute;top:50%;transform:translateY(-50%);z-index:20;background:var(--bg);border:1px solid var(--b);border-left:none;border-radius:0 6px 6px 0;padding:7px 4px;color:var(--t4);transition:left .22s ease,color .15s,background .15s;display:flex;align-items:center}.sidebar-toggle:hover{color:var(--t3);background:var(--bg1)}.gallery-main{flex:1;overflow-y:auto;padding:24px 28px}.active-filters{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:20px}.active-filters-label{font-family:var(--mono);font-size:11px;color:var(--t4)}.filter-chip{display:flex;align-items:center;gap:4px;background:var(--bg1);border:1px solid var(--b);border-radius:4px;padding:3px 8px;font-size:11px;color:var(--t2);transition:border-color .15s;cursor:pointer}.filter-chip:hover{border-color:var(--b2)}.filter-chip-x{color:var(--t4)}.docs-grid{display:grid;gap:14px}.docs-grid.size-large{grid-template-columns:repeat(2,1fr)}.docs-grid.size-medium{grid-template-columns:repeat(3,1fr)}.docs-grid.size-small{grid-template-columns:repeat(4,1fr)}@media (min-width: 640px){.docs-grid.size-large{grid-template-columns:repeat(3,1fr)}.docs-grid.size-medium{grid-template-columns:repeat(4,1fr)}.docs-grid.size-small{grid-template-columns:repeat(5,1fr)}}@media (min-width: 1024px){.docs-grid.size-large{grid-template-columns:repeat(4,1fr)}.docs-grid.size-medium{grid-template-columns:repeat(5,1fr)}.docs-grid.size-small{grid-template-columns:repeat(6,1fr)}}.project-group{margin-bottom:44px}.project-group-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding-bottom:12px;border-bottom:1.5px solid var(--b)}.project-group-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.project-group-name{font-size:15px;font-weight:600;color:var(--t2);letter-spacing:-.01em}.project-group-count{font-family:var(--mono);font-size:10px;color:var(--t4);background:var(--bg2);border:1px solid var(--b);padding:1px 8px;border-radius:20px;margin-left:2px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center;gap:10px}.empty-state-icon{width:52px;height:52px;border-radius:14px;background:var(--bg1);border:1px solid var(--b);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.empty-state-title{font-size:15px;font-weight:500;color:var(--t3)}.empty-state-sub{font-size:12px;color:var(--t4);max-width:280px;line-height:1.5}.card-thumb{position:relative;flex-shrink:0;overflow:hidden;background:var(--bg1);height:200px}.card-thumb-shimmer{position:absolute;top:0;right:0;bottom:0;left:0}.card-thumb-iframe-wrap{position:absolute;top:0;left:0;transform-origin:top left;pointer-events:none}.card-thumb-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;padding:16px}.card-thumb-fallback-lines{width:100%;opacity:.35;display:flex;flex-direction:column;gap:6px}.fallback-line{height:7px;background:var(--b2);border-radius:3px}.fallback-line-block{height:28px;background:var(--b2);border-radius:4px;margin-top:8px}.card-hover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000;transition:background .2s;display:flex;align-items:center;justify-content:center}.card-preview:hover .card-hover-overlay{background:#0003}.card-open-btn{width:38px;height:38px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:opacity .2s,transform .2s;box-shadow:0 4px 14px #0000002e}.card-preview:hover .card-open-btn{opacity:1;transform:scale(1)}.card-version-badge{position:absolute;top:10px;right:10px;background:#ffffffe6;border:1px solid var(--b);border-radius:4px;padding:2px 7px}.card-version-text{font-family:var(--mono);font-size:10px;color:var(--t3)}.card-body{padding:13px;display:flex;flex-direction:column;gap:7px;flex:1}.card-title{font-size:13px;font-weight:600;color:var(--t2);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .15s}.card-preview:hover .card-title{color:var(--t)}.card-desc{font-size:11px;color:var(--t3);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-tags{display:flex;flex-wrap:wrap;gap:4px}.card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:8px;border-top:1px solid var(--b)}.card-date{font-family:var(--mono);font-size:9px;color:var(--t4)}.card-footer-right{display:flex;align-items:center;gap:6px}.card-size{font-family:var(--mono);font-size:9px;color:var(--t4)}.card-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s}.card-preview:hover .card-actions{opacity:1}.card-action-btn{padding:5px;border-radius:5px;display:flex;align-items:center;justify-content:center;transition:background .15s;cursor:pointer;color:var(--t4)}.card-action-btn:hover{background:var(--bg2);color:var(--t3)}.card-action-btn.danger:hover{background:#fef2f2;color:#dc2626}.login-page{min-height:100vh;background:var(--bg1);display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}.login-bg-blob{position:fixed;border-radius:50%;pointer-events:none}.login-bg-blob-1{top:-25%;left:-15%;width:700px;height:700px;background:radial-gradient(circle,rgba(0,0,0,.025) 0%,transparent 70%)}.login-bg-blob-2{bottom:-25%;right:-15%;width:600px;height:600px;background:radial-gradient(circle,rgba(0,0,0,.02) 0%,transparent 70%)}.login-bg-grid{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.04;background-image:linear-gradient(var(--b2) 1px,transparent 1px),linear-gradient(90deg,var(--b2) 1px,transparent 1px);background-size:40px 40px}.login-wrap{position:relative;width:100%;max-width:360px;animation:fade-up .35s ease both}.login-brand{text-align:center;margin-bottom:28px}.login-brand-icon{width:42px;height:42px;border-radius:12px;background:var(--t);display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px}.login-brand-name{display:block;font-size:22px;font-weight:700;color:var(--t);letter-spacing:-.03em}.login-brand-sub{display:block;font-family:var(--mono);font-size:11px;color:var(--t3);margin-top:6px}.login-card{background:var(--bg);border:1px solid var(--b);border-radius:16px;padding:28px;box-shadow:0 4px 24px #00000012,0 1px 4px #0000000a}.login-form{display:flex;flex-direction:column;gap:16px}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--t3)}.form-input,.form-textarea,.form-select{width:100%;background:var(--bg1);border:1px solid var(--b);border-radius:8px;padding:9px 12px;font-size:13px;color:var(--t);transition:border-color .15s,background .15s}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--t);background:#fff}.form-input::placeholder,.form-textarea::placeholder{color:var(--t4)}.form-textarea{resize:none}.form-select{cursor:pointer}.form-select option{background:#fff;color:var(--t)}.error-box{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;font-size:12px;color:#dc2626}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:20px;background:#00000059;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.modal-box{width:100%;max-width:520px;background:var(--bg);border:1px solid var(--b);border-radius:16px;padding:24px;box-shadow:0 20px 60px #00000024;animation:fade-up .25s ease both}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-size:15px;font-weight:600;color:var(--t)}.modal-close{color:var(--t3);cursor:pointer;transition:color .15s;display:flex;align-items:center;padding:4px;border-radius:6px}.modal-close:hover{color:var(--t);background:var(--bg1)}.modal-body{display:flex;flex-direction:column;gap:16px}.modal-actions{display:flex;gap:10px;margin-top:20px}.modal-actions .btn-ghost,.modal-actions .btn-primary{flex:1;padding:10px;font-size:13px;border-radius:8px;text-align:center}.tags-input-area{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.header-logo{display:flex;align-items:center;gap:8px;flex-shrink:0;padding:4px 8px 4px 4px;border-radius:8px;transition:background .15s;cursor:pointer}.header-logo:hover{background:var(--bg1)}.sidebar-manage-hint{margin-top:auto;padding-top:16px}.sidebar-manage-btn{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--t4);padding:6px 8px;border-radius:6px;width:100%;transition:background .15s,color .15s;cursor:pointer;text-align:left}.sidebar-manage-btn:hover{background:var(--bg2);color:var(--t3)}.manage-modal{width:100%;max-width:480px;background:var(--bg);border:1px solid var(--b);border-radius:18px;box-shadow:0 24px 80px #00000021,0 2px 8px #0000000f;animation:fade-up .22s ease both;display:flex;flex-direction:column;max-height:80vh;overflow:hidden}.manage-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 0}.manage-title{font-size:16px;font-weight:700;color:var(--t);letter-spacing:-.02em}.manage-tabs{display:flex;gap:2px;padding:14px 20px 0;border-bottom:1px solid var(--b);margin-top:14px}.manage-tab{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--t3);padding:8px 12px;border-radius:8px 8px 0 0;transition:color .15s,background .15s;cursor:pointer;position:relative;bottom:-1px;border:1px solid transparent}.manage-tab:hover{color:var(--t2);background:var(--bg1)}.manage-tab.active{color:var(--t);background:var(--bg);border-color:var(--b);border-bottom-color:var(--bg)}.manage-tab-count{font-family:var(--mono);font-size:10px;color:var(--t4);background:var(--bg2);border:1px solid var(--b);padding:0 6px;border-radius:10px;line-height:1.6}.manage-tab.active .manage-tab-count{background:var(--bg1)}.manage-body{padding:16px 20px 20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:0}.manage-loading{display:flex;flex-direction:column;gap:8px}.manage-empty{font-size:13px;color:var(--t4);padding:16px 0}.manage-list{display:flex;flex-direction:column;gap:2px;margin-bottom:20px}.manage-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;transition:background .15s}.manage-row:hover{background:var(--bg1)}.manage-row.editing{background:var(--bg1);border:1px solid var(--b);border-radius:10px;padding:12px;flex-direction:column;align-items:stretch;gap:10px}.manage-row-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.manage-row-name{font-size:13px;color:var(--t2);font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manage-row-count{font-family:var(--mono);font-size:10px;color:var(--t4);flex-shrink:0}.manage-tag-name{font-family:var(--mono);font-size:11px;color:var(--t3);flex:1}.manage-row-btns{display:flex;gap:2px;margin-left:auto;flex-shrink:0}.manage-icon-btn{padding:5px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--t4);transition:background .15s,color .15s;cursor:pointer}.manage-icon-btn:hover{background:var(--bg2);color:var(--t3)}.manage-icon-btn.danger:hover{background:#fef2f2;color:#dc2626}.manage-row-actions{display:flex;gap:8px}.manage-btn-save{background:var(--t);color:#fff;font-size:12px;font-weight:500;padding:6px 14px;border-radius:6px;cursor:pointer;transition:background .15s;white-space:nowrap}.manage-btn-save:hover:not(:disabled){background:#000}.manage-btn-save:disabled{opacity:.4;cursor:not-allowed}.manage-btn-ghost{background:none;border:1px solid var(--b);color:var(--t3);font-size:12px;padding:6px 14px;border-radius:6px;cursor:pointer;transition:border-color .15s,color .15s}.manage-btn-ghost:hover{border-color:var(--b2);color:var(--t2)}.manage-input{width:100%;background:var(--bg);border:1px solid var(--b);border-radius:7px;padding:8px 11px;font-size:13px;color:var(--t);transition:border-color .15s}.manage-input:focus{outline:none;border-color:var(--t)}.manage-input::placeholder{color:var(--t4)}.manage-swatches{display:flex;flex-wrap:wrap;gap:7px;padding:4px 0}.manage-add-section{border-top:1px solid var(--b);padding-top:16px;display:flex;flex-direction:column;gap:10px}.manage-add-label{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--t4)}.manage-add-row{display:flex;gap:8px}.manage-add-row .manage-input{flex:1}.manage-drag-hint{font-family:var(--mono);font-size:10px;color:var(--t4);margin-bottom:8px;letter-spacing:.04em}.manage-sortable-row{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:8px;transition:background .12s,box-shadow .12s;cursor:default;-webkit-user-select:none;user-select:none}.manage-sortable-row:hover{background:var(--bg1)}.manage-sortable-row[draggable]:hover{cursor:grab}.manage-sortable-row[draggable]:active{cursor:grabbing}.manage-sortable-row.drop-target{background:var(--bg2);box-shadow:inset 0 2px 0 0 var(--b2)}.drag-handle{display:flex;align-items:center;color:var(--t4);flex-shrink:0;cursor:grab;padding:2px;border-radius:4px;transition:color .12s}.manage-sortable-row:hover .drag-handle{color:var(--b2)}.drag-handle:active{cursor:grabbing}
