*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html,body,#root{height:100%}body{background:#0a0a0f;color:#d8d8e8;font-family:-apple-system,BlinkMacSystemFont,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: #0a0a0f;--bg1: #0f0f18;--bg2: #16161f;--bg3: #1e1e2a;--b: #2a2a38;--b2: #3a3a4e;--t: #d8d8e8;--t2: #a0a0b8;--t3: #8080a0;--t4: #4a4a62;--ac: #c8ff00;--ac2: #d4ff33;--mono: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg1)}::-webkit-scrollbar-thumb{background:var(--b);border-radius:3px}::-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(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-bar{0%,to{transform:scaleY(1)}50%{transform:scaleY(2.5)}}.card-preview{background:linear-gradient(135deg,#16161f,#1e1e2a);border:1px solid var(--b);border-radius:16px;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;transition:border-color .25s ease,transform .25s ease,box-shadow .25s ease}.card-preview:hover{border-color:var(--ac);transform:translateY(-3px);box-shadow:0 12px 40px #c8ff0014}.tag-pill{font-family:var(--mono);font-size:10px;letter-spacing:.05em;background:var(--bg3);border:1px solid var(--b);color:var(--t3);padding:2px 8px;border-radius:3px;transition:all .15s ease;display:inline-flex;align-items:center;gap:4px;cursor:pointer;line-height:1.4}.tag-pill:hover,.tag-pill.active{background:var(--ac);border-color:var(--ac);color:var(--bg)}.tag-pill button{background:none;border:none;cursor:pointer;color:inherit;line-height:1;padding:0}.project-chip{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border-radius:2px;display:inline-block}.btn-primary{background:var(--ac);color:var(--bg);font-weight:600;font-size:13px;letter-spacing:.02em;padding:8px 18px;border-radius:6px;border:none;cursor:pointer;transition:background .15s ease,transform .15s ease;display:inline-block;text-align:center;white-space:nowrap}.btn-primary:hover:not(:disabled){background:var(--ac2);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:none;border:1px solid var(--b);color:var(--t3);font-size:13px;padding:8px 18px;border-radius:6px;cursor:pointer;transition:border-color .15s ease,color .15s ease;white-space:nowrap}.btn-ghost:hover{border-color:var(--b2);color:var(--t)}.shimmer{background:linear-gradient(90deg,#16161f 25%,#1e1e2a,#16161f 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:32px;height:32px;border-radius:8px;background:var(--ac);display:flex;align-items:center;justify-content:center}.loading-bar{width:4px;height:24px;background:var(--b);border-radius:99px;overflow:hidden}.loading-bar-fill{width:100%;height:40%;background:var(--ac);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:#0a0a0fe6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--b)}.gallery-header-inner{display:flex;align-items:center;gap:12px;padding:0 16px;height:56px}.header-logo{display:flex;align-items:center;gap:8px;flex-shrink:0}.header-logo-icon{width:28px;height:28px;border-radius:7px;background:var(--ac);display:flex;align-items:center;justify-content:center}.header-logo-text{font-size:15px;font-weight:700;color:var(--t);letter-spacing:-.02em}.header-search{flex:1;max-width:420px;position:relative}.header-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--t4);pointer-events:none;display:flex}.header-search input{width:100%;background:var(--bg2);border:1px solid var(--b);border-radius:8px;padding:7px 12px 7px 34px;font-size:13px;color:var(--t);transition:border-color .15s ease}.header-search input:focus{border-color:var(--b2)}.header-search input::placeholder{color:var(--t4)}.grid-controls{display:flex;align-items:center;gap:2px;background:var(--bg2);border:1px solid var(--b);border-radius:8px;padding:3px}.grid-btn{padding:4px 10px;border-radius:6px;font-size:13px;font-family:var(--mono);transition:all .15s ease;color:var(--t4)}.grid-btn:hover{color:var(--t2)}.grid-btn.active{background:var(--ac);color:var(--bg);font-weight:600}.doc-count{font-family:var(--mono);font-size:11px;color:var(--t4);white-space:nowrap}.logout-btn{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--t3);margin-left:auto;transition:color .15s ease}.logout-btn:hover{color:var(--t2)}.logout-email{display:none}@media (min-width: 640px){.logout-email{display:inline}}.gallery-body{display:flex;flex:1;position:relative}.sidebar{flex-shrink:0;border-right:1px solid var(--b);background:var(--bg);overflow:hidden;transition:width .2s ease}.sidebar.open{width:208px}.sidebar.closed{width:0}.sidebar-inner{padding:16px;width:208px}.sidebar-section{margin-bottom:24px}.sidebar-label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--t4);margin-bottom:10px}.sidebar-nav{display:flex;flex-direction:column;gap:2px}.sidebar-item{width:100%;display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border-radius:8px;font-size:13px;text-align:left;cursor:pointer;transition:all .15s ease;color:var(--t3)}.sidebar-item:hover{color:var(--t2);background:var(--bg2)}.sidebar-item.active{background:var(--ac);color:var(--bg);font-weight:500}.sidebar-item-count{font-family:var(--mono);font-size:11px;color:var(--t4);flex-shrink:0}.sidebar-item.active .sidebar-item-count{color:#0a0a0f80}.sidebar-item-label{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.sidebar-item-dot{width:8px;height:8px;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(--bg2);border:1px solid var(--b);border-left:none;border-radius:0 6px 6px 0;padding:6px 4px;color:var(--t3);transition:left .2s ease,color .15s ease,background .15s ease;display:flex;align-items:center}.sidebar-toggle:hover{color:var(--t2);background:var(--bg3)}.gallery-main{flex:1;overflow:auto;padding:20px}.active-filters{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:16px}.active-filters-label{font-family:var(--mono);font-size:11px;color:var(--t4)}.filter-chip{display:flex;align-items:center;gap:4px;background:var(--bg2);border:1px solid var(--b);border-radius:4px;padding:3px 8px;font-size:11px;color:var(--t2);transition:border-color .15s ease;cursor:pointer}.filter-chip:hover{border-color:#7f1d1d}.filter-chip-x{color:var(--t4)}.docs-grid{display:grid;gap:16px}.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)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:100px 20px;text-align:center;gap:12px}.empty-state-icon{width:64px;height:64px;border-radius:16px;background:var(--bg2);border:1px solid var(--b);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.empty-state-title{font-size:17px;font-weight:500;color:var(--t3)}.empty-state-sub{font-size:12px;color:var(--t4)}.card-thumb{position:relative;flex-shrink:0;overflow:hidden;background:#0f0f18;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:.3;display:flex;flex-direction:column;gap:6px}.fallback-line{height:7px;background:#3a3a4e;border-radius:3px}.fallback-line-block{height:28px;background:#3a3a4e;border-radius:4px;margin-top:8px}.card-hover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0a0f00;transition:background .2s ease;display:flex;align-items:center;justify-content:center}.card-preview:hover .card-hover-overlay{background:#0a0a0f66}.card-open-btn{width:44px;height:44px;border-radius:50%;background:var(--ac);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:opacity .2s ease,transform .2s ease}.card-preview:hover .card-open-btn{opacity:1;transform:scale(1)}.card-version-badge{position:absolute;top:10px;right:10px;background:#0a0a0fd9;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:14px;display:flex;flex-direction:column;gap:8px;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 ease}.card-preview:hover .card-title{color:var(--ac)}.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:8px}.card-size{font-family:var(--mono);font-size:9px;color:var(--t4)}.card-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s ease}.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 ease;cursor:pointer;color:var(--t3)}.card-action-btn:hover{background:var(--bg3)}.card-action-btn.danger:hover{background:#1a0000}.login-page{min-height:100vh;background:var(--bg);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:-20%;left:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(200,255,0,.04) 0%,transparent 70%)}.login-bg-blob-2{bottom:-20%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(124,58,237,.05) 0%,transparent 70%)}.login-bg-grid{position:fixed;top:0;right:0;bottom:0;left:0;opacity:.03;pointer-events:none;background-image:linear-gradient(#d8d8e8 1px,transparent 1px),linear-gradient(90deg,#d8d8e8 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:32px}.login-brand-icon{width:40px;height:40px;border-radius:12px;background:var(--ac);display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px}.login-brand-name{display:block;font-size:21px;font-weight:700;color:var(--t);letter-spacing:-.02em}.login-brand-sub{display:block;font-family:var(--mono);font-size:11px;color:var(--t3);margin-top:6px}.login-card{background:var(--bg2);border:1px solid var(--b);border-radius:20px;padding:32px;box-shadow:0 0 0 1px #c8ff000d,0 24px 64px #0006}.login-form{display:flex;flex-direction:column;gap:18px}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3)}.form-input,.form-textarea,.form-select{width:100%;background:var(--bg3);border:1px solid var(--b);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--t);transition:border-color .15s ease}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--ac)}.form-input::placeholder,.form-textarea::placeholder{color:var(--t4)}.form-textarea{resize:none}.form-select{cursor:pointer}.form-select option{background:var(--bg2);color:var(--t)}.error-box{background:#1a0000;border:1px solid #7f1d1d;border-radius:8px;padding:10px 14px;font-size:12px;color:#f87171}.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:#000000b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.modal-box{width:100%;max-width:520px;background:var(--bg2);border:1px solid var(--b);border-radius:20px;padding:24px;box-shadow:0 24px 80px #00000080;animation:fade-up .25s ease both}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.modal-title{font-size:15px;font-weight:600;color:var(--t)}.modal-close{color:var(--t3);cursor:pointer;transition:color .15s ease;display:flex;align-items:center;padding:4px}.modal-close:hover{color:var(--t)}.modal-body{display:flex;flex-direction:column;gap:16px}.modal-actions{display:flex;gap:10px;margin-top:22px}.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}
