:root{
  --bg:#f5f7fb;--panel:#fff;--panel2:#f9fafc;--text:#121827;--muted:#697386;--line:#e6eaf2;
  --primary:#e92176;--primary-dark:#c9135f;--ok:#0e9f6e;--danger:#d92d20;--warn:#b7791f;
  --shadow:0 18px 45px rgba(15,23,42,.08);--radius:18px;
}
*{box-sizing:border-box}html,body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--text)}a{color:inherit}.hidden{display:none!important}.muted{color:var(--muted)}.tiny{font-size:12px}
body:not(.auth-body){height:100vh;overflow:hidden}.auth-body{min-height:100vh;overflow:auto;display:flex;align-items:center;justify-content:center;padding:28px;background:radial-gradient(circle at top left,rgba(233,33,118,.18),transparent 34%),linear-gradient(135deg,#fff,#f5f7fb 55%,#eef2ff)}
.auth-card{width:min(440px,100%);background:rgba(255,255,255,.92);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.7);border-radius:28px;padding:34px;box-shadow:var(--shadow)}.installer-card{width:min(540px,100%)}
.brand-mark{width:58px;height:58px;border-radius:18px;background:linear-gradient(135deg,var(--primary),#8b1cf6);display:flex;align-items:center;justify-content:center;color:#fff;font-size:30px;font-weight:900;box-shadow:0 12px 28px rgba(233,33,118,.28);margin-bottom:18px}.brand-mark.small{width:42px;height:42px;font-size:22px;border-radius:14px;margin:0}.auth-card h1{margin:0 0 8px;font-size:29px;letter-spacing:-.03em}
.form-stack{display:flex;flex-direction:column;gap:15px;margin-top:22px}.form-stack label{display:flex;flex-direction:column;gap:7px;font-size:13px;font-weight:750;color:#344054}.form-stack input,.form-stack textarea,.form-grid input,.form-grid select,.tool-site-row select,.full-select,.search-input{width:100%;border:1px solid var(--line);border-radius:14px;padding:12px 14px;font:inherit;background:#fff;color:var(--text);outline:none;transition:.18s}.form-stack textarea{resize:vertical}.form-stack input:focus,.form-stack textarea:focus,.form-grid input:focus,.form-grid select:focus,.search-input:focus,.tool-site-row select:focus,.full-select:focus{border-color:rgba(233,33,118,.65);box-shadow:0 0 0 4px rgba(233,33,118,.12)}
.button{border:1px solid var(--line);background:#fff;color:#202939;border-radius:13px;padding:10px 15px;font-weight:800;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;transition:.18s;white-space:nowrap}.button:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(15,23,42,.08)}.button:disabled,.button.disabled,.upload-button.disabled{opacity:.48;pointer-events:none}.button-primary{background:linear-gradient(135deg,var(--primary),#a01de2);color:#fff;border-color:transparent}.button-primary:hover{box-shadow:0 14px 30px rgba(233,33,118,.22)}.button.danger,.danger{background:#fff1f0!important;border-color:#ffd6d1!important;color:#9b2118!important}.full{width:100%}.alert,.notice{border-radius:16px;padding:13px 14px;font-size:14px;line-height:1.45}.alert-danger,.notice.error{background:#fff1f0;color:#9b2118;border:1px solid #ffd6d1}.alert-ok,.notice{background:#effdf6;color:#05603a;border:1px solid #bef3d3}.notice{position:sticky;top:0;z-index:20;margin-bottom:14px}
.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:270px;background:#101828;color:#f9fafb;display:flex;flex-direction:column;padding:22px;flex:0 0 270px}.sidebar-brand{display:flex;align-items:center;gap:13px;padding-bottom:22px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-brand strong{display:block;font-size:17px}.sidebar-brand small{display:block;color:#aab2c0;font-size:12px;margin-top:2px}.side-nav{display:flex;flex-direction:column;gap:8px;margin-top:24px}.side-nav a{padding:13px 14px;text-decoration:none;border-radius:14px;color:#ccd5e1;font-weight:750}.side-nav a:hover,.side-nav a.active{background:rgba(255,255,255,.09);color:#fff}.sidebar-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.1);padding-top:18px;display:flex;flex-direction:column;gap:10px;color:#cbd5e1}.sidebar-footer a{color:#fff;text-decoration:none;font-weight:800}
.main-area{height:100vh;flex:1;min-width:0;padding:24px 28px;display:flex;flex-direction:column;overflow:hidden}.topbar{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:16px;flex:0 0 auto}.topbar h1{margin:0;font-size:29px;letter-spacing:-.04em}.topbar p{margin:5px 0 0;color:var(--muted)}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:16px;flex:0 0 auto}.stat-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:0 10px 28px rgba(15,23,42,.04)}.stat-card span{display:block;color:var(--muted);font-size:13px;font-weight:750}.stat-card strong{display:block;font-size:24px;margin-top:8px;letter-spacing:-.03em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.view-section{min-height:0;flex:1;display:flex;flex-direction:column}.view-section.active{display:flex}.workspace{display:grid;grid-template-columns:340px minmax(0,1fr);gap:18px;min-height:0;height:100%}.explorer-workspace,.db-workspace{height:100%}.sites-panel,.file-panel,.panel-block{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 10px 30px rgba(15,23,42,.04);min-width:0}.sites-panel{padding:18px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.file-panel{padding:0;overflow:hidden;display:flex;flex-direction:column;min-height:0}.panel-block{padding:20px;min-height:0;overflow:auto}.panel-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.panel-title h2,.file-toolbar h2{margin:0;font-size:17px;letter-spacing:-.02em}.panel-title p{margin:4px 0 0}.icon-button{width:38px;height:38px;border-radius:12px;border:1px solid var(--line);background:#fff;font-size:18px;font-weight:900;cursor:pointer}.toolbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.file-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line);flex:0 0 auto}.breadcrumb{font-size:13px;color:var(--muted);margin-top:4px;word-break:break-all}.drop-hint{padding:12px 20px;background:#fafbff;border-bottom:1px solid var(--line);color:#667085;font-size:13px;flex:0 0 auto}.drag-over{outline:3px dashed rgba(233,33,118,.35);outline-offset:-8px}.selection-bar{margin:12px 20px 0;padding:11px 12px;border:1px solid #f3c6d9;background:#fff7fb;border-radius:14px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:13px;color:#475467;flex:0 0 auto}.selection-bar strong{color:#101828}.selection-bar .mini-btn{margin-left:auto}
.sites-list{display:flex;flex-direction:column;gap:10px;overflow:auto;min-height:0;padding-right:4px}.manager-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;overflow:visible}.site-item{border:1px solid var(--line);background:#fff;border-radius:16px;padding:14px;cursor:pointer;transition:.18s}.site-item:hover,.site-item.active{border-color:rgba(233,33,118,.45);box-shadow:0 12px 26px rgba(15,23,42,.07)}.site-item strong{display:flex;align-items:center;gap:8px;margin-bottom:6px}.site-item small{display:block;color:var(--muted);font-size:12px;margin-top:4px;word-break:break-all}.status-dot{width:9px;height:9px;border-radius:99px;background:#d0d5dd}.status-dot.ok{background:var(--ok)}.site-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:12px}.mini-btn{border:1px solid var(--line);background:#fff;border-radius:11px;padding:7px 10px;font-size:12px;font-weight:800;cursor:pointer}.mini-btn:hover{box-shadow:0 8px 18px rgba(15,23,42,.06)}.mini-btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-flex;align-items:center;border-radius:99px;padding:4px 8px;font-size:12px;font-weight:800;background:#f2f4f7;color:#475467}.badge.ok{background:#ecfdf3;color:#067647}.badge.error{background:#fff1f0;color:#b42318}
.table-wrap{overflow:auto;min-height:0;flex:1}.file-table{width:100%;border-collapse:separate;border-spacing:0;min-width:720px}.file-table th{text-transform:uppercase;font-size:12px;color:#667085;letter-spacing:.04em;background:#fbfcff;text-align:left}.file-table th,.file-table td{border-bottom:1px solid var(--line);padding:13px 14px;vertical-align:middle}.file-row{cursor:default}.file-row:hover{background:#fafbff}.file-row.selected{background:#fff4fa}.file-name{display:flex;align-items:center;gap:10px;font-weight:800}.file-icon{width:32px;height:32px;border-radius:10px;background:#f2f4f7;display:flex;align-items:center;justify-content:center}.check-col{width:44px;text-align:center}.check-col input{width:16px;height:16px;accent-color:var(--primary)}.empty{text-align:center;color:var(--muted);padding:24px!important}.activity-inline{border-top:1px solid var(--line);padding:14px 18px;max-height:190px;overflow:auto;flex:0 0 auto}.activity-list{display:flex;flex-direction:column;gap:9px}.activity-item{border:1px solid var(--line);border-radius:14px;padding:10px 12px;display:flex;justify-content:space-between;gap:12px;background:#fff}.activity-item p{margin:4px 0 0;color:var(--muted);font-size:12px}.activity-item strong{font-size:13px}.activity-list.slim .activity-item{padding:8px 10px}.context-menu{position:fixed;z-index:1000;min-width:210px;background:#fff;border:1px solid var(--line);box-shadow:0 18px 45px rgba(15,23,42,.18);border-radius:14px;padding:8px}.context-title{padding:8px 10px;color:var(--muted);font-size:12px;font-weight:800;border-bottom:1px solid var(--line);margin-bottom:4px}.context-menu button{width:100%;border:0;background:transparent;text-align:left;padding:10px 11px;border-radius:10px;font-weight:750;cursor:pointer}.context-menu button:hover{background:#f7f8fb}
.tool-site-row{display:grid;grid-template-columns:minmax(260px,1fr) auto;gap:12px;align-items:end;margin-bottom:16px}.tool-site-row label{font-size:13px;font-weight:800;color:#344054}.info-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin-bottom:16px}.info-grid article{border:1px solid var(--line);background:#fbfcff;border-radius:14px;padding:12px}.info-grid span{display:block;font-size:12px;color:var(--muted);font-weight:800}.info-grid strong{display:block;margin-top:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tools-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;align-items:stretch}.tool-card{border:1px solid var(--line);border-radius:18px;background:#fff;padding:18px;display:flex;flex-direction:column;gap:12px;min-width:0}.tool-card h3{margin:0;font-size:17px}.tool-card p{margin:0;color:var(--muted);line-height:1.45}.tool-card textarea{width:100%;border:1px solid var(--line);border-radius:14px;padding:12px;resize:vertical;font:inherit}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.danger-card{background:#fffafa;border-color:#ffd6d1}.two-buttons{display:flex;gap:10px;flex-wrap:wrap}
.db-workspace{grid-template-columns:320px minmax(0,1fr)}.db-table-list{display:flex;flex-direction:column;gap:8px;overflow:auto;min-height:0;margin-top:12px}.db-table-btn{border:1px solid var(--line);background:#fff;border-radius:14px;padding:12px;text-align:left;cursor:pointer}.db-table-btn:hover,.db-table-btn.active{border-color:rgba(233,33,118,.5);background:#fff7fb}.db-table-btn strong{display:block}.db-table-btn small{display:block;color:var(--muted);margin-top:5px}.search-input{margin:10px 0 0}.row-search{width:260px;margin:0}.db-scroll{max-height:none}.db-table{min-width:900px}.load-more-wrap{padding:12px 20px;border-top:1px solid var(--line);display:flex;justify-content:center;flex:0 0 auto}.db-row-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;overflow:auto;max-height:65vh}.db-row-fields label{display:flex;flex-direction:column;gap:7px;font-size:13px;font-weight:800}.db-row-fields textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:10px;font:inherit}.db-row-fields small{color:var(--muted);font-weight:600}
.modal{position:fixed;inset:0;background:rgba(16,24,40,.48);display:flex;align-items:center;justify-content:center;padding:24px;z-index:999}.modal-card{width:min(620px,100%);max-height:90vh;overflow:auto;background:#fff;border-radius:22px;box-shadow:var(--shadow);padding:20px;border:1px solid rgba(255,255,255,.7)}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.modal-head h2{margin:0}.editor-card{width:min(980px,100%)}.editor-meta{color:var(--muted);font-size:13px;margin-bottom:10px;word-break:break-all}#fileEditor{width:100%;height:60vh;border:1px solid var(--line);border-radius:16px;padding:14px;font:13px/1.5 ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;resize:vertical;background:#0f172a;color:#e5e7eb}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}
@media (max-width:1200px){.info-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.workspace{grid-template-columns:300px minmax(0,1fr)}}
@media (max-width:900px){body:not(.auth-body){height:auto;overflow:auto}.app-shell{height:auto;min-height:100vh;display:block}.sidebar{position:static;width:100%;height:auto}.main-area{height:auto;overflow:visible;padding:18px}.stats-grid,.tools-grid,.workspace,.db-workspace,.info-grid{grid-template-columns:1fr}.view-section{display:block}.file-panel,.sites-panel{min-height:420px}.topbar,.file-toolbar{flex-direction:column;align-items:flex-start}.toolbar-actions{width:100%}.row-search{width:100%}}
/* V4 */
.tools-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.subtabs{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0 16px;border-bottom:1px solid var(--line);padding-bottom:10px}
.subtabs button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 16px;font-weight:850;cursor:pointer;color:#344054}
.subtabs button.active{background:linear-gradient(135deg,var(--primary),#a01de2);color:#fff;border-color:transparent;box-shadow:0 12px 24px rgba(233,33,118,.16)}
.tools-tab{min-height:0}.plugin-manager{margin-top:16px;border:1px solid var(--line);border-radius:18px;background:#fff;padding:16px}.plugins-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;max-height:42vh;overflow:auto;padding-right:4px}.plugin-item{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;border:1px solid var(--line);border-radius:14px;background:#fff;padding:11px;cursor:pointer}.plugin-item.active{background:#f7fffb;border-color:#b7efcf}.plugin-item.locked{opacity:.72}.plugin-item input{width:16px;height:16px;accent-color:var(--primary)}.plugin-item strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plugin-item small{display:block;color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:3px}.plugin-item em{font-style:normal;font-size:12px;font-weight:850;border-radius:999px;padding:5px 8px;background:#f2f4f7;color:#475467}.plugin-item.active em{background:#ecfdf3;color:#067647}.mini-list{display:flex;flex-direction:column;gap:8px;max-height:210px;overflow:auto}.mini-list-item{border:1px solid var(--line);background:#fbfcff;border-radius:13px;padding:10px}.mini-list-item strong{display:block;font-size:13px}.mini-list-item small{display:block;color:var(--muted);font-size:12px;margin-top:3px;word-break:break-all}.upload-progress{margin:12px 20px 0;padding:13px 14px;border:1px solid #f3c6d9;background:#fff7fb;border-radius:16px;flex:0 0 auto}.upload-progress-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:9px}.upload-progress-head strong{font-size:14px}.upload-progress-head span{font-weight:900;color:var(--primary)}.upload-progress-bar{height:9px;background:#f4d4e2;border-radius:999px;overflow:hidden}.upload-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),#a01de2);border-radius:999px;transition:width .18s ease}.upload-progress small{display:block;margin-top:8px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (max-width:1250px){.tools-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.plugins-list{grid-template-columns:1fr}}
@media (max-width:900px){.tools-grid{grid-template-columns:1fr}.plugins-list{grid-template-columns:1fr;max-height:none}}
