:root{--bg-primary: #FAFBFC;--bg-secondary: #FFFFFF;--bg-tertiary: #F1F3F5;--border-color: #E1E4E8;--border-light: #EBEDEF;--accent: #1E88E5;--accent-hover: #1565C0;--accent-light: #E3F2FD;--accent-subtle: #F0FBF5;--text-primary: #24292E;--text-secondary: #586069;--text-muted: #8B949E;--danger: #D73A49;--danger-hover: #CB2431;--danger-bg: #FFEEF0;--success: #28A745;--success-bg: #DCFFE4;--warning: #F9A825;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--sidebar-width: 280px;--header-height: 38px;--transition: .2s ease;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-family);font-size:14px;color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased}#root{height:100%}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:13px;font-family:inherit;cursor:pointer;transition:all var(--transition);white-space:nowrap}.btn:hover{background:var(--bg-tertiary);border-color:#ccd1d5}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-tertiary);border-color:var(--border-color)}.btn-ghost{background:#ffffff1a;border-color:#ffffff40;color:#ffffffe6;border-radius:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-weight:500;letter-spacing:.3px}.btn-ghost:hover{background:#fff3;border-color:#fff6;color:#fff;box-shadow:0 0 8px #ffffff1a}.btn-sm{padding:5px 10px;font-size:12px}.btn-outline{background:transparent}.btn-outline:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;cursor:pointer;color:#ffffffb3;transition:all var(--transition)}.btn-icon:hover{background:#ffffff26;color:#fff}.btn.has-changes{animation:pulse-save 1.5s infinite}@keyframes pulse-save{0%,to{box-shadow:0 0 #066f424d}50%{box-shadow:0 0 0 4px #066f4226}}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#42a5f5,#1e88e5,#0d47a1)}.login-card{background:var(--bg-secondary);padding:48px 40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:center;max-width:400px;width:90%}.login-logo{width:120px;height:auto;margin-bottom:16px}.login-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.login-subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:15px}.login-btn-container{display:flex;justify-content:center}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{display:flex;flex-direction:column;z-index:100;flex-shrink:0;position:relative;background:#fff;box-shadow:0 1px 8px #00000014}.header-bar{display:flex;align-items:center;justify-content:space-between;height:50px;padding:0 16px}.header-left{display:flex;align-items:center;gap:8px;flex-shrink:0}.header-brand{display:flex;align-items:center;text-decoration:none;transition:opacity .2s ease}.header-brand:hover{opacity:.85}.header-logo{height:34px;width:auto;object-fit:contain}.header-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.header-nav{display:flex;align-items:center;gap:2px}.header-tab{display:flex;align-items:center;gap:5px;padding:6px 14px;border:none;border-radius:6px;background:transparent;color:#555;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit;white-space:nowrap}.header-tab svg{flex-shrink:0;opacity:.6;stroke:#555}.header-tab:hover{color:#1e88e5;background:#f0f7ff}.header-tab:hover svg{opacity:1;stroke:#1e88e5}.header-tab.active{color:#1e88e5;background:#e8f2fd;font-weight:600}.header-tab.active svg{opacity:1;stroke:#1e88e5}.header-divider{width:1px;height:24px;background:#e0e0e0;margin:0 6px}.header-user{display:flex;align-items:center;gap:8px}.user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:2px solid #e0e0e0;transition:border-color .2s ease}.user-avatar:hover{border-color:#1e88e5}.user-name{font-size:13px;color:#444;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-back-mobile,.btn-menu-mobile{display:none}.btn-logout{color:#999;transition:all .2s ease;border-radius:6px;width:30px;height:30px}.btn-logout:hover{color:#e53935;background:#fff0f0}.btn-login{display:inline-flex;align-items:center;gap:5px;padding:6px 16px;border:1px solid #FF7043;border-radius:6px;background:#fff;color:#ff7043;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s ease}.btn-login:hover{background:#ff7043;color:#fff}.btn-login svg{flex-shrink:0}.header-nav-mobile{display:none}.app-statusbar{display:flex;align-items:center;height:30px;padding:0 12px;flex-shrink:0;z-index:100;justify-content:center;position:relative;background:#fafdfe;border-top:1px solid #eee}.statusbar-links{position:absolute;left:12px;display:flex;align-items:center;gap:4px}.statusbar-links a{color:#999;text-decoration:none;font-size:11px;transition:color .2s}.statusbar-links a:hover{color:#1e88e5}.statusbar-sep{color:#ccc;font-size:10px}.statusbar-loading{position:absolute;left:12px;top:50%;transform:translateY(-50%);display:flex;align-items:center}.statusbar-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.25);border-top-color:#ffffffe6;border-radius:50%;animation:spin .7s linear infinite}.statusbar-brand{display:flex;align-items:end;gap:6px;text-decoration:none;color:#1e88e5;font-size:11px;transition:color .2s ease}.statusbar-brand:hover{color:#1e88e5}.statusbar-logo{height:25px;object-fit:contain;opacity:1}.statusbar-brand:hover .statusbar-logo{opacity:1}.app-main{display:flex;flex:1;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background-color:#fcfcfc;border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:5px 12px;border-bottom:1px solid var(--border-light);display:flex;flex-direction:column;gap:3px}.search-box{display:flex;align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:0 8px;transition:border-color var(--transition)}.search-box:focus-within{border-color:var(--accent);background:var(--bg-secondary)}.search-icon{flex-shrink:0;color:var(--text-muted)}.search-input{flex:1;border:none;background:transparent;padding:7px 8px;font-size:13px;font-family:inherit;color:var(--text-primary);outline:none}.search-clear{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:12px;border-radius:50%}.search-clear:hover{background:var(--border-color);color:var(--text-primary)}.sidebar-actions{display:flex;gap:6px;flex-direction:row-reverse}.sidebar-actions .btn{border:none!important;color:#6dbf8e!important}.sidebar-actions .btn:hover{background:none!important;color:#ff7043!important}.sidebar-actions .btn-sm{padding:3px}.tree-container{flex:1;overflow-y:auto;padding:3px 10px}.tree-container::-webkit-scrollbar{width:6px}.tree-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.tree-container::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.tree-folder{position:relative}.tree-item{display:flex;align-items:center;cursor:pointer;transition:background var(--transition);-webkit-user-select:none;user-select:none;min-height:20px;position:relative}.tree-item:hover,.tree-item.active{color:var(--accent)}.tree-icon{font-size:16px;flex-shrink:0;margin-right:4px;display:flex;align-items:center}.tree-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:8px 0}.tree-menu-btn{opacity:.6;border:none;background:transparent;cursor:pointer;color:var(--text-muted);font-size:16px;padding:2px 4px;border-radius:var(--radius-sm);flex-shrink:0;transition:all var(--transition)}.tree-item:hover .tree-menu-btn{opacity:1}.tree-menu-btn:hover{background:var(--border-color);color:var(--text-primary)}.tree-children{position:relative;margin-left:9px;padding-left:18px}.tree-children:before{content:"";position:absolute;left:0;top:0;bottom:0;width:1px;background:#b0bec5}.tree-children>:last-child:before{content:"";position:absolute;left:-18px;top:50%;bottom:0;width:1px;background:var(--bg-secondary);z-index:1}.tree-children>.tree-folder>.tree-item:after,.tree-children>.tree-item.tree-file:after{content:"";position:absolute;left:-18px;top:50%;width:14px;height:1px;background:#b0bec5}.tree-empty{padding:24px;text-align:center;color:var(--text-muted);font-size:13px}.editor-area{flex:1;display:flex;flex-direction:row;overflow:hidden;background:var(--bg-primary)}.editor-placeholder{display:flex;align-items:center;justify-content:center;flex:1}.placeholder-content{text-align:center;color:var(--text-muted);width:100%}.placeholder-logo{width:120px;height:auto;opacity:.4;margin-bottom:16px}.editor-content{display:flex;flex-direction:column;flex:1;overflow:hidden}.editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-light);flex-shrink:0}.editor-filename{font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-breadcrumb{display:flex;align-items:center;overflow:hidden;min-width:0}.breadcrumb-path{font-size:12px;color:var(--text-muted);white-space:nowrap;flex-shrink:1;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:2px}.breadcrumb-path:not(:empty){margin-right:6px}.breadcrumb-path .breadcrumb-item{color:#606060}.breadcrumb-path .breadcrumb-sep{margin:0 3px;color:#606060}.btn-attachment-active{background:var(--accent-light)!important;border-color:var(--accent)!important;color:var(--accent)!important}.attachment-bar{display:flex;align-items:center;gap:8px;padding:6px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-light);flex-shrink:0;flex-wrap:wrap;min-height:36px}.attachment-list{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.attachment-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--accent-subtle);border:1px solid var(--accent-light);border-radius:20px;font-size:12px;max-width:200px;transition:all var(--transition)}.attachment-chip:hover{background:var(--accent-light);border-color:var(--accent)}.attachment-name{display:inline-flex;align-items:center;gap:4px;color:var(--accent);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}.attachment-name:hover{text-decoration:underline}.attachment-delete{border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:10px;padding:1px 3px;border-radius:50%;line-height:1;transition:all var(--transition)}.attachment-delete:hover{background:var(--danger-bg);color:var(--danger)}.attachment-add-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border:1px dashed var(--border-color);border-radius:20px;background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer;font-family:inherit;transition:all var(--transition)}.attachment-add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.attachment-add-btn:disabled{opacity:.5;cursor:not-allowed}.editor-body{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0;position:relative}.editor-body .tox.tox-tinymce{flex:1;min-height:400px;border:none!important;border-radius:0!important}.tox .tox-edit-area{height:500px!important;min-height:500px!important}.tox .tox-edit-area:before{border:1px solid #f0f5fb!important;border-radius:0!important;content:""}.editor-plain{flex:1;width:100%;border:none;padding:16px;font-family:SF Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:14px;line-height:1.6;color:var(--text-primary);background:var(--bg-secondary);resize:none;outline:none}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1000;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-overlay.active{display:flex}.modal{background:var(--bg-secondary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:90%;max-width:420px;padding:24px;animation:modal-in .2s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-title{font-size:16px;font-weight:600;margin-bottom:12px}.modal-body{margin-bottom:20px;color:var(--text-secondary);font-size:14px}.modal-body p{margin-bottom:8px}.modal-input{width:100%;padding:9px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--text-primary);outline:none;transition:border-color var(--transition)}.modal-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #066f421a}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.move-list{max-height:300px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--radius-sm)}.move-item{display:block;width:100%;padding:10px 12px;border:none;background:transparent;text-align:left;font-size:13px;font-family:inherit;color:var(--text-primary);cursor:pointer;transition:background var(--transition)}.move-item:hover{background:var(--accent-light)}.move-item+.move-item{border-top:1px solid var(--border-light)}.context-menu{position:fixed;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:180px;padding:4px;z-index:500;animation:ctx-in .15s ease}@keyframes ctx-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:transparent;font-size:13px;font-family:inherit;color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition)}.context-menu-item:hover{background:var(--bg-tertiary)}.context-menu-item.danger{color:var(--danger)}.context-menu-item.danger:hover{background:var(--danger-bg)}.context-menu-icon{font-size:14px;width:18px;text-align:center}.context-menu-separator{height:1px;background:var(--border-light);margin:4px 8px}.loading-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#fff9;z-index:2000;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.loading-overlay.active{display:flex}.spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;bottom:20px;right:20px;z-index:3000;display:flex;flex-direction:column;gap:8px}.toast{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--bg-secondary);border-radius:var(--radius-md);box-shadow:var(--shadow-md);font-size:13px;transform:translate(120%);transition:transform .3s ease;border-left:3px solid var(--accent)}.toast.show{transform:translate(0)}.toast-success{border-left-color:var(--success)}.toast-error{border-left-color:var(--danger)}.toast-icon{font-size:16px;flex-shrink:0}.notification-bar-container{flex-shrink:0}.notification-bar{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#ffa726,#ff9800 40%,#fb8c00);background:linear-gradient(135deg,#f5f9ff,#fff2df 40%,#f5fdff);color:#1e88e5;font-size:13px;animation:notif-slide-in .4s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden;padding:10px;font-weight:700}.notification-bar:before{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);animation:notif-shimmer 4s ease-in-out infinite;pointer-events:none}@keyframes notif-shimmer{0%,to{left:-50%}50%{left:100%}}@keyframes notif-slide-in{0%{opacity:0;max-height:0;padding-top:0;padding-bottom:0}to{opacity:1;max-height:60px;padding-top:9px;padding-bottom:9px}}.notification-bar-inner{display:flex;align-items:center;gap:10px;min-width:0}.notification-icon{font-size:16px;flex-shrink:0;filter:drop-shadow(0 1px 2px rgba(0,0,0,.15))}.notification-message{font-weight:500;letter-spacing:.15px;word-break:break-word}.notification-dismiss{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:50%;background:#ffffff2e;color:#980000;cursor:pointer;flex-shrink:0;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.notification-dismiss:hover{background:#ffffff59;transform:scale(1.1)}.notification-dismiss:active{transform:scale(.95)}.notification-info{background:linear-gradient(135deg,#f5f9ff,#d4f7f6 40%,#f5fdff);color:#1e88e5}.notification-success{background:linear-gradient(135deg,#f5f9ff,#d4f7f6 40%,#f5fdff);color:#106f01}.notification-warning{background:linear-gradient(135deg,#f5f9ff,#d4f7f6 40%,#f5fdff);color:#a85f01}.notification-error{background:linear-gradient(135deg,#f5f9ff,#d4f7f6 40%,#f5fdff);color:#a70000}.tox .tox-tbtn{color:#aeadad!important}.tox .tox-tbtn svg{fill:#aeadad!important}.tox .tox-collection--list .tox-collection__item--active:not(.tox-collection__item--state-disabled){background-color:#ddf5ea!important;color:#1e88e5!important}.tox .tox-tbtn--active,.tox .tox-tbtn--enabled,.tox .tox-tbtn--enabled:focus,.tox .tox-tbtn--enabled:hover{background:#e3f2fd!important}.znads-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:5000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:znads-fade-in .3s ease;cursor:pointer}@keyframes znads-fade-in{0%{opacity:0}to{opacity:1}}.znads-content{background:#fff;border-radius:16px;padding:32px 28px;text-align:center;max-width:320px;width:85%;box-shadow:0 20px 60px #0000004d;animation:znads-slide-up .35s cubic-bezier(.22,1,.36,1)}@keyframes znads-slide-up{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.znads-icon{font-size:48px;margin-bottom:12px}.znads-title{font-size:20px;font-weight:700;color:#ee4d2d;margin-bottom:8px}.znads-desc{font-size:14px;color:#666;margin-bottom:20px}.znads-btn{display:inline-block;padding:12px 36px;background:linear-gradient(135deg,#ee4d2d,#f63);color:#fff;border:none;border-radius:24px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 4px 15px #ee4d2d59}.znads-btn:active{transform:scale(.96)}.znads-dismiss{margin-top:14px;font-size:13px;color:#999;cursor:pointer;transition:color .2s}.znads-dismiss:active{color:#666}@media(max-width:768px){:root{--header-height: 82px}.app-header{height:auto}.header-bar{height:46px;padding:0 10px;justify-content:center;position:relative}.header-logo{height:28px}.header-nav,.header-divider,.header-user .user-name{display:none}.header-right{position:absolute;right:10px}.btn-login span{display:none}.header-left{position:static}.btn-menu-mobile,.btn-back-mobile{position:absolute;left:10px}.header-nav-mobile{display:flex;flex-wrap:wrap;gap:0;border-top:1px solid #eee;background:#fafbfc}.header-tab-mobile{display:flex;align-items:center;justify-content:center;gap:5px;flex:1;min-width:0;padding:8px 6px;border:none;background:transparent;color:#666;font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s ease;white-space:nowrap;border-bottom:2px solid transparent}.header-tab-mobile svg{flex-shrink:0;opacity:.6;stroke:#666}.header-tab-mobile:hover{color:#1e88e5;background:#f0f7ff}.header-tab-mobile:hover svg{stroke:#1e88e5;opacity:1}.header-tab-mobile.active{color:#1e88e5;border-bottom-color:#1e88e5;font-weight:600}.header-tab-mobile.active svg{stroke:#1e88e5;opacity:1}.sidebar{position:fixed;top:var(--header-height);left:0;bottom:0;width:280px;z-index:60;transform:translate(-100%);transition:transform .3s ease;box-shadow:none}.sidebar.sidebar-mobile-open{transform:translate(0)!important;box-shadow:var(--shadow-lg);z-index:70}.editor-area{position:relative;flex:1}.app-container.file-open .sidebar:not(.sidebar-mobile-open){transform:translate(-100%)}.app-container.file-open .editor-area{transform:translate(0)}.app-container.file-open .btn-back-mobile,.btn-menu-mobile{display:flex}.sidebar-backdrop{position:fixed;inset:var(--header-height) 0 0 0;background:#0000004d;z-index:65}.user-name{display:none}.app-statusbar{bottom:0;left:0;right:0;z-index:200;flex-direction:column;height:auto;padding:6px 12px;gap:2px}.statusbar-links{position:static;justify-content:center}}@media(max-width:480px){.login-card{padding:32px 24px}.login-title{font-size:24px}}.editor-props-sidebar{width:280px;min-width:280px;border-left:1px solid var(--border-color);background:var(--bg-secondary);display:flex;flex-direction:column;overflow-y:auto}.props-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border-light);flex-shrink:0}.props-header h3{font-size:13px;font-weight:600;margin:0}.props-body{padding:12px 14px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.props-group{display:flex;flex-direction:column;gap:4px}.props-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.props-input{padding:6px 10px;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;color:var(--text-primary);background:var(--bg-primary);outline:none;transition:border-color var(--transition);width:100%}.props-input:focus{border-color:var(--accent);background:var(--bg-secondary)}.props-textarea{resize:vertical;min-height:60px}.props-hint{font-size:11px;color:var(--text-muted)}.props-thumbnail{border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-light)}.props-thumbnail img{width:100%;height:140px;object-fit:cover;display:block}.props-thumb-actions{display:flex;gap:6px;padding:6px;background:var(--bg-tertiary)}.props-upload-btn{width:100%;justify-content:center}.props-divider{height:1px;background:var(--border-light);margin:4px 0}.props-section-title{font-size:12px;font-weight:600;color:var(--accent);margin:0}.btn-icon{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:14px;padding:2px 4px;border-radius:var(--radius-sm)}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-danger-outline{color:var(--danger)!important;border-color:var(--danger)!important}.btn-danger-outline:hover{background:var(--danger-bg)!important}@media(max-width:768px){.editor-props-sidebar{position:fixed;right:0;top:var(--header-height);bottom:0;z-index:100;box-shadow:var(--shadow-lg)}}.article-page{flex:1;flex-direction:column!important;overflow-y:auto;padding:0}.article-breadcrumb{padding:10px 24px;border-bottom:1px solid var(--border-light);background:var(--bg-primary)}.breadcrumb-list{display:flex;flex-wrap:wrap;align-items:center;gap:0;list-style:none;padding:0;margin:0;font-size:13px}.breadcrumb-li{display:flex;align-items:center;gap:0}.breadcrumb-link{color:var(--text-secondary);text-decoration:none;padding:2px 4px;border-radius:var(--radius-sm);transition:color var(--transition)}a.breadcrumb-link:hover{color:var(--accent);text-decoration:underline}.breadcrumb-current{color:var(--text-primary);font-weight:500}.breadcrumb-sep{margin:0 4px;color:var(--text-muted);font-size:12px}.article-header{padding:20px 24px 12px;border-bottom:1px solid var(--border-light)}.article-title{font-size:1.6rem;font-weight:700;line-height:1.3;color:var(--text-primary);margin:0 0 8px}.article-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--text-muted)}.article-date,.article-reading-time,.article-updated{display:flex;align-items:center;gap:4px}.article-body{padding:0}.article-html-content{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.7;color:#333;padding:20px 24px;max-width:100%}.article-html-content h1{font-size:1.8rem;margin:1.5rem 0 1rem}.article-html-content h2{font-size:1.5rem;margin:1.5rem 0 1rem}.article-html-content h3{font-size:1.25rem;margin:1.25rem 0 .75rem}.article-html-content p{margin:0 0 1rem}.article-html-content img{max-width:100%;height:auto;border-radius:4px}.article-html-content pre{background:#2d2d2d;padding:16px 20px;border-radius:8px;overflow-x:auto;font-size:14px;line-height:1.5;margin:1rem 0;border:1px solid #444}.article-html-content pre code{background:none;padding:0;border-radius:0;font-size:inherit;color:inherit}.article-html-content code{background:#f0f2f5;padding:2px 6px;border-radius:3px;font-size:.9em;font-family:SF Mono,Fira Code,Consolas,monospace}.article-html-content table{width:100%;border-collapse:collapse;margin:1rem 0}.article-html-content th,.article-html-content td{border:1px solid var(--border-color);padding:8px 12px;text-align:left}.article-html-content th{background:var(--bg-tertiary);font-weight:600}.article-html-content blockquote{border-left:3px solid var(--accent);padding-left:16px;margin:1rem 0;color:var(--text-secondary)}.article-html-content ul,.article-html-content ol{padding-left:24px;margin:.5rem 0 1rem}.article-share-btns{display:flex;gap:6px;align-items:center;margin-left:auto}.share-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);text-decoration:none}.share-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.share-fb:hover{color:#1877f2;border-color:#1877f2}.tree-status-badge{font-size:10px;flex-shrink:0;margin-right:2px;opacity:.7}.homepage{flex-direction:column!important}.homepage-scroll{flex:1;overflow-y:auto;padding:0}.homepage-hero{text-align:center;padding:40px 24px 24px;background:linear-gradient(135deg,var(--accent-light) 0%,var(--bg-primary) 100%);border-bottom:1px solid var(--border-light)}.homepage-logo{width:80px;height:auto;opacity:.85;margin-bottom:12px}.homepage-title{font-size:1.5rem;font-weight:700;color:var(--accent);margin:0 0 6px}.homepage-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.homepage-section{padding:20px 24px;border-bottom:1px solid var(--border-light)}.homepage-section:last-child{border-bottom:none}.homepage-section-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.homepage-tools{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}.tool-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:all var(--transition)}.tool-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.tool-icon{font-size:28px;flex-shrink:0}.tool-info h3{font-size:14px;font-weight:600;margin:0 0 2px;color:var(--text-primary)}.tool-info p{font-size:12px;color:var(--text-muted);margin:0}.tool-link{margin-left:auto;font-size:12px;color:var(--accent);white-space:nowrap}.homepage-articles{display:flex;flex-direction:column;gap:2px}.article-card{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);text-decoration:none;color:inherit;transition:background var(--transition)}.article-card:hover{background:var(--accent-light)}.article-card-thumb{width:48px;height:36px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.article-card-body{flex:1;min-width:0}.article-card-title{font-size:13px;font-weight:500;margin:0;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.article-card-date{font-size:11px;color:var(--text-muted)}.category-header{padding:28px 24px 16px;border-bottom:1px solid var(--border-light)}.category-title{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.category-desc{font-size:13px;color:var(--text-secondary);margin:0 0 8px}.category-article-count{font-size:12px;color:var(--text-muted)}.category-empty{color:var(--text-muted);font-size:14px;text-align:center;padding:40px 0}.category-count{margin-left:auto;font-size:11px;background:var(--accent-light);color:var(--accent);padding:1px 7px;border-radius:10px;font-weight:500}.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.tools-grid-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 16px;border-radius:12px;border:1px solid var(--border-light);background:#fff;text-decoration:none;color:var(--text-primary);transition:all .2s ease}.tools-grid-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #066f421a;transform:translateY(-2px)}.tools-grid-icon{font-size:36px;margin-bottom:12px}.tools-grid-name{font-size:15px;font-weight:600;margin:0 0 6px}.tools-grid-desc{font-size:12px;color:var(--text-secondary);margin:0 0 10px;line-height:1.4}.tools-grid-link{font-size:11px;color:var(--accent);font-weight:500}.tool-page{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:20px;overflow-y:auto;background:linear-gradient(135deg,#f5f7fa,#e8edf5);min-height:calc(100vh - var(--header-height))}.tool-page-inner{width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:24px}.timer-mode-tabs{display:flex;background:#e0e5ec;border-radius:12px;padding:4px;gap:4px;width:100%}.timer-mode-tab{flex:1;padding:10px 0;border:none;border-radius:10px;background:transparent;font-size:14px;font-weight:500;color:#666;cursor:pointer;transition:all .2s}.timer-mode-tab.active{background:#fff;color:var(--accent);box-shadow:0 2px 8px #0000001a;font-weight:600}.timer-display{width:100%;display:flex;flex-direction:column;align-items:center;gap:20px}.timer-time{font-size:56px;font-weight:200;font-family:SF Mono,Fira Code,monospace;color:#1a1a2e;letter-spacing:2px}.timer-ms{font-size:28px;font-weight:300;color:#888;margin-top:-16px}.timer-actions{display:flex;gap:12px}.timer-btn{padding:12px 28px;border:none;border-radius:28px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.timer-btn-start{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.timer-btn-start:hover{transform:scale(1.05);box-shadow:0 4px 15px #28a7454d}.timer-btn-stop{background:linear-gradient(135deg,#dc3545,#e74c5a);color:#fff}.timer-btn-stop:hover{transform:scale(1.05)}.timer-btn-lap{background:#e0e5ec;color:#333}.timer-btn-reset{background:#e0e5ec;color:#555}.timer-btn-reset:hover{background:#d0d5dc}.timer-laps{width:100%;margin-top:8px}.timer-laps h3{font-size:13px;color:#888;text-transform:uppercase;letter-spacing:1px;margin:0 0 8px}.timer-laps-list{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.timer-lap-item{display:flex;justify-content:space-between;padding:8px 12px;background:#fff;border-radius:8px;font-size:14px}.lap-num{color:#888;font-weight:500}.lap-time{font-family:SF Mono,monospace;color:#333}.countdown-input{display:flex;align-items:center;gap:8px}.countdown-input-group{display:flex;flex-direction:column;align-items:center}.countdown-num{width:72px;padding:12px 0;text-align:center;border:2px solid #e0e5ec;border-radius:12px;font-size:32px;font-weight:300;color:#1a1a2e;background:#fff;outline:none;transition:border-color .2s;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.countdown-num::-webkit-inner-spin-button,.countdown-num::-webkit-outer-spin-button{-webkit-appearance:none}.countdown-num:focus{border-color:var(--accent)}.countdown-input-group label{font-size:11px;color:#888;margin-top:4px;text-transform:uppercase;letter-spacing:1px}.countdown-sep{font-size:32px;color:#ccc;font-weight:300;margin-bottom:20px}.countdown-progress-ring{position:relative;width:350px;height:350px}.countdown-svg{width:100%;height:100%;transform:rotate(-90deg)}.countdown-track{fill:none;stroke:#e0e5ec;stroke-width:8}.countdown-fill{fill:none;stroke:var(--accent);stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .1s linear}.countdown-time-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.countdown-time-overlay .timer-time{font-size:36px}.countdown-finished{font-size:24px;font-weight:600;color:#dc3545;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.calc-container{width:100%;max-width:380px;background:#1a1a2e;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #00000026}.calc-display{padding:24px 20px 16px;text-align:right}.calc-expression{font-size:14px;color:#fff6;min-height:20px;word-break:break-all}.calc-result{font-size:40px;font-weight:300;color:#fff;font-family:SF Mono,Fira Code,monospace;word-break:break-all;line-height:1.2}.calc-sci-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;padding:0 8px;margin-bottom:2px}.calc-sci{font-size:12px!important;padding:8px 4px!important;background:#16213e!important;color:#a8b4d0!important;border-radius:6px!important}.calc-sci:hover{background:#1f3460!important;color:#fff!important}.calc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;padding:8px}.calc-btn{padding:18px 0;border:none;border-radius:10px;font-size:20px;font-weight:400;cursor:pointer;background:#16213e;color:#fff;transition:all .1s}.calc-btn:hover{background:#1f3460}.calc-btn:active{transform:scale(.95)}.calc-func{background:#2a3a5c!important;color:#a8b4d0!important;font-size:16px}.calc-func:hover{background:#3a4a6c!important}.calc-op{background:#0f3460!important;color:#64b5f6!important;font-size:22px;font-weight:500}.calc-op:hover{background:#1a4a80!important}.calc-eq{background:linear-gradient(135deg,#1e88e5,#42a5f5)!important;color:#fff!important;font-size:24px;font-weight:600}.calc-eq:hover{background:linear-gradient(135deg,#42a5f5,#1e88e5)!important}.calc-history{padding:12px 16px 16px;border-top:1px solid rgba(255,255,255,.06)}.calc-history h4{font-size:11px;color:#ffffff4d;text-transform:uppercase;letter-spacing:1px;margin:0 0 8px}.calc-history-item{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;cursor:pointer;transition:color .2s}.calc-history-item:hover{color:#64b5f6}.calc-hist-expr{color:#fff6}.calc-hist-result{color:#ffffffb3;font-family:monospace}.converter-container{width:100%;max-width:520px;display:flex;flex-direction:column;gap:16px}.converter-cats{display:flex;gap:6px;flex-wrap:wrap}.converter-cat{padding:8px 14px;border:1px solid #e0e5ec;border-radius:10px;background:#fff;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.converter-cat:hover{border-color:var(--accent)}.converter-cat.active{background:var(--accent);color:#fff;border-color:var(--accent)}.converter-main{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 20px #0000000f}.converter-row{display:flex;align-items:flex-end;gap:12px}.converter-field{flex:1;display:flex;flex-direction:column;gap:6px}.converter-field label{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:1px;font-weight:600}.converter-field select{padding:10px 12px;border:1px solid #e0e5ec;border-radius:10px;font-size:13px;background:#f8f9fb;outline:none;cursor:pointer}.converter-field select:focus{border-color:var(--accent)}.converter-input{padding:14px 12px;border:2px solid #e0e5ec;border-radius:12px;font-size:22px;font-weight:300;text-align:center;outline:none;transition:border-color .2s;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.converter-input::-webkit-inner-spin-button,.converter-input::-webkit-outer-spin-button{-webkit-appearance:none}.converter-input:focus{border-color:var(--accent)}.converter-result{padding:14px 12px;border:2px solid var(--accent);border-radius:12px;font-size:22px;font-weight:600;text-align:center;color:var(--accent);background:#066f420a;min-height:54px;display:flex;align-items:center;justify-content:center;word-break:break-all}.converter-swap{padding:10px;border:1px solid #e0e5ec;border-radius:50%;background:#fff;font-size:20px;cursor:pointer;transition:all .2s;margin-bottom:18px;flex-shrink:0}.converter-swap:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.converter-all{background:#fff;border-radius:16px;padding:16px 20px;box-shadow:0 4px 20px #0000000f}.converter-all h4{font-size:12px;color:#888;text-transform:uppercase;letter-spacing:1px;margin:0 0 10px}.converter-all-list{display:flex;flex-direction:column;gap:2px}.converter-all-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f0f2f5;font-size:14px}.converter-all-item:last-child{border-bottom:none}.converter-all-name{color:#666}.converter-all-val{font-family:SF Mono,monospace;color:#1a1a2e;font-weight:500}@media(max-width:500px){.converter-row{flex-direction:column;align-items:stretch}.converter-swap{align-self:center;margin-bottom:0}}.qr-split{width:100%;max-width:800px;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}.qr-title{font-size:20px;font-weight:600;color:#1a1a2e;margin:0 0 12px}.qr-input-section{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 20px #0000000f}.qr-textarea{width:100%;padding:14px;border:2px solid #e0e5ec;border-radius:12px;font-size:15px;resize:vertical;outline:none;font-family:inherit;transition:border-color .2s;box-sizing:border-box}.qr-textarea:focus{border-color:var(--accent)}.qr-options{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}.qr-option{display:flex;flex-direction:column;gap:4px}.qr-option label{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:1px;font-weight:600}.qr-option select,.qr-option input[type=color]{padding:8px;border:1px solid #e0e5ec;border-radius:8px;font-size:13px;outline:none;cursor:pointer}.qr-option input[type=color]{height:36px;padding:2px}.qr-preview-section{display:flex;flex-direction:column;align-items:center;gap:14px;position:sticky;top:20px}.qr-canvas-wrap{display:flex;align-items:center;justify-content:center;border-radius:16px;padding:20px;box-shadow:0 4px 20px #0000000f;min-width:200px;min-height:200px}.qr-canvas-wrap canvas{border-radius:4px;max-width:100%;height:auto}.qr-placeholder{color:#aaa;font-size:14px;text-align:center;padding:40px 20px}.qr-actions{display:flex;gap:10px}.qr-download,.qr-copy{padding:10px 20px;border:none;border-radius:24px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.qr-download{background:linear-gradient(135deg,#1e88e5,#42a5f5);color:#fff}.qr-download:hover{transform:scale(1.05);box-shadow:0 4px 15px #066f424d}.qr-copy{background:#e0e5ec;color:#333}.qr-copy:hover{background:#d0d5dc}.qr-copy.copied{background:#28a745;color:#fff}.qr-option-full{grid-column:1 / -1}.qr-logo-row{display:flex;align-items:center;gap:8px}.qr-logo-row input[type=file]{font-size:13px}.qr-logo-clear{background:none;border:1px solid #ddd;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;color:#888}.qr-logo-clear:hover{background:#f0f0f0}.qr-logo-note{font-size:11px;color:#888;font-style:italic}@media(max-width:640px){.qr-split{grid-template-columns:1fr}}.encode-container{width:100%;max-width:560px;display:flex;flex-direction:column;gap:12px}.encode-textarea{width:100%;padding:14px;border:2px solid #e0e5ec;border-radius:12px;font-size:14px;font-family:SF Mono,Fira Code,monospace;resize:vertical;outline:none;transition:border-color .2s;box-sizing:border-box;background:#fff}.encode-textarea:focus{border-color:var(--accent)}.encode-output{background:#f8f9fb}.encode-label{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:1px;font-weight:600}.encode-label-row{display:flex;justify-content:space-between;align-items:center}.encode-split{display:grid;grid-template-columns:1fr 1fr;gap:16px}.encode-pane{display:flex;flex-direction:column;gap:6px}.hash-results{display:flex;flex-direction:column;gap:6px;background:#fff;border-radius:12px;padding:16px;box-shadow:0 4px 20px #0000000f}.hash-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #f0f2f5}.hash-row:last-child{border-bottom:none}.hash-label{font-size:12px;font-weight:600;color:#888;min-width:65px;flex-shrink:0}.hash-value{font-size:12px;font-family:SF Mono,monospace;color:#1a1a2e;word-break:break-all;flex:1}.hash-copy{padding:4px 10px;border:1px solid #e0e5ec;border-radius:6px;background:#fff;font-size:12px;cursor:pointer;flex-shrink:0;transition:all .2s}.hash-copy:hover{background:#f0f2f5}.hash-copy.copied{background:#28a745;color:#fff;border-color:#28a745}.regex-pattern-row{display:flex;align-items:center;gap:4px;background:#fff;border:2px solid #e0e5ec;border-radius:12px;padding:4px 12px}.regex-pattern-row:focus-within{border-color:var(--accent)}.regex-slash{font-size:20px;color:#ccc;font-weight:300}.regex-pattern-input{flex:1;border:none;outline:none;font-size:16px;font-family:SF Mono,monospace;padding:8px 0;background:transparent}.regex-flags-input{border:none;outline:none;font-size:16px;font-family:SF Mono,monospace;padding:8px 0;color:var(--accent);font-weight:600;background:transparent}.regex-error{font-size:13px;color:#dc3545;padding:6px 12px;background:#fff5f5;border-radius:8px}.regex-section{display:flex;flex-direction:column;gap:6px;margin-top:4px}.regex-highlighted{background:#fff;border:1px solid #e0e5ec;border-radius:10px;padding:14px;font-family:SF Mono,monospace;font-size:14px;white-space:pre-wrap;word-break:break-all;line-height:1.8}mark.regex-match{border-radius:3px;padding:1px 2px}mark.regex-match-0{background:#fde68a;color:#92400e}mark.regex-match-1{background:#a7f3d0;color:#065f46}.regex-matches{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.regex-match-item{display:flex;align-items:center;gap:10px;padding:6px 10px;background:#fff;border-radius:8px;font-size:13px;border:1px solid #f0f2f5}.regex-match-idx{font-weight:600;color:#888}.regex-match-text{color:#1a1a2e}.regex-match-pos{color:#888;font-size:11px}.regex-match-groups{color:var(--accent);font-size:11px}@media(max-width:600px){.encode-split{grid-template-columns:1fr}}.short-form{display:flex;flex-direction:column;gap:8px}.short-url-input,.short-title-input{padding:12px 14px;border:2px solid #e0e5ec;border-radius:12px;font-size:15px;outline:none;transition:border-color .2s}.short-url-input:focus,.short-title-input:focus{border-color:var(--accent)}.short-title-input{font-size:13px}.short-submit{padding:12px;border:none;border-radius:12px;background:linear-gradient(135deg,#1e88e5,#42a5f5);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.short-submit:hover{transform:scale(1.02)}.short-submit:disabled{opacity:.5;cursor:default;transform:none}.short-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.short-item{background:#fff;border-radius:12px;padding:14px;box-shadow:0 2px 12px #0000000a;border:1px solid #f0f2f5;display:flex;flex-wrap:wrap;gap:10px}.short-item.inactive{opacity:.5}.short-item-main{flex:1;min-width:200px}.short-item-short{font-family:SF Mono,monospace;font-size:14px;color:var(--accent);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.short-item-short:hover{text-decoration:underline}.short-copied{color:#28a745;font-size:12px}.short-item-url{font-size:13px;color:#666;margin-top:4px;word-break:break-all;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:400px}.short-item-meta{display:flex;gap:14px;margin-top:6px;font-size:12px;color:#aaa}.short-item-actions{display:flex;gap:4px;align-items:flex-start}.short-item-actions button{background:none;border:1px solid #e0e5ec;border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:background .2s}.short-item-actions button:hover{background:#f0f2f5}.short-stats{width:100%;border-top:1px solid #f0f2f5;padding-top:10px;margin-top:4px}.short-stats-total{font-size:13px;color:#666;margin-bottom:8px}.short-chart{display:flex;gap:2px;align-items:flex-end;height:100px;padding:4px 0;overflow-x:auto}.short-chart-bar-wrap{display:flex;flex-direction:column;align-items:center;flex:1;min-width:18px}.short-chart-bar{width:12px;background:linear-gradient(to top,#1e88e5,#64b5f6);border-radius:3px 3px 0 0;min-height:2px;transition:height .3s}.short-chart-label{font-size:9px;color:#aaa;margin-top:2px;white-space:nowrap}.admin-settings-panel{padding:10px 14px;border-bottom:1px solid #e8e8e8;background:#f8f9fb}.admin-settings-label{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:1px;font-weight:600;display:block;margin-bottom:6px}.admin-settings-row{display:flex;gap:6px}.admin-settings-input{flex:1;padding:6px 10px;border:1px solid #ddd;border-radius:8px;font-size:13px;outline:none}.admin-settings-input:focus{border-color:var(--accent)}.admin-settings-save{padding:6px 14px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:12px;font-weight:600;cursor:pointer}.admin-settings-save:hover{opacity:.9}.admin-tool-form{padding:8px 0;border-bottom:1px solid #e8e8e8}.admin-tools-list{max-height:200px;overflow-y:auto;margin-top:6px}.admin-tool-item{display:flex;align-items:center;gap:6px;padding:4px 0;border-bottom:1px solid #f0f0f0;font-size:12px}.admin-tool-icon{flex-shrink:0}.admin-tool-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-tool-actions{display:flex;gap:2px;flex-shrink:0}.admin-tool-actions button{background:none;border:none;cursor:pointer;padding:2px 4px;font-size:12px;opacity:.6}.admin-tool-actions button:hover{opacity:1}.admin-toolbar{display:flex;gap:0;background:#fff;border-bottom:1px solid #e8e8e8;padding:0 16px;flex-shrink:0}.admin-toolbar-tab{padding:10px 20px;border:none;background:none;font-size:13px;font-weight:500;color:#666;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.admin-toolbar-tab:hover{color:#333;background:#f8f9fb}.admin-toolbar-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.admin-page{flex:1;padding:24px 32px;overflow-y:auto}.admin-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.admin-page-header h2{font-size:18px;font-weight:600;color:#333;margin:0}.admin-page-count{font-size:13px;color:#999;margin-left:12px}.admin-section{margin-bottom:24px}.admin-section-subtitle{font-size:14px;font-weight:600;color:#555;margin-bottom:10px}.admin-section-row{display:flex;gap:8px}.admin-search-form{display:flex;gap:8px;margin-bottom:20px;max-width:500px}.admin-input{padding:8px 12px;border:1px solid #ddd;border-radius:8px;font-size:13px;outline:none;width:100%;box-sizing:border-box}.admin-input:focus{border-color:var(--accent)}.admin-btn-primary{padding:8px 18px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}.admin-btn-primary:hover{opacity:.9}.admin-btn-secondary{padding:8px 16px;border:1px solid #ddd;border-radius:8px;background:#fff;color:#666;font-size:13px;cursor:pointer;white-space:nowrap}.admin-btn-sm{background:none;border:none;cursor:pointer;padding:4px 6px;font-size:13px;opacity:.6;border-radius:4px}.admin-btn-sm:hover{opacity:1;background:#f0f0f0}.admin-btn-sm.btn-danger:hover{background:#fee}.admin-btn-sm.btn-success:hover{background:#efe}.admin-table{border:1px solid #e8e8e8;border-radius:10px;overflow:hidden;max-width:900px}.admin-table-head{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#f8f9fb;font-size:11px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px}.admin-table-row{display:flex;align-items:center;gap:12px;padding:10px 16px;border-top:1px solid #f0f0f0;font-size:13px}.admin-table-row:hover{background:#fafbfc}.admin-table-row.row-inactive{opacity:.5}.admin-table-empty{padding:24px;text-align:center;color:#999;font-size:13px}.admin-text-muted{color:#999;font-size:12px}.col-avatar{width:32px;flex-shrink:0}.col-icon{width:28px;flex-shrink:0;font-size:18px}.col-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-email{flex:1.5;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;color:#666}.col-url{flex:1.5;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-role,.col-status{width:70px;flex-shrink:0}.col-clicks{width:50px;flex-shrink:0;text-align:center}.col-code{width:80px;flex-shrink:0}.col-badges{width:60px;flex-shrink:0;display:flex;gap:4px}.col-date{width:90px;flex-shrink:0;font-size:12px;color:#999}.col-actions{width:120px;flex-shrink:0;display:flex;gap:2px;justify-content:flex-end}.badge-role,.badge-status{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600}.badge-role.admin{background:#e8f4fe;color:#2563eb}.badge-role.member{background:#f0f0f0;color:#666}.badge-status.active{background:#e8fbe8;color:#16a34a}.badge-status.inactive{background:#fee;color:#dc2626}.badge-pin,.badge-ext{font-size:10px;padding:1px 5px;border-radius:4px;background:#e8f4fe}.admin-user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.admin-pagination{display:flex;align-items:center;gap:12px;margin-top:16px;font-size:13px;color:#666}.admin-pagination button{padding:6px 14px;border:1px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:12px}.admin-pagination button:disabled{opacity:.4;cursor:default}.admin-pagination button:not(:disabled):hover{background:#f8f9fb}.admin-tool-edit{background:#f8f9fb;border:1px solid #e8e8e8;border-radius:10px;padding:14px;margin-bottom:16px;display:flex;flex-direction:column;gap:8px;max-width:900px}.admin-tool-edit-row{display:flex;gap:8px}.admin-tool-edit-options{display:flex;align-items:center;gap:14px;font-size:12px;flex-wrap:wrap;margin-top:4px}
