.login-page[data-v-f3bf9246]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);position:relative;overflow:hidden}.bg-decoration[data-v-f3bf9246]{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.bg-circle[data-v-f3bf9246]{position:absolute;border-radius:50%;filter:blur(100px);opacity:.15}.bg-circle--1[data-v-f3bf9246]{width:500px;height:500px;background:var(--color-primary);top:-150px;right:-150px;animation:float-f3bf9246 12s ease-in-out infinite}.bg-circle--2[data-v-f3bf9246]{width:400px;height:400px;background:var(--color-purple);bottom:-120px;left:-120px;animation:float-f3bf9246 14s ease-in-out infinite reverse}.bg-circle--3[data-v-f3bf9246]{width:300px;height:300px;background:var(--color-teal);top:50%;left:50%;transform:translate(-50%,-50%);animation:float-f3bf9246 10s ease-in-out infinite;opacity:.08}.bg-grid[data-v-f3bf9246]{display:none}@keyframes float-f3bf9246{0%,to{transform:translateY(0)}50%{transform:translateY(-16px)}}.login-card[data-v-f3bf9246]{width:400px;background:var(--color-surface);border-radius:var(--radius-xl);padding:44px 36px 32px;box-shadow:var(--shadow-xl);border:1px solid var(--color-border);position:relative;z-index:1}.login-header[data-v-f3bf9246]{text-align:center;margin-bottom:32px}.login-logo[data-v-f3bf9246]{width:52px;height:52px;margin:0 auto 16px;border-radius:var(--radius-md);background:var(--color-primary);display:flex;align-items:center;justify-content:center;color:#fff}.login-header h1[data-v-f3bf9246]{font-size:20px;font-weight:600;color:var(--color-text);letter-spacing:-.3px}.login-header p[data-v-f3bf9246]{font-size:13px;color:var(--color-text-3);margin-top:6px}.form-group[data-v-f3bf9246]{margin-bottom:18px}.form-group label[data-v-f3bf9246]{display:block;font-size:13px;font-weight:500;color:var(--color-text-2);margin-bottom:6px}.input-wrap[data-v-f3bf9246]{position:relative}.input-icon[data-v-f3bf9246]{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-4);pointer-events:none;transition:color var(--duration-fast) var(--ease-out)}.input-wrap:focus-within .input-icon[data-v-f3bf9246]{color:var(--color-primary)}.form-group input[data-v-f3bf9246]{width:100%;padding:10px 12px 10px 38px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-sans);color:var(--color-text);outline:none;transition:all var(--duration-fast) var(--ease-out);background:var(--color-surface)}.form-group input[data-v-f3bf9246]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.form-group input[data-v-f3bf9246]::placeholder{color:var(--color-text-4)}.error-msg[data-v-f3bf9246]{display:flex;align-items:center;gap:6px;color:var(--color-red);font-size:13px;margin-bottom:16px;padding:10px 12px;background:var(--color-red-bg);border-radius:var(--radius-sm)}.login-btn[data-v-f3bf9246]{width:100%;padding:11px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out);display:flex;align-items:center;justify-content:center;gap:8px}.login-btn[data-v-f3bf9246]:hover:not(:disabled){background:var(--color-primary-hover)}.login-btn[data-v-f3bf9246]:active:not(:disabled){transform:scale(.98)}.login-btn[data-v-f3bf9246]:disabled{opacity:.6;cursor:not-allowed}.spinner[data-v-f3bf9246]{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-f3bf9246 .6s linear infinite}@keyframes spin-f3bf9246{to{transform:rotate(360deg)}}.login-footer[data-v-f3bf9246]{text-align:center;margin-top:24px;font-size:12px;color:var(--color-text-4)}.loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:80px 0;color:var(--color-text-3);font-size:14px}.loading-spinner{width:18px;height:18px;border:2px solid var(--color-border-2);border-top-color:var(--color-primary);border-radius:50%;animation:cms-spin .7s linear infinite}.loading-spinner-sm{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:cms-spin .7s linear infinite}.loading-inline{display:flex;align-items:center;justify-content:center;gap:8px}.loading-inline .loading-spinner{width:16px;height:16px}@keyframes cms-spin{to{transform:rotate(360deg)}}.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:20px}.search-wrap{position:relative;flex:1;max-width:360px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-4);pointer-events:none}.search-input{width:100%;padding:8px 12px 8px 36px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-sans);outline:none;background:var(--color-surface);transition:all var(--duration-fast) var(--ease-out);color:var(--color-text)}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.total-badge{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-3);background:var(--color-surface);padding:6px 14px;border-radius:20px;border:1px solid var(--color-border)}.filter-bar{display:flex;align-items:flex-end;gap:12px;margin-bottom:20px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-label{font-size:11px;font-weight:500;color:var(--color-text-3);text-transform:uppercase;letter-spacing:.3px}.filter-wrap{position:relative}.filter-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-4);pointer-events:none}.filter-select{padding:8px 32px 8px 12px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-sans);outline:none;background:var(--color-surface);color:var(--color-text-2);cursor:pointer;transition:border-color var(--duration-fast) var(--ease-out);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238e8e93' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;min-width:140px}.filter-wrap .filter-select{padding-left:34px}.filter-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.filter-input{padding:8px 12px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-sans);outline:none;background:var(--color-surface);transition:all var(--duration-fast) var(--ease-out);color:var(--color-text);min-width:140px}.filter-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.filter-btn{padding:8px 18px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:background var(--duration-fast) var(--ease-out)}.filter-btn:hover{background:var(--color-primary-hover)}.filter-btn--reset{background:var(--color-surface);color:var(--color-text-2);border:1px solid var(--color-border-2)}.filter-btn--reset:hover{background:var(--color-surface-3);border-color:var(--color-border-2)}.table-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-xs)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{background:var(--color-surface-2);padding:10px 16px;text-align:left;font-weight:500;color:var(--color-text-3);font-size:12px;letter-spacing:.2px;border-bottom:1px solid var(--color-border)}.data-table td{padding:12px 16px;border-bottom:1px solid var(--color-separator);color:var(--color-text-2)}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background var(--duration-fast) var(--ease-out)}.data-table tbody tr:hover{background:var(--color-surface-2)}.empty{text-align:center;color:var(--color-text-4);padding:48px 0!important}.user-cell{display:flex;align-items:center;gap:10px}.user-avatar{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--color-primary-bg-2);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.user-avatar-sm{width:26px;height:26px;border-radius:var(--radius-xs);background:var(--color-primary-bg-2);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;flex-shrink:0}.user-name{font-weight:500;color:var(--color-text);font-size:13px}.user-email{font-size:12px;color:var(--color-text-3);margin-top:1px}.date-cell{font-size:12px;color:var(--color-text-3);white-space:nowrap}.id-cell{font-family:var(--font-mono);font-size:12px;color:var(--color-text-3)}.mono-cell{font-family:var(--font-mono);font-size:12px;color:var(--color-primary)}.num-cell{font-weight:600;color:var(--color-text);font-variant-numeric:tabular-nums}.action-cell{display:flex;gap:6px;align-items:center}.title-cell{font-weight:500;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text)}.prompt-cell{max-width:320px;color:var(--color-text-3);word-break:break-all}.message-cell{max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-3)}.error-cell{max-width:320px;color:var(--color-red);font-size:12px;word-break:break-all}.resource-id-cell{font-family:var(--font-mono);font-size:12px;color:var(--color-text-3)}.no-data{color:var(--color-text-4)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500}.status-dot{width:6px;height:6px;border-radius:50%}.status-badge.active,.status--ok{background:var(--color-green-bg);color:#059669}.status-badge.active .status-dot,.status--ok .status-dot{background:var(--color-green)}.status-badge.inactive,.status--err{background:var(--color-red-bg);color:#dc2626}.status-badge.inactive .status-dot,.status--err .status-dot{background:var(--color-red)}.status--run{background:var(--color-primary-bg);color:var(--color-primary)}.status--run .status-dot{background:var(--color-primary);animation:cms-pulse 1.5s ease-in-out infinite}.status--pend{background:var(--color-orange-bg);color:#d97706}.status--pend .status-dot{background:var(--color-orange)}@keyframes cms-pulse{0%,to{opacity:1}50%{opacity:.3}}.role-tag{display:inline-block;padding:2px 8px;background:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-xs);font-size:11px;font-weight:500;margin-right:4px}.no-role{color:var(--color-text-4);font-size:12px}.type-tag{padding:2px 8px;background:var(--color-surface-3);color:var(--color-text-2);border-radius:var(--radius-xs);font-size:11px;font-weight:500;font-family:var(--font-mono)}.tool-tag{padding:2px 8px;background:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-xs);font-size:11px;font-weight:500}.status-tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-xs);font-size:11px;font-weight:500}.status-tag.DRAFT{background:var(--color-orange-bg);color:#d97706}.status-tag.ACTIVE{background:var(--color-green-bg);color:#059669}.status-tag.ARCHIVED{background:var(--color-surface-3);color:var(--color-text-3)}.action-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-xs);font-size:11px;font-weight:500}.action-badge--create{background:var(--color-green-bg);color:#059669}.action-badge--update{background:var(--color-primary-bg);color:var(--color-primary)}.action-badge--delete{background:var(--color-red-bg);color:#dc2626}.action-badge--default{background:var(--color-surface-3);color:var(--color-text-3)}.type-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-xs);font-size:11px;font-weight:500}.type-system{background:var(--color-primary-bg);color:var(--color-primary)}.type-success{background:var(--color-green-bg);color:#059669}.type-fail{background:var(--color-red-bg);color:var(--color-red)}.credit-cell{font-size:13px;font-weight:600;color:var(--color-text);font-variant-numeric:tabular-nums}.credit-cell--empty{color:var(--color-red)}.credit-total{font-weight:400;color:var(--color-text-4);font-size:12px}.read-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.read-dot.read{background:var(--color-text-4)}.read-dot.unread{background:var(--color-green)}.progress-cell{display:flex;align-items:center;gap:8px}.progress-bar{width:80px;height:4px;background:var(--color-surface-3);border-radius:2px;overflow:hidden;flex-shrink:0}.progress-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s var(--ease-out)}.progress-fill.progress--err{background:var(--color-orange)}.progress-text{font-size:12px;color:var(--color-text-3);font-family:var(--font-mono);font-weight:500}.progress-failed{font-size:11px;color:var(--color-red);font-weight:500}.action-btn{padding:5px 12px;border:1px solid var(--color-border-2);border-radius:var(--radius-xs);background:var(--color-surface);font-size:12px;font-weight:500;color:var(--color-text-2);cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.action-btn:hover{background:var(--color-surface-3)}.action-btn--danger{border-color:#ff3b3033;color:var(--color-red)}.action-btn--danger:hover{background:var(--color-red-bg)}.delete-btn{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border:1px solid rgba(255,59,48,.15);border-radius:var(--radius-xs);background:none;color:var(--color-red);font-size:12px;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.delete-btn:hover{background:var(--color-red-bg)}.cancel-btn{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border:1px solid rgba(255,59,48,.15);border-radius:var(--radius-xs);background:none;color:var(--color-red);font-size:12px;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.cancel-btn:hover{background:var(--color-red-bg)}.refresh-btn{margin-left:auto;display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);background:var(--color-surface);font-size:13px;font-weight:500;color:var(--color-text-2);cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.refresh-btn:hover{background:var(--color-surface-3)}.create-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:background var(--duration-fast) var(--ease-out)}.create-btn:hover{background:var(--color-primary-hover)}.save-btn{padding:8px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:background var(--duration-fast) var(--ease-out)}.save-btn:hover{background:var(--color-primary-hover)}.save-btn:disabled{opacity:.6;cursor:not-allowed}.send-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:background var(--duration-fast) var(--ease-out)}.send-btn:hover:not(:disabled){background:var(--color-primary-hover)}.send-btn:disabled{opacity:.6;cursor:not-allowed}.cancel-form-btn{padding:8px 16px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);background:var(--color-surface);font-size:13px;font-weight:500;color:var(--color-text-3);cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.cancel-form-btn:hover{background:var(--color-surface-3)}.expand-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--color-border-2);border-radius:var(--radius-xs);background:var(--color-surface);cursor:pointer;color:var(--color-text-3);transition:all var(--duration-fast) var(--ease-out)}.expand-btn:hover{background:var(--color-surface-3)}.expand-btn svg{transition:transform var(--duration-fast) var(--ease-out)}.expand-btn--open svg{transform:rotate(180deg)}.perm-edit-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border:1px solid var(--color-border-2);border-radius:var(--radius-xs);background:var(--color-surface);font-size:12px;font-weight:500;color:var(--color-primary);cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.perm-edit-btn:hover{background:var(--color-primary-bg)}.default-toggle-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border:1px solid var(--color-border-2);border-radius:var(--radius-xs);background:var(--color-surface);font-size:12px;font-weight:500;color:var(--color-text-4);cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.default-toggle-btn:hover{background:var(--color-orange-bg);color:#d97706}.default-toggle-btn.active{background:var(--color-orange-bg);border-color:#ff950033;color:#d97706}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px}.pagination button{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);background:var(--color-surface);font-size:13px;font-weight:500;color:var(--color-text-2);cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.pagination button:hover:not(:disabled){background:var(--color-surface-3)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.page-info{font-size:13px;color:var(--color-text-3);font-weight:500;min-width:60px;text-align:center}.tabs{display:flex;gap:2px;background:var(--color-surface-3);border-radius:var(--radius-sm);padding:3px;margin-bottom:20px;width:fit-content}.tab{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border:none;border-radius:var(--radius-xs);font-size:13px;font-weight:500;color:var(--color-text-3);background:none;cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.tab:hover{color:var(--color-text-2)}.tab.active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-xs)}.tab.active .tab-count{background:var(--color-primary-bg);color:var(--color-primary)}.tab-count{padding:1px 7px;border-radius:var(--radius-xs);font-size:11px;font-weight:500;background:var(--color-surface-3);color:var(--color-text-3)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-xs)}.form-title{font-size:15px;font-weight:600;color:var(--color-text);margin-bottom:16px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-group{margin-bottom:16px}.form-group--full{grid-column:1 / -1}.form-group label,.form-label{display:block;font-size:12px;font-weight:500;color:var(--color-text-3);margin-bottom:6px}.form-input{width:100%;padding:8px 12px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-sans);outline:none;background:var(--color-surface);color:var(--color-text);transition:all var(--duration-fast) var(--ease-out);box-sizing:border-box}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.form-textarea{width:100%;padding:8px 12px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-sans);outline:none;background:var(--color-surface);color:var(--color-text);transition:all var(--duration-fast) var(--ease-out);resize:vertical;box-sizing:border-box}.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.create-form{margin-bottom:20px}.radio-group{display:flex;gap:6px}.radio-option{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--color-text-3);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.radio-option input{display:none}.radio-option.active{border-color:var(--color-primary);background:var(--color-primary-bg);color:var(--color-primary)}.send-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:24px;max-width:560px;box-shadow:var(--shadow-xs)}.send-result{font-size:13px;font-weight:500}.send-result.success{color:#059669}.send-result.error{color:var(--color-red)}.user-search-wrap{position:relative}.user-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-top:4px;box-shadow:var(--shadow-lg);z-index:50;max-height:240px;overflow-y:auto}.user-dropdown-item{padding:8px 12px;cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.user-dropdown-item:hover{background:var(--color-surface-2)}.user-dropdown-item:first-child{border-radius:var(--radius-sm) var(--radius-sm) 0 0}.user-dropdown-item:last-child{border-radius:0 0 var(--radius-sm) var(--radius-sm)}.dropdown-name{font-size:13px;font-weight:500;color:var(--color-text)}.dropdown-email{font-size:11px;color:var(--color-text-3);margin-top:1px}.video-link{display:inline-flex;align-items:center;gap:4px;color:var(--color-primary);font-size:12px;font-weight:500;text-decoration:none;transition:color var(--duration-fast) var(--ease-out)}.video-link:hover{color:var(--color-primary-hover);text-decoration:underline}.detail-row{cursor:default!important}.detail-row:hover{background:var(--color-surface-2)!important}.detail-content{padding:8px 12px}.detail-meta{display:flex;gap:24px;margin-bottom:8px;font-size:12px;color:var(--color-text-3)}.detail-meta strong{color:var(--color-text-2)}.detail-json{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:12px 16px;font-size:12px;font-family:var(--font-mono);color:var(--color-text-2);overflow-x:auto;margin:0;white-space:pre-wrap;word-break:break-all}.role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:16px}.role-card{transition:box-shadow var(--duration-fast) var(--ease-out);position:relative}.role-card:hover{box-shadow:var(--shadow-md)}.role-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.role-icon-wrap{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--color-primary-bg);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.role-info{flex:1;min-width:0}.role-name{font-size:14px;font-weight:600;color:var(--color-text)}.role-slug{font-size:12px;color:var(--color-text-4);font-family:var(--font-mono);margin-top:1px}.role-meta{display:flex;gap:16px;margin-bottom:8px}.meta-item{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--color-text-3);font-weight:500}.role-desc{font-size:13px;color:var(--color-text-3);line-height:1.5}.role-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-separator)}.perm-panel{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-separator)}.perm-grid{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.perm-checkbox{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:var(--radius-xs);cursor:pointer;transition:background var(--duration-fast) var(--ease-out);border:1px solid transparent}.perm-checkbox:hover{background:var(--color-surface-2)}.perm-checkbox.checked{background:var(--color-primary-bg);border-color:#007aff1a}.perm-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.perm-name{font-size:13px;font-weight:500;color:var(--color-text)}.perm-code{font-size:11px;color:var(--color-text-4);font-family:var(--font-mono);margin-left:auto}.perm-actions{display:flex;justify-content:flex-end;gap:10px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width: 900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:20px;transition:box-shadow var(--duration-fast) var(--ease-out)}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-icon-wrap{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:14px}.stat-body{margin-bottom:6px}.stat-label{font-size:12px;color:var(--color-text-3);font-weight:500;margin-bottom:4px}.stat-value{font-size:28px;font-weight:700;color:var(--color-text);line-height:1;letter-spacing:-.5px;font-variant-numeric:tabular-nums}.stat-today{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--color-green);font-weight:500;margin-top:4px}.stat-today--zero{color:var(--color-text-4)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.modal-box{background:var(--color-surface);border-radius:var(--radius-xl);padding:28px;width:560px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.modal-title{font-size:16px;font-weight:600;color:var(--color-text);margin-bottom:20px;letter-spacing:-.2px}.modal-body{margin-bottom:20px}.modal-body label{display:block;font-size:12px;font-weight:500;color:var(--color-text-3);margin-bottom:6px}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.modal-textarea{width:100%;padding:10px 12px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-sans);resize:vertical;outline:none;color:var(--color-text);background:var(--color-surface);box-sizing:border-box;transition:all var(--duration-fast) var(--ease-out)}.modal-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.toggle-label,.form-group .toggle-label,.modal-body .toggle-label{display:inline-flex;align-items:center;gap:10px;cursor:pointer;margin-bottom:0}.toggle-checkbox{display:none}.toggle-switch{position:relative;width:40px;height:22px;background:var(--color-border-2);border-radius:11px;transition:background var(--duration-fast) var(--ease-out)}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform var(--duration-fast) var(--ease-out);box-shadow:0 1px 3px #00000026}.toggle-checkbox:checked+.toggle-switch{background:var(--color-primary)}.toggle-checkbox:checked+.toggle-switch:after{transform:translate(18px)}.toggle-checkbox:disabled+.toggle-switch{opacity:.5;cursor:not-allowed}.toggle-text{font-size:13px;color:var(--color-text-3);font-weight:500}.action-group{display:flex;gap:6px}.action-btn--edit{color:var(--color-primary)}.action-btn--edit:hover{background:var(--color-primary-bg);border-color:#007aff33}.action-btn--on{color:var(--color-green)}.action-btn--on:hover{background:#34c75914;border-color:#34c75933}.action-btn--off{color:var(--color-orange)}.action-btn--off:hover{background:#ff950014;border-color:#ff950033}.action-btn--del{color:var(--color-red)}.action-btn--del:hover{background:var(--color-red-bg);border-color:#ff3b3033}.page-header{margin-bottom:24px}.page-title{font-size:20px;font-weight:600;color:var(--color-text);margin:0 0 4px;letter-spacing:-.3px}.page-desc{font-size:14px;color:var(--color-text-3);margin:0}.toolbar-left{display:flex;gap:10px;align-items:center}.toolbar-title{font-size:17px;font-weight:600;color:var(--color-text);letter-spacing:-.2px}.empty-state{text-align:center;color:var(--color-text-4);font-size:14px;padding:80px 0}.filter-btn{padding:6px 16px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);background:var(--color-surface);font-size:12px;font-weight:500;color:var(--color-text-3);cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.filter-btn:hover{border-color:#007aff4d;color:var(--color-primary)}.filter-btn.active{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary);font-weight:600}.save-btn--danger{background:var(--color-red)}.save-btn--danger:hover{background:#e0342d;box-shadow:0 4px 12px #ff3b3040}.category-tag{padding:3px 10px;background:var(--color-surface-3);color:var(--color-text-3);border-radius:var(--radius-xs);font-size:11px;font-weight:600}.tag-badge{display:inline-block;padding:3px 10px;border-radius:var(--radius-xs);font-size:11px;font-weight:600}.tag--image{background:#af52de1a;color:var(--color-purple)}.tag--video{background:var(--color-primary-bg);color:var(--color-primary)}.status--active{background:#34c7591a;color:var(--color-green)}.status--inactive{background:var(--color-surface-3);color:var(--color-text-4)}.content-cell{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-3);font-size:12.5px}.fade-enter-active{transition:opacity .15s ease}.fade-leave-active{transition:opacity .1s ease}.fade-enter-from,.fade-leave-to{opacity:0}.page-hint{padding:12px 18px;background:#ffcc0014;border:1px solid rgba(255,204,0,.2);border-radius:var(--radius-md);font-size:13px;color:var(--color-orange);margin-bottom:20px}.success-msg{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#34c7591a;color:var(--color-green);border-radius:var(--radius-sm);font-size:12px;font-weight:600}.granularity-btns{display:flex;gap:2px;background:var(--color-surface-3);border-radius:var(--radius-sm);padding:3px}.gran-btn{padding:6px 16px;border:none;border-radius:var(--radius-xs);font-size:13px;font-weight:500;color:var(--color-text-3);background:none;cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.gran-btn.active{background:var(--color-surface);color:var(--color-primary);font-weight:600;box-shadow:var(--shadow-xs)}.bar-col{width:200px}.bar-cell{padding-right:24px}.bar-track{width:100%;height:8px;background:var(--color-surface-3);border-radius:4px;overflow:hidden}.bar-fill{height:100%;background:var(--color-primary);border-radius:4px;transition:width .3s ease;min-width:2px}.type-badge{display:inline-block;padding:3px 10px;border-radius:var(--radius-xs);font-size:11px;font-weight:600}.type--banner{background:var(--color-primary-bg);color:var(--color-primary)}.type--modal{background:#ffcc001a;color:var(--color-orange)}.type--toast{background:#007aff14;color:var(--color-primary)}.color-swatch-group{display:flex;gap:6px;align-items:center}.color-swatch{display:inline-block;width:22px;height:22px;border-radius:var(--radius-xs);box-shadow:var(--shadow-xs)}.color-input-wrap{display:flex;gap:8px;align-items:center}.color-picker{width:40px;height:40px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);padding:2px;cursor:pointer;flex-shrink:0;background:none}.color-picker::-webkit-color-swatch-wrapper{padding:0}.color-picker::-webkit-color-swatch{border:none;border-radius:calc(var(--radius-sm) - 2px)}.color-text{flex:1;font-family:var(--font-mono);font-size:12px}.preview-section{margin-bottom:20px}.preview-label{display:block;font-size:12px;font-weight:500;color:var(--color-text-3);margin-bottom:8px}.preview-banner{padding:16px 20px;border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}.preview-title{font-size:14px;font-weight:700;margin-bottom:4px}.preview-content{font-size:12px;opacity:.9;line-height:1.5}.model-tag{display:inline-flex;align-items:center;padding:3px 10px;background:#34c75914;color:var(--color-green);border-radius:var(--radius-xs);font-size:11px;font-weight:600;font-family:var(--font-mono)}.type-tag{display:inline-flex;align-items:center;padding:3px 10px;background:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-xs);font-size:11px;font-weight:600}.btn-edit,.btn-cancel{padding:4px 12px;border:1px solid var(--color-border-2);border-radius:var(--radius-xs);font-size:12px;color:var(--color-primary);background:var(--color-surface);cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.btn-edit:hover{background:var(--color-primary-bg)}.btn-cancel{color:var(--color-text-3)}.btn-cancel:hover{background:var(--color-surface-2)}.btn-save{padding:4px 12px;border:none;border-radius:var(--radius-xs);font-size:12px;color:#fff;background:var(--color-primary);cursor:pointer;font-family:var(--font-sans)}.btn-save:disabled{opacity:.5;cursor:not-allowed}.btn-delete{padding:4px 12px;border:1px solid var(--color-border-2);border-radius:var(--radius-xs);font-size:12px;color:var(--color-red);background:var(--color-surface);cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out)}.btn-delete:hover{background:#ff3b3014}.edit-input{width:100%;padding:6px 10px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-sans);color:var(--color-text-2);outline:none;transition:all var(--duration-fast) var(--ease-out)}.edit-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.type-btns{display:flex;gap:8px}.type-btn{padding:6px 16px;border:1px solid var(--color-border-2);border-radius:var(--radius-sm);background:var(--color-surface);font-size:13px;color:var(--color-text-3);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);font-family:var(--font-sans)}.type-btn.active{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary);font-weight:600}.form-row{display:flex;gap:12px}.form-textarea{font-family:var(--font-mono);font-size:12px;resize:vertical}.required{color:var(--color-red)}
