:root{--bg:#0a0a0f;--card:#111118;--input:#1a1a25;--border:#252540;--accent:#8b5cf6;--accent2:#a78bfa;--accent-dark:#6d28d9;--text:#e5e7eb;--text2:#9ca3af;--text3:#6b7280;--green:#10b981;--red:#ef4444;--gold:#f59e0b;--r:12px;--rs:8px;--w:240px}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Segoe UI','Microsoft YaHei',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow:hidden}
a{text-decoration:none;color:inherit}

/* ===== 登录页 ===== */
.web-login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:radial-gradient(ellipse at center,#1a0a2e 0%,#0a0a0f 70%)}
.web-login-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:36px 32px;width:420px;box-shadow:0 20px 60px rgba(139,92,246,.15);text-align:center}
.web-login-logo{width:56px;height:56px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-size:24px;color:#fff;margin-bottom:12px;box-shadow:0 6px 20px rgba(139,92,246,.4)}
.web-login-card h1{font-size:22px;font-weight:700;color:#fff;margin-bottom:4px}
.web-login-sub{color:var(--text2);font-size:13px;margin-bottom:24px}
.web-input-group{position:relative;display:flex;align-items:center;margin-bottom:14px}
.web-input-group i{position:absolute;left:12px;color:var(--text3);font-size:15px}
.web-input-group input{width:100%;padding:11px 14px 11px 38px;background:var(--input);border:1px solid var(--border);border-radius:var(--rs);color:var(--text);font-size:14px;transition:.15s}
.web-input-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(139,92,246,.12)}
.web-login-btn{width:100%;padding:12px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border:none;border-radius:var(--rs);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:.15s;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:10px}
.web-login-btn:hover{box-shadow:0 4px 14px rgba(139,92,246,.5);transform:translateY(-1px)}
.web-switch{color:var(--accent2);font-size:13px;display:block;margin-bottom:14px;cursor:pointer}
.web-switch:hover{text-decoration:underline}
.web-login-err{color:var(--red);font-size:13px;min-height:18px}
.web-skip-btn{width:100%;padding:10px;background:transparent;border:1px solid var(--border);border-radius:var(--rs);color:var(--text2);font-size:14px;cursor:pointer;margin-top:12px;display:flex;align-items:center;justify-content:center;gap:8px;transition:.15s}
.web-skip-btn:hover{border-color:var(--accent);color:#fff}

/* ===== 弹窗 ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100}
.modal-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px 32px;width:400px;max-width:90vw;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.modal-header h3{font-size:18px;color:#fff;display:flex;align-items:center;gap:8px;margin-bottom:12px}
.modal-desc{color:var(--text2);font-size:13px;margin-bottom:20px;line-height:1.6}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}

/* ===== 按钮 ===== */
.btn-primary{padding:10px 20px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border:none;border-radius:var(--rs);color:#fff;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:.15s}
.btn-primary:hover{box-shadow:0 4px 12px rgba(139,92,246,.5);transform:translateY(-1px)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.btn-secondary{padding:10px 20px;background:transparent;border:1px solid var(--border);border-radius:var(--rs);color:var(--text2);font-size:14px;cursor:pointer;transition:.15s}
.btn-secondary:hover{border-color:var(--accent);color:#fff}
.btn-danger{padding:10px 20px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:var(--rs);color:var(--red);font-size:14px;cursor:pointer;transition:.15s}
.btn-danger:hover{background:rgba(239,68,68,.2)}
.btn-sm{padding:6px 12px;font-size:12px;border-radius:6px;border:none;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:4px}
.btn-gold{background:linear-gradient(135deg,#f59e0b,#d97706)!important}
.btn-gold:hover{box-shadow:0 4px 12px rgba(245,158,11,.5)!important}
.btn-compile{width:100%;justify-content:center;padding:12px;font-size:15px}
.btn-download{width:100%;justify-content:center;padding:14px;font-size:15px;text-align:center}
.text-gold{color:var(--gold)}
.text-green{color:var(--green)}
.text-red{color:var(--red)}
.text-accent{color:var(--accent)}
.text-muted{color:var(--text3)}

/* ===== 主布局 ===== */
#mainPage{display:flex;min-height:100vh}
.web-sidebar{width:var(--w);min-width:var(--w);background:linear-gradient(180deg,#1a1028 0%,#2d1b4e 100%);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:10}
.web-logo{display:flex;align-items:center;gap:10px;padding:18px 16px;border-bottom:1px solid rgba(139,92,246,.2);font-size:16px;font-weight:700;color:#fff}
.web-logo i{font-size:20px;color:var(--accent);width:38px;height:38px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(139,92,246,.4)}
.web-user-info{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid rgba(139,92,246,.15);background:rgba(139,92,246,.06)}
.web-user-info img{width:40px;height:40px;border-radius:50%;border:2px solid var(--accent)}
.web-user-name{font-size:14px;font-weight:600;color:#fff;display:block}
.web-user-role{font-size:11px;color:var(--text2)}

/* 配额 */
.web-quota-box{margin:12px 16px;padding:12px 14px;background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.2);border-radius:var(--rs);display:flex;align-items:center;justify-content:space-between}
.web-quota-info{display:flex;flex-direction:column}
.web-quota-label{font-size:11px;color:var(--text3)}
.web-quota-value{font-size:22px;font-weight:700;color:var(--gold)}
.web-buy-quota-btn{padding:6px 14px;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:20px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:.15s;white-space:nowrap;display:flex;align-items:center;gap:4px}
.web-buy-quota-btn:hover{box-shadow:0 3px 10px rgba(245,158,11,.5);transform:translateY(-1px)}

/* 导航 */
.web-nav{flex:1;padding:10px 8px;display:flex;flex-direction:column;gap:2px}
.web-nav-item{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--rs);color:var(--text2);font-size:14px;transition:.15s}
.web-nav-item i{width:18px;text-align:center;font-size:15px}
.web-nav-item:hover{background:rgba(139,92,246,.15);color:#fff}
.web-nav-item.active{background:var(--accent);color:#fff;box-shadow:0 3px 10px rgba(139,92,246,.35)}
.web-sidebar-foot{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-top:1px solid rgba(139,92,246,.2);font-size:12px;color:var(--text3)}
.web-sidebar-foot button{width:30px;height:30px;border:1px solid rgba(239,68,68,.3);background:transparent;color:var(--red);border-radius:var(--rs);cursor:pointer;font-size:13px;transition:.15s}
.web-sidebar-foot button:hover{background:rgba(239,68,68,.15)}

/* 主内容 */
.web-main{margin-left:var(--w);flex:1;padding:24px 28px;overflow-y:auto;height:100vh}
.web-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:22px}
.web-header h2{font-size:20px;display:flex;align-items:center;gap:10px}
.web-header span{color:var(--text3);font-size:13px}
.web-content{max-width:960px}
.web-page{display:none}
.web-page.active{display:block}

/* ===== 仪表盘 ===== */
.web-welcome{margin-bottom:20px}
.web-welcome h1{font-size:26px;margin-bottom:6px}
.grad{background:linear-gradient(135deg,#a78bfa,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.web-welcome p{color:var(--text2);font-size:14px}
.web-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.web-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:14px 16px;display:flex;align-items:center;gap:12px;transition:.15s}
.web-card:hover{border-color:rgba(139,92,246,.4);box-shadow:0 4px 12px rgba(139,92,246,.08)}
.web-card i{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.web-card.c1 i{background:rgba(59,130,246,.15);color:#60a5fa}
.web-card.c2 i{background:rgba(16,185,129,.15);color:#34d399}
.web-card.c3 i{background:rgba(245,158,11,.15);color:#fbbf24}
.web-card.c4 i{background:rgba(139,92,246,.15);color:#a78bfa}
.web-card span{font-size:11px;color:var(--text2);display:block}
.web-card strong{font-size:17px;font-weight:700;display:block;margin-top:2px}
.web-launch-btn{width:100%;padding:14px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border:none;border-radius:var(--r);color:#fff;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:.15s;margin-bottom:14px}
.web-launch-btn:hover{box-shadow:0 6px 18px rgba(139,92,246,.5);transform:translateY(-2px)}
.web-socials{display:flex;gap:12px;margin-bottom:20px}
.web-socials a{flex:1;padding:12px;border-radius:var(--rs);color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:.15s}
.web-kook-btn{background:linear-gradient(135deg,#5865f2,#4752c4)}
.web-qq-btn{background:linear-gradient(135deg,#12b7f5,#0d8fc2)}
.web-socials a:hover{transform:translateY(-1px);opacity:.9}
.web-announce{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;margin-bottom:16px}
.web-announce h3{font-size:15px;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.web-announce h3 i{color:var(--accent)}
.anc-item{display:flex;gap:10px;padding:8px 10px;background:rgba(139,92,246,.05);border-radius:var(--rs);margin-bottom:6px;font-size:13px}
.anc-date{color:var(--accent2);font-weight:600;white-space:nowrap;font-size:12px}
.anc-text{color:var(--text2);line-height:1.5}
.web-footer{display:flex;gap:20px;padding:10px 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--rs);font-size:12px;color:var(--text2)}
.empty{text-align:center;color:var(--text3);padding:40px;line-height:2}
.empty i{font-size:32px;margin-bottom:8px;display:block;color:var(--text3)}

/* ===== 登录器配置页 ===== */
.login-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--text3)}
.login-prompt i{font-size:48px;margin-bottom:16px;opacity:.5}
.login-prompt h3{font-size:18px;color:var(--text2);margin-bottom:8px}
.login-prompt p{font-size:14px}

.launchers-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.web-add-launcher-btn{padding:10px 20px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border:none;border-radius:var(--rs);color:#fff;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:.15s}
.web-add-launcher-btn:hover{box-shadow:0 4px 12px rgba(139,92,246,.5);transform:translateY(-1px)}
.launchers-quota-hint{font-size:13px;color:var(--text2);display:flex;align-items:center;gap:6px}
.launchers-quota-hint strong{color:var(--gold);font-size:18px}

/* 登录器卡片 */
.launchers-list{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.launcher-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px;display:flex;align-items:center;justify-content:space-between;transition:.15s;cursor:pointer}
.launcher-card:hover{border-color:rgba(139,92,246,.4);background:rgba(139,92,246,.03)}
.launcher-card.active{border-color:var(--accent);box-shadow:0 0 0 2px rgba(139,92,246,.2)}
.launcher-card-main{display:flex;align-items:center;gap:14px;flex:1;min-width:0}
.launcher-card-icon{width:44px;height:44px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;flex-shrink:0;box-shadow:0 4px 12px rgba(139,92,246,.3)}
.launcher-card-info{min-width:0}
.launcher-card-name{font-size:15px;font-weight:600;color:#fff;margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.launcher-card-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--text3)}
.launcher-card-meta i{font-size:11px}
.launcher-card-actions{display:flex;gap:6px;flex-shrink:0;margin-left:12px}

/* 编译状态徽标 */
.build-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}
.build-badge.pending{background:rgba(245,158,11,.1);color:var(--gold)}
.build-badge.building{background:rgba(139,92,246,.1);color:var(--accent)}
.build-badge.completed{background:rgba(16,185,129,.1);color:var(--green)}
.build-badge.failed{background:rgba(239,68,68,.1);color:var(--red)}
.build-badge.none{background:rgba(107,114,128,.1);color:var(--text3)}

/* ===== 详情面板 ===== */
.launcher-detail{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;animation:slideUp .3s}
@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.detail-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}
.detail-header h3{font-size:17px;display:flex;align-items:center;gap:8px}
.detail-date{font-size:12px;color:var(--text3);margin-top:2px;display:block}
.detail-close{width:32px;height:32px;border:1px solid var(--border);background:transparent;color:var(--text3);border-radius:var(--rs);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:.15s}
.detail-close:hover{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.3);color:var(--red)}
.detail-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 22px}
.detail-tab{padding:12px 18px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:.15s}
.detail-tab:hover{color:#fff}
.detail-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.detail-panel{display:none;padding:22px}
.detail-panel.active{display:block}

/* 服务器配置表 */
.config-table{display:flex;flex-direction:column;gap:1px;background:var(--border);border-radius:var(--rs);overflow:hidden}
.cfg-row{display:flex;background:var(--input);transition:.1s}
.cfg-row:hover{background:var(--border)}
.cfg-label{padding:12px 16px;font-size:13px;color:var(--text2);width:160px;flex-shrink:0;display:flex;align-items:center;gap:8px;border-right:1px solid var(--border)}
.cfg-label i{color:var(--accent);width:16px;text-align:center;font-size:13px}
.cfg-value{padding:12px 16px;font-size:13px;color:var(--text);word-break:break-all}
.cfg-value a{color:var(--accent2);text-decoration:underline}
.cfg-value a:hover{color:var(--accent)}

/* ===== 编译区 ===== */
.compile-section{max-width:700px}
.compile-form{margin-bottom:20px}
.compile-form-row{display:flex;gap:14px}
.compile-hint{font-size:12px;color:var(--text3);margin-top:10px;display:flex;align-items:center;gap:6px}

/* 编译状态 */
.compile-status-box{background:var(--input);border:1px solid var(--border);border-radius:var(--rs);padding:16px;margin-bottom:14px}
.compile-status-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-size:14px;font-weight:600}
.compile-status-header i{font-size:18px}
.compile-progress{display:flex;align-items:center;gap:12px}
.progress-bar{flex:1;height:8px;background:var(--border);border-radius:4px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#a78bfa);border-radius:4px;transition:width .3s;width:0}
.progress-text{font-size:13px;color:var(--accent2);font-weight:600;min-width:36px;text-align:right}

/* 编译日志 */
.compile-log-box{margin-bottom:14px;border:1px solid var(--border);border-radius:var(--rs);overflow:hidden}
.log-header{padding:10px 16px;background:var(--input);color:var(--text2);font-size:13px;cursor:pointer;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}
.log-header:hover{color:#fff}
.log-content{background:#0d0d12;padding:14px 16px;font-size:12px;color:var(--text2);font-family:'Cascadia Code','Consolas',monospace;max-height:300px;overflow-y:auto;line-height:1.7;white-space:pre-wrap;word-break:break-all}

/* 下载 */
.compile-download-box{display:flex;align-items:center;gap:16px;padding:18px;background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.2);border-radius:var(--rs)}
.download-info{flex:1;font-size:13px;color:var(--text2)}
.compile-download-box .btn-download{background:linear-gradient(135deg,#10b981,#059669)!important;flex-shrink:0;text-decoration:none}

/* 编译历史 */
.compile-history{margin-bottom:20px}
.history-title{font-size:14px;color:var(--text2);margin-bottom:10px;font-weight:600}
.history-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--input);border-radius:var(--rs);margin-bottom:6px;font-size:13px}
.history-item i{font-size:16px;flex-shrink:0}
.history-info{flex:1;min-width:0}
.history-info span{display:block}
.history-info .history-meta{font-size:11px;color:var(--text3);margin-top:2px}

/* ===== 配额选择器 ===== */
.quota-selector{display:flex;align-items:center;gap:0;border:1px solid var(--border);border-radius:var(--rs);overflow:hidden}
.quota-btn{width:40px;height:40px;background:var(--input);border:none;color:var(--text);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s}
.quota-btn:hover{background:rgba(139,92,246,.2)}
.quota-selector input{width:80px;height:40px;border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);background:var(--input);color:var(--text);font-size:16px;font-weight:600;text-align:center;outline:none}
.quota-selector input::-webkit-inner-spin-button{display:none}
.quota-price{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.15);border-radius:var(--rs);font-size:13px;color:var(--text2)}

/* ===== 表单 ===== */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:13px;color:var(--text2);margin-bottom:5px;font-weight:500}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;background:var(--input);border:1px solid var(--border);border-radius:var(--rs);color:var(--text);font-size:14px;font-family:inherit}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(139,92,246,.12)}

/* ===== Toast ===== */
.toast{position:fixed;top:20px;right:20px;padding:12px 20px;border-radius:var(--rs);color:#fff;font-size:14px;z-index:1000;animation:slideIn .3s;box-shadow:0 4px 12px rgba(0,0,0,.3)}
.toast.ok{background:var(--green)}.toast.err{background:var(--red)}.toast.info{background:var(--accent)}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(139,92,246,.3);border-radius:2px}

/* ===== 登录器配置编辑器 ===== */
.config-editor{padding:4px 0}
.config-editor .config-section{margin-bottom:20px}
.config-editor .config-section h4{font-size:15px;color:var(--accent2);margin-bottom:14px;display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.color-picker-group{display:flex;align-items:center;gap:8px}
.color-picker-group input[type="color"]{width:36px;height:36px;border:1px solid var(--border);border-radius:var(--rs);cursor:pointer;background:transparent;padding:2px}
.color-picker-group .color-input{flex:1}
.btn-save-config{width:100%;padding:12px;margin-top:8px;font-size:14px}
.icon-upload-row{display:flex;align-items:center;gap:10px}
.form-hint{font-size:11px;color:var(--text3);margin-top:4px;display:block}

/* ===== 新仪表盘 ===== */
.dash-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}
.dash-stat{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px 16px;display:flex;align-items:center;gap:14px;transition:.15s}
.dash-stat:hover{border-color:rgba(139,92,246,.4);box-shadow:0 4px 12px rgba(139,92,246,.08)}
.dash-stat-icon{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.dash-stat.s1 .dash-stat-icon{background:rgba(139,92,246,.15);color:#a78bfa}
.dash-stat.s2 .dash-stat-icon{background:rgba(16,185,129,.15);color:#34d399}
.dash-stat.s3 .dash-stat-icon{background:rgba(59,130,246,.15);color:#60a5fa}
.dash-stat.s4 .dash-stat-icon{background:rgba(245,158,11,.15);color:#fbbf24}
.dash-stat-label{font-size:12px;color:var(--text2);display:block}
.dash-stat-value{font-size:20px;font-weight:700;display:block;margin-top:2px}
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.dash-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px}
.dash-card-title{font-size:14px;font-weight:600;color:#fff;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.dash-card-title i{color:var(--accent)}
.dash-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dash-act-btn{padding:14px 12px;background:var(--input);border:1px solid var(--border);border-radius:var(--rs);color:var(--text);font-size:13px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:.15s;text-align:left}
.dash-act-btn i{font-size:16px;color:var(--accent);flex-shrink:0}
.dash-act-btn:hover{border-color:var(--accent);background:rgba(139,92,246,.06)}
.dash-build-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--rs);margin-bottom:6px;font-size:13px;background:var(--input)}
.dash-build-item i{font-size:14px;flex-shrink:0}
.dash-build-info{flex:1;min-width:0}
.dash-build-info span{display:block}
.dash-build-info .dash-build-meta{font-size:11px;color:var(--text3);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-announce{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px}
.dash-announce h3{font-size:15px;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.dash-announce h3 i{color:var(--accent)}

/* ===== 内容管理 ===== */
.content-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.content-row-col{flex-direction:column;align-items:stretch}
.content-input{padding:8px 10px;background:var(--input);border:1px solid var(--border);border-radius:var(--rs);color:var(--text);font-size:13px;font-family:inherit}
.content-input:focus{outline:none;border-color:var(--accent)}
.content-textarea{padding:8px 10px;background:var(--input);border:1px solid var(--border);border-radius:var(--rs);color:var(--text);font-size:13px;font-family:inherit;resize:vertical;width:100%;margin-top:6px}
.content-textarea:focus{outline:none;border-color:var(--accent)}

/* ===== 公告编辑器 ===== */
.announce-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.announce-row .anc-input{padding:8px 10px;background:var(--input);border:1px solid var(--border);border-radius:var(--rs);color:var(--text);font-size:13px;font-family:inherit}
.announce-row .anc-input:focus{outline:none;border-color:var(--accent)}
.announce-row .anc-input:first-child{width:90px;flex-shrink:0}

