.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:220px;background:#001529;color:#fff;overflow-y:auto;flex-shrink:0}.admin-sidebar h1{padding:16px;font-size:18px;text-align:center;border-bottom:1px solid #0d2137}.sidebar-group{margin-bottom:4px}.sidebar-group-title{padding:8px 16px;font-size:13px;color:#8c8c8c;text-transform:uppercase;cursor:pointer;display:flex;justify-content:space-between;align-items:center;-webkit-user-select:none;user-select:none;transition:color .2s}.sidebar-group-title:hover{color:#bfbfbf}.sidebar-group-arrow{font-size:12px}.sidebar-link{display:block;padding:8px 16px 8px 28px;font-size:14px;color:#ffffffa6;transition:all .2s}.sidebar-link:hover,.sidebar-link.active{color:#fff;background:#1677ff}.admin-main{flex:1;display:flex;flex-direction:column}.admin-header{height:48px;background:#fff;display:flex;align-items:center;justify-content:flex-end;padding:0 24px;box-shadow:0 1px 4px #00000014}.admin-header button{background:none;border:none;cursor:pointer;color:#666;font-size:14px}.admin-content{flex:1;padding:16px;overflow-y:auto}.login-wrapper{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#f0f2f5}.login-form{width:360px;padding:32px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.login-form h2{text-align:center;margin-bottom:24px}.login-form label{display:block;margin-bottom:4px;font-size:14px}.login-form input{width:100%;padding:8px 12px;margin-bottom:16px;border:1px solid #d9d9d9;border-radius:4px;font-size:14px}.login-form button{width:100%;padding:10px;background:#1677ff;color:#fff;border:none;border-radius:4px;font-size:16px;cursor:pointer}.login-form button:hover{background:#4096ff}.login-error{color:#ff4d4f;margin-bottom:12px;font-size:14px}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-wrap{background:#fff;border-radius:8px;max-height:80vh;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid #f0f0f0}.modal-title{font-size:16px;font-weight:600}.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:#999;line-height:1}.modal-close:hover{color:#333}.modal-body{padding:24px;overflow-y:auto}.pagination{display:flex;align-items:center;gap:4px;margin-top:16px;justify-content:flex-end}.pagination-total{margin-right:8px;font-size:14px;color:#666}.pagination button{min-width:32px;height:32px;border:1px solid #d9d9d9;background:#fff;border-radius:4px;cursor:pointer;font-size:14px}.pagination button:hover:not(:disabled):not(.active){border-color:#1677ff;color:#1677ff}.pagination button.active{background:#1677ff;color:#fff;border-color:#1677ff}.pagination button:disabled{cursor:not-allowed;color:#d9d9d9}.pagination-ellipsis{padding:0 4px;color:#999}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.page-header h3,.page-header h2{margin:0}.btn{padding:6px 16px;border:1px solid #d9d9d9;border-radius:4px;background:#fff;cursor:pointer;font-size:14px;line-height:1.5}.btn:hover{border-color:#1677ff;color:#1677ff}.btn-primary{background:#1677ff;color:#fff;border-color:#1677ff}.btn-primary:hover{background:#4096ff;border-color:#4096ff;color:#fff}.btn-danger{color:#ff4d4f;border-color:#ff4d4f}.btn-danger:hover{color:#ff7875;border-color:#ff7875}.btn-link{background:none;border:none;color:#1677ff;cursor:pointer;padding:0;font-size:14px}.btn-link:hover{color:#4096ff}.btn-sm{padding:2px 8px;font-size:13px}.search-bar{display:flex;gap:8px;margin-bottom:16px;align-items:center;background:#fff;padding:16px;border-radius:4px}.search-bar input,.search-bar select{padding:6px 12px;border:1px solid #d9d9d9;border-radius:4px;font-size:14px;outline:none}.search-bar input:focus,.search-bar select:focus{border-color:#1677ff}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:4px;overflow:hidden}.data-table th,.data-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #f0f0f0;font-size:14px}.data-table th{background:#fafafa;font-weight:600;white-space:nowrap}.data-table td{color:#333}.data-table tr:hover td{background:#fafafa}.tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;line-height:1.5}.tag-success{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}.tag-error{background:#fff2f0;color:#ff4d4f;border:1px solid #ffccc7}.tag-default{background:#fafafa;color:#666;border:1px solid #d9d9d9}.tag-blue{background:#e6f4ff;color:#1677ff;border:1px solid #91caff}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:4px;font-size:14px;color:#333;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:6px 12px;border:1px solid #d9d9d9;border-radius:4px;font-size:14px;outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#1677ff}.form-group textarea{resize:vertical;min-height:60px}.form-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:16px;border-top:1px solid #f0f0f0}.action-col{display:flex;gap:8px;flex-wrap:wrap}.empty-row td{text-align:center;color:#999;padding:48px 16px}.perm-menu{background:#fff;border-radius:6px;border:1px solid #e8e8e8;overflow:hidden}.perm-node-row{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:14px;color:#333;border-bottom:1px solid #f5f5f5;transition:background .15s;-webkit-user-select:none;user-select:none}.perm-node-row:hover{background:#f7f9fc}.perm-node-expandable{cursor:pointer}.perm-node-arrow{flex-shrink:0;width:14px;font-size:12px;color:#999;text-align:center}.perm-status-dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:#d9d9d9}.perm-status-dot[data-on=true]{background:#52c41a}.perm-node-name{font-weight:500;white-space:nowrap}.perm-node-code{font-size:12px;color:#999;font-family:monospace;margin-left:auto}.perm-node-path{font-size:12px;color:#1677ff;background:#e6f4ff;padding:1px 6px;border-radius:3px;white-space:nowrap}.perm-node-children{background:#00000003}.perm-node-row .tag{flex-shrink:0}.checkbox-list{max-height:300px;overflow-y:auto}.checkbox-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:14px}.checkbox-item input[type=checkbox]{width:16px;height:16px}.checkbox-group-title{font-weight:600;font-size:14px;margin:8px 0 4px;padding-bottom:4px;border-bottom:1px solid #f0f0f0}.tab-bar{display:flex;gap:0;background:#fff;border-radius:4px 4px 0 0;border-bottom:2px solid #f0f0f0;padding:0 8px}.tab-btn{padding:10px 20px;border:none;background:none;cursor:pointer;font-size:14px;color:#666;position:relative;transition:color .2s}.tab-btn:hover{color:#1677ff}.tab-btn.active{color:#1677ff;font-weight:500}.tab-btn.active:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:#1677ff}.detail-content{max-height:600px;overflow-y:auto}.detail-section{margin-bottom:24px}.detail-section h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#333;border-bottom:1px solid #f0f0f0;padding-bottom:8px}.detail-row{display:flex;padding:8px 0;font-size:14px;border-bottom:1px solid #fafafa}.detail-label{min-width:120px;color:#666;font-weight:500}.detail-row>span:last-child{flex:1;color:#333}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-top:12px}.image-item{border:1px solid #f0f0f0;border-radius:4px;overflow:hidden}.image-label{padding:8px;background:#fafafa;font-size:13px;font-weight:500;color:#666;text-align:center}.image-item img{width:100%;height:200px;object-fit:cover;display:block}.tag-warning{background:#fffbe6;color:#faad14;border:1px solid #ffe58f}.shell-page{padding:24px}.shell-page h3{margin-bottom:16px}.shell-actions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.shell-action{padding:6px 12px;border:1px solid #d9d9d9;border-radius:4px;background:#fff;cursor:pointer;font-size:12px}.shell-action:hover{border-color:#999}.shell-table{width:100%;border-collapse:collapse;background:#fff;border-radius:4px;overflow:hidden}.shell-table th,.shell-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #f0f0f0;font-size:14px}.shell-table th{background:#fafafa;font-weight:600}.shell-placeholder{padding:48px;text-align:center;color:#999;background:#fff;border-radius:4px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#333;background:#f0f2f5}a{color:inherit;text-decoration:none}
