
.af-btn{display:inline-block;padding:8px 12px;border:1px solid #ddd;border-radius:8px;background:#fff;cursor:pointer}
.af-btn.primary{background:#2563eb;color:#fff;border-color:#2563eb}
.af-btn.danger{background:#dc2626;color:#fff;border-color:#dc2626}
.af-btn.small{padding:4px 8px;font-size:12px}

.af-list-wrap{max-width:1100px;margin:20px auto;padding:10px}
.af-list-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.af-table{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}
.af-tr{display:grid;grid-template-columns:3fr 1.4fr 3fr 1.4fr;border-top:1px solid #f1f5f9}
.af-tr.af-th{background:#f8fafc;font-weight:600}
.af-tr>div{padding:10px 12px;display:flex;gap:8px;align-items:center}
.af-empty{padding:24px;text-align:center;color:#6b7280}
.af-code{background:#f1f5f9;padding:2px 6px;border-radius:6px}

.af-modal{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:9999}
.af-modal .af-modal-body{background:#fff;max-width:720px;width:92%;border-radius:12px;padding:20px;border:1px solid #e5e7eb}
#af-code-text{width:100%;height:160px;background:#0b1020;color:#e5eeff;border:none;border-radius:8px;padding:10px;font-family:ui-monospace,Consolas,monospace}

.af-builder-wrap{max-width:1200px;margin:20px auto}
.af-builder-head .af-row{display:flex;gap:10px;margin:8px 0}
.af-builder-head label{width:120px;display:inline-block}
.af-cols{display:grid;grid-template-columns:260px 1fr 300px;gap:16px;margin-top:12px}
.af-col{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px}
.af-palette{display:flex;flex-wrap:wrap;gap:8px}
.af-chip{padding:6px 10px;border:1px dashed #94a3b8;border-radius:999px;background:#f8fafc;cursor:pointer}
#af-canvas.af-canvas{min-height:240px;border:2px dashed #cbd5e1;border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:10px}
.af-item{border:1px solid #e5e7eb;border-radius:10px;padding:10px;background:#fafafa;cursor:pointer}
.af-item.active{outline:2px solid #2563eb;background:#eef2ff}
.af-item .meta{font-size:12px;color:#6b7280}

.af-inspector .af-row{display:flex;gap:8px;margin:8px 0}
.af-inspector label{width:92px}
.af-inspector input[type="text"],
.af-inspector input[type="number"],
.af-inspector textarea,
.af-inspector select{flex:1;border:1px solid #e5e7eb;border-radius:8px;padding:6px 8px}
.af-inspector .opt-list{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.af-inspector .opt-list input{width:100%}

.af-builder-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}

.af-render .af-grid{display:grid;gap:12px}
.af-render .af-grid.columns-1{grid-template-columns:1fr}
.af-render .af-grid.columns-2{grid-template-columns:1fr 1fr}
.af-render .af-grid.columns-3{grid-template-columns:1fr 1fr 1fr}
.af-field label{display:block;margin-bottom:6px;font-weight:600}
.af-field .req{color:#dc2626}
.af-help{font-size:12px;color:#64748b;margin-top:4px}
.af-form-actions{margin-top:14px}
.af-custom-top,.af-custom-bottom{background:#f8fafc;border:1px dashed #cbd5e1;padding:10px;border-radius:10px;margin:8px 0}
.muted{color:#94a3b8}
