*{margin:0;padding:0;box-sizing:border-box}body{font-family:Microsoft YaHei,sans-serif;background:#0a0a0f;color:#fff;overflow:hidden;width:100vw;height:100vh}#app{width:100%;height:100%}.app-container{width:100vw;height:100vh;position:relative;overflow:hidden;background:#0a0a0f;transition:background .5s ease,color .5s ease}.click-ripple{position:fixed;border:1.5px solid #ff69b4;background:transparent;border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%)}.click-ripple.small{animation:small-ripple-animation .6s ease-out forwards}.click-ripple.large{border-width:2px;animation:large-ripple-animation 1s ease-out forwards}@keyframes small-ripple-animation{0%{width:0;height:0;opacity:.5}to{width:30px;height:30px;opacity:0}}@keyframes large-ripple-animation{0%{width:0;height:0;opacity:.8}to{width:120px;height:120px;opacity:0}}.app-container.light-mode{background:#f0f0f5;color:#1a1a2e}.app-container.light-mode .side-panel{background:#fff;border-left:1px solid rgba(0,0,0,.1);box-shadow:-10px 0 30px #0000000d}.app-container.light-mode .node-name,.app-container.light-mode .info-item span,.app-container.light-mode .related-item span,.app-container.light-mode .input-group label{color:#1a1a2e}.app-container.light-mode .input-group input,.app-container.light-mode .input-group textarea,.app-container.light-mode .pair-input input{background:#fdfdfd;color:#1a1a2e;border-color:#ff69b480}.app-container.light-mode .user-dropdown{background:#fff;color:#1a1a2e;border:1px solid #ff69b4;box-shadow:0 4px 20px #0000001a}.app-container.light-mode .user-dropdown button{color:#1a1a2e}.app-container.light-mode .user-dropdown button:hover{background:#ff69b41a}.app-container.light-mode .login-guest{background:#333;color:#fff;border:1px solid #1a1a2e}.app-container.light-mode .login-guest:not(.dropdown-active):hover{background:#000;box-shadow:0 0 15px #0003}.app-container.light-mode .login-active{background:#2d9a8a;color:#fff;border:1px solid #247a6d}.app-container.light-mode .login-active:not(.dropdown-active):hover{background:#247a6d;box-shadow:0 0 15px #247a6d66}.app-container.light-mode .search-results{background:#fff;color:#1a1a2e}.bottom-left,.bottom-right{transition:transform .4s cubic-bezier(.165,.84,.44,1)}.bottom-left.panel-up,.bottom-right.panel-up{transform:translateY(-200px)}.app-container.light-mode .search-container input{background:#fffc;color:#1a1a2e;border:1px solid #ff69b4}.app-container.light-mode .history-modal,.app-container.light-mode .site-info-panel{background:#fff;color:#1a1a2e;box-shadow:0 0 30px #0000001a}.graph-container{width:100%;height:100%;transition:transform .5s ease}.graph-container.shifted{transform:translate(-15%)}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0a0a0f;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.loader{border:5px solid #1a1a2e;border-top:5px solid #ff69b4;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ui-layer{position:absolute;z-index:100}.top-left{top:20px;left:20px}.top-right{top:20px;right:20px;display:flex;align-items:flex-start;gap:10px}.bottom-left{bottom:20px;left:20px}.bottom-right{bottom:20px;right:20px}.header-controls{display:flex;gap:15px;align-items:center;position:relative}.theme-toggle{width:40px!important;height:40px!important;display:flex!important;justify-content:center!important;align-items:center!important;border-radius:50%!important;padding:0!important;border:1px solid #ff69b4;background:#ffffff1a;color:#ff69b4;cursor:pointer;transition:all .3s ease;flex-shrink:0}.theme-toggle svg{width:20px!important;height:20px!important;min-width:20px!important;min-height:20px!important;display:block}.theme-toggle:hover{background:#ff69b44d}.user-status{padding:0 16px;border-radius:20px;font-size:14px;cursor:pointer;position:relative;height:40px;box-sizing:border-box;display:flex;align-items:center;justify-content:center;line-height:1;transition:all .3s ease}.user-status.dropdown-active{cursor:default}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#1a1a2e;border:1px solid #ff69b4;border-radius:12px;width:220px;overflow:hidden;z-index:1000;box-shadow:0 4px 20px #00000080;padding:10px;color:#fff}.user-role-badge{text-align:center;padding:4px;border-radius:4px;margin-bottom:10px;font-weight:700;font-size:11px;display:flex;align-items:center;justify-content:center;line-height:normal}.user-role-badge.admin{background:linear-gradient(45deg,#ff69b4,#ff1493);color:#fff}.user-role-badge.visitor,.user-role-badge.user{background:#50e3c233;color:#50e3c2}.quota-info{display:flex;justify-content:space-between;text-align:center;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.1)}.quota-item{display:flex;flex-direction:column;gap:3px;align-items:center}.quota-item span:first-child{font-size:11px;color:#888}.quota-num{font-size:16px;font-weight:700;color:#ff69b4;line-height:1}.logout-btn{width:100%;padding:8px;background:#ffffff1a;border:none;border-radius:8px;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:1;font-size:13px}.logout-btn:hover{background:#ff69b433;color:#ff69b4}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}.left-controls{display:flex;gap:15px}.pink-btn{padding:8px 16px;border-radius:20px;font-size:14px;cursor:pointer;background:#ff69b433;color:#ff69b4;border:1px solid #ff69b4;transition:all .3s ease}.pink-btn:hover{background:#ff69b44d;box-shadow:0 0 10px #ff69b480}.grey-btn{padding:8px 16px;border-radius:20px;font-size:14px;cursor:pointer;background:#f0f0f0cc;color:#333;border:1px solid #ccc;transition:all .3s ease}.grey-btn:hover{background:#fff;box-shadow:0 0 10px #0000001a}.user-status{padding:8px 16px;border-radius:20px;font-size:14px;cursor:pointer;position:relative;transition:all .3s ease}.login-guest:not(.dropdown-active):hover{background:#ffffff40;color:#fff;box-shadow:0 0 15px #fff3}.login-active:not(.dropdown-active):hover{background:#50e3c24d;box-shadow:0 0 15px #50e3c24d}.login-guest{background:#ffffff26;color:#ccc;transition:all .3s ease}.login-active{background:#50e3c233;color:#50e3c2;border:1px solid #50e3c2;display:flex;align-items:center;justify-content:center;min-width:120px}.quota-info{padding:10px;font-size:12px;color:#888;border-bottom:1px solid rgba(255,105,180,.1)}.user-dropdown{position:absolute;top:100%;right:0;background:#1a1a2e;border:1px solid #ff69b4;border-radius:8px;margin-top:10px;width:200px;overflow:hidden;z-index:1000}.login-action-btn{background:#ff69b4;color:#fff!important;text-align:center!important;border-radius:4px;width:100%!important;box-sizing:border-box;margin:0!important;font-weight:700;border:none;padding:10px 12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:normal;transform:translateY(-1px);white-space:normal}.login-action-btn:hover{background:#ff1493;box-shadow:0 0 15px #ff69b466}.app-container.light-mode .login-action-btn{background:#db3a8d}.app-container.light-mode .login-action-btn:hover{background:#b82d75;box-shadow:0 0 10px #db3a8d4d}.user-dropdown button{width:100%;padding:10px;border:none;background:none;color:#fff;text-align:left;cursor:pointer}.user-dropdown button:hover{background:#ff69b433}.search-container{position:relative;width:300px}.active-filters{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:5px}.filter-tag{background:#ff69b4;color:#fff;padding:2px 8px;border-radius:12px;font-size:12px;display:flex;align-items:center;gap:5px}.filter-tag i{cursor:pointer;font-style:normal}.search-container input{width:100%;background:#1a1a2ecc;border:1px solid #ff69b4;color:#fff;padding:10px 15px;border-radius:25px;outline:none}.search-results{position:absolute;bottom:100%;left:0;width:100%;background:#1a1a2e;border:1px solid #ff69b4;border-radius:12px;margin-bottom:10px;max-height:300px;overflow-y:auto}.search-item{padding:10px 15px;cursor:pointer;display:flex;gap:10px}.search-item:hover{background:#ff69b433}.res-type{font-size:10px;background:#ff69b4;padding:2px 5px;border-radius:4px}input,textarea{scrollbar-width:none!important;-ms-overflow-style:none!important}input::-webkit-scrollbar,textarea::-webkit-scrollbar{display:none!important}.input-group{margin-bottom:15px}.input-group label{display:block;color:#888;font-size:14px;margin-bottom:5px}.input-group input,.input-group textarea{width:100%;background:#ffffff0d;border:1px solid rgba(255,105,180,.3);color:#fff;padding:8px 12px;border-radius:4px;font-family:inherit;resize:vertical;scrollbar-width:none;-ms-overflow-style:none}.input-group input::-webkit-scrollbar,.input-group textarea::-webkit-scrollbar{display:none}.pair-input{display:flex;gap:10px}.pair-input input{flex:1}.pair-input-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.remove-btn{background:none;border:none;color:#ff4757;font-size:20px;cursor:pointer;padding:0 5px}.add-btn{background:#ff69b41a;border:1px dashed #ff69b4;color:#ff69b4;padding:8px;border-radius:8px;cursor:pointer;width:100%;margin-top:5px;transition:all .2s}.add-btn:hover{background:#ff69b433}.info-link{color:#ff69b4;text-decoration:none;transition:all .2s}.info-link:hover{text-decoration:underline;opacity:.8}.related-list{display:flex;flex-direction:column;gap:5px}.related-item{display:block}.image-container.editable{cursor:pointer;position:relative;overflow:hidden;display:flex;justify-content:center;align-items:center;background:#ffffff0d}.hover-mask{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;opacity:0;transition:opacity .3s;color:#fff;font-weight:700}.image-container.editable:hover .hover-mask{opacity:1}.image-container.editable:hover img{filter:grayscale(.5)}.upload-placeholder{width:100%;height:200px;background:#1a1a2e80;border:2px dashed #ff69b4;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#ff69b4;border-radius:8px}.upload-placeholder small{font-size:10px;opacity:.7}.crop-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;z-index:2000;display:flex;justify-content:center;align-items:center}.crop-modal{background:#1a1a2e;border:1px solid #ff69b4;border-radius:20px;padding:24px;width:360px;text-align:center}.canvas-container{width:300px;height:300px;margin:20px auto;background:#000;border-radius:8px;overflow:hidden;cursor:move;touch-action:none}.crop-tip{font-size:12px;color:#888;margin:5px 0}.crop-actions{display:flex;justify-content:space-around;margin-top:20px}.form-actions{display:flex;gap:10px;margin-top:20px}.btn.confirm{background:#50e3c2}.btn.cancel{background:#888}.side-panel{position:absolute;right:0;top:0;width:400px;height:100%;background:#0a0a0fd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-left:1px solid rgba(255,105,180,.3);box-shadow:-10px 0 20px #00000080;z-index:200;padding:0;display:flex;flex-direction:column;overflow:hidden}.close-btn{position:absolute;top:10px;right:15px;background:none;border:none;color:#fff;font-size:24px;cursor:pointer}.node-update-history-btn-round{position:absolute;top:15px;left:15px;width:35px;height:35px;background:#ff69b433;color:#ff69b4;border:1px solid #ff69b4;border-radius:50%;cursor:pointer;display:flex;justify-content:center;align-items:center;box-shadow:0 2px 10px #0000004d;transition:all .3s;z-index:201}.node-update-history-btn-round:hover{background:#ff69b44d;transform:scale(1.1)}.panel-inner-close-btn{position:absolute;top:15px;right:15px;width:35px;height:35px;background:#ff69b433;color:#ff69b4;border:1px solid #ff69b4;border-radius:50%;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:all .3s;z-index:202}.panel-inner-close-btn:hover{background:#ff69b44d;transform:rotate(90deg)}.panel-content{position:relative;overflow-y:auto;flex:1;padding:60px 20px 40px;scrollbar-width:none;-ms-overflow-style:none;cursor:grab}.panel-content:active{cursor:grabbing}.panel-content::-webkit-scrollbar{display:none}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1500;display:flex;justify-content:center;align-items:center}.image-container{width:100%;aspect-ratio:1;border-radius:12px;overflow:hidden;margin-top:15px;margin-bottom:20px;border:2px solid #ff69b4}.image-container img{width:100%;height:100%;object-fit:cover}.node-name{font-size:24px;color:#ff69b4;margin-bottom:20px;text-align:center}.info-item{margin-bottom:20px}.info-item label{display:block;color:#888;font-size:14px;margin-bottom:5px}.info-intro{display:block;line-height:1.6;white-space:pre-wrap;background:#ffffff0d;padding:10px;border-radius:8px;border-left:3px solid #ff69b4;font-size:14px}.tag-list{display:flex;flex-wrap:wrap;gap:8px}.tag{background:#ff69b433;border:1px solid #ff69b4;color:#ff69b4;padding:2px 10px;border-radius:12px;font-size:12px}.action-buttons{display:flex;gap:10px;margin-top:20px;padding-bottom:20px}.btn{flex:1;padding:8px;border-radius:4px;cursor:pointer;border:none;color:#fff;font-size:14px;transition:opacity .3s}.btn:hover{opacity:.8}.btn.edit{background:#4a90e2}.btn.add{background:#50e3c2}.btn.delete{background:#d0021b}.btn:disabled{background:#555!important;cursor:not-allowed;opacity:.5}.node-info-footer{padding-top:15px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:flex-end}.history-icon-btn{background:none;border:1px solid rgba(255,105,180,.5);color:#ff69b4;padding:5px 10px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .3s}.history-icon-btn:hover{background:#ff69b41a;box-shadow:0 0 10px #ff69b44d}.history-loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:15px;color:#ff69b4}.mini-loader{border:3px solid rgba(255,105,180,.1);border-top:3px solid #ff69b4;border-radius:50%;width:24px;height:24px;animation:spin .8s linear infinite}.history-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:650px;max-height:70vh;background:#1a1a2e;border:1px solid rgba(255,105,180,.4);border-radius:16px;z-index:2000;display:flex;flex-direction:column;box-shadow:0 0 60px #0009;padding:10px;color:#fff}.app-container.light-mode .history-modal{background:#fff;color:#1a1a2e}.modal-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1);text-align:center}.modal-header h3{margin:0;color:#ff69b4;font-size:1.3rem}.history-list{padding:10px 20px;overflow-y:auto;flex:1}.history-item{padding:15px;border-bottom:1px solid rgba(255,255,255,.05);font-size:.95rem;line-height:1.6}.history-time{color:#888;margin-right:12px}.history-user{font-weight:700}.history-user.admin{color:#0ff}.history-user.user{color:#ff69b4}.history-action.add{color:#50fa7b}.history-action.edit{color:#f1fa8c}.history-action.delete{color:#f55}.history-node-link{color:#ff69b4;text-decoration:underline;cursor:pointer}.site-info-panel{position:fixed;bottom:0;left:0;right:0;background:#1a1a2e;border-top:1px solid rgba(255,105,180,.5);z-index:1000;padding:40px;color:#fff;box-shadow:0 -10px 40px #0009;height:200px;box-sizing:border-box}.site-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:1200px;margin:0 auto}.info-section h4{color:#ff69b4;margin-bottom:20px;font-size:1.1rem;border-left:3px solid #ff69b4;padding-left:10px}.info-section p,.info-section a{color:#bbb;font-size:.95rem;text-decoration:none;display:block;margin-bottom:10px}.info-section a:hover{color:#ff1493}.legal-info{margin-top:30px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);text-align:center;font-size:.8rem;color:#666}.slide-enter-active,.slide-leave-active{transition:transform .5s ease}.slide-enter-from,.slide-leave-to{transform:translate(100%)}.slide-up-enter-active,.slide-up-leave-active{transition:transform .4s cubic-bezier(.165,.84,.44,1)}.slide-up-enter-from,.slide-up-leave-to{transform:translateY(100%)}@media screen and (max-width:768px){.top-left{top:10px;left:10px}.left-controls{flex-direction:column;align-items:flex-start;gap:8px}.top-right{top:10px;right:10px}.user-status{padding:6px 12px;max-width:140px;font-size:11px;white-space:nowrap;overflow:visible;text-overflow:ellipsis}.bottom-left{bottom:20px;left:10px;width:auto;right:120px}.search-container{width:100%}.bottom-right{bottom:20px;right:10px}.side-panel{width:100%;max-width:100%}.graph-container.shifted{transform:none;opacity:.3}.site-info-panel{padding:20px;height:auto;min-height:250px;max-height:400px;overflow-y:auto}.site-info-grid{grid-template-columns:1fr;gap:15px}.bottom-left.panel-up,.bottom-right.panel-up{transform:translateY(-280px)}}
