/* assets/css/builder.css */

/* ── SHELL ───────────────────────────── */
.builder-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg)}

/* ── TOPBAR ──────────────────────────── */
.builder-topbar{
  height:var(--topbar-h);display:flex;align-items:center;gap:8px;
  padding:0 14px;background:var(--surface);border-bottom:1px solid var(--border);
  flex-shrink:0;z-index:100;
}
.topbar-logo{font-size:16px;font-weight:600;color:var(--brand);letter-spacing:-.3px;margin-right:4px}
.topbar-app-name{font-size:13px;font-weight:500;color:var(--ink-2);padding:4px 10px;border-radius:var(--r-md);border:1px solid transparent;cursor:text;outline:none;min-width:120px}
.topbar-app-name:focus{border-color:var(--brand);background:var(--surface-2)}
.topbar-sep{flex:1}
.save-chip{font-size:11px;padding:3px 9px;border-radius:var(--r-pill)}

/* ── MAIN WORKSPACE ──────────────────── */
.builder-body{display:flex;flex:1;overflow:hidden}

/* ── LEFT PANEL ──────────────────────── */
.left-panel{
  width:200px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow-y:auto;
}
.panel-tabs{display:flex;border-bottom:1px solid var(--border);padding:6px 8px 0;gap:2px}
.panel-tab{flex:1;font-size:11px;font-weight:500;padding:5px 4px;text-align:center;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;transition:all .15s;margin-bottom:-1px}
.panel-tab.active{color:var(--brand);border-bottom-color:var(--brand)}
.panel-section-label{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);padding:10px 10px 4px}
.comp-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px 8px 10px}
.comp-tile{
  border:1px solid var(--border);border-radius:var(--r-md);padding:8px 4px;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  cursor:grab;font-size:10px;color:var(--muted);text-align:center;
  background:var(--surface);transition:all .15s;user-select:none;
  line-height:1.2;
}
.comp-tile:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}
.comp-tile:active{cursor:grabbing}
.comp-tile i{font-size:17px}
.comp-tile.dragging-source{opacity:.5}

/* ── CANVAS ──────────────────────────── */
.canvas-wrap{
  flex:1;background:#EEEDF7;overflow:auto;position:relative;
  background-image:radial-gradient(circle,var(--border-2) 1px,transparent 1px);
  background-size:20px 20px;
}
.canvas{
  min-height:100%;max-width:800px;margin:0 auto;
  padding:24px 20px 80px;display:flex;flex-direction:column;gap:2px;
}
.canvas.drag-over{outline:2px dashed var(--brand);outline-offset:-4px;border-radius:var(--r-lg)}

.drop-hint{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:400px;gap:10px;color:var(--muted);font-size:13px;pointer-events:none;
}
.drop-hint i{font-size:40px;opacity:.4}

/* Canvas item wrapper */
.c-item{
  position:relative;background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--r-md);cursor:pointer;transition:border-color .12s;
  group:hover;
}
.c-item:hover{border-color:var(--brand-mid)}
.c-item.selected{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-light)}
.c-item-bar{
  display:none;position:absolute;top:-1px;left:-1px;right:-1px;
  background:var(--brand);border-radius:var(--r-md) var(--r-md) 0 0;
  height:22px;align-items:center;padding:0 8px;gap:6px;z-index:10;
}
.c-item:hover .c-item-bar,.c-item.selected .c-item-bar{display:flex}
.c-item-type{font-size:10px;font-weight:600;color:rgba(255,255,255,.8);flex:1;letter-spacing:.03em;text-transform:uppercase}
.c-item-action{width:18px;height:18px;border-radius:3px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);cursor:pointer;font-size:13px;transition:all .1s}
.c-item-action:hover{background:rgba(255,255,255,.2);color:#fff}
.c-item-body{padding:10px 12px 12px}
.c-item:hover .c-item-body,.c-item.selected .c-item-body{padding-top:28px}

/* Drag ghost */
.drag-ghost{
  position:fixed;pointer-events:none;z-index:9999;
  background:var(--brand);color:#fff;font-size:12px;font-weight:500;
  padding:6px 12px;border-radius:var(--r-md);opacity:.9;
  box-shadow:var(--shadow-lg);transform:translate(-50%,-50%);
}

/* ── RIGHT PANEL ─────────────────────── */
.right-panel{
  width:240px;flex-shrink:0;background:var(--surface);border-left:1px solid var(--border);
  overflow-y:auto;display:flex;flex-direction:column;
}
.props-header{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.props-title{font-size:13px;font-weight:600}
.props-section{padding:12px 14px;border-bottom:1px solid var(--border)}
.props-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:10px;display:flex;align-items:center;gap:5px}
.prop-row{margin-bottom:10px}
.prop-label{font-size:11px;font-weight:500;color:var(--ink-2);margin-bottom:3px}
.prop-input{width:100%;padding:5px 8px;border:1px solid var(--border-2);border-radius:var(--r-sm);font-size:12px;color:var(--ink);background:var(--surface);outline:none;transition:border-color .12s}
.prop-input:focus{border-color:var(--brand)}
.prop-toggle{display:flex;align-items:center;justify-content:space-between}
.toggle{width:32px;height:18px;border-radius:var(--r-pill);background:var(--border-2);cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}
.toggle.on{background:var(--brand)}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:left .2s}
.toggle.on::after{left:16px}
.js-hook-badge{font-size:10px;padding:2px 7px;border-radius:var(--r-pill);background:var(--brand-light);color:var(--brand);font-weight:600}
.code-textarea{font-family:var(--mono);font-size:11px;background:var(--surface-2);resize:vertical;min-height:80px;line-height:1.6;border-color:var(--border)}
.code-hint{font-size:10px;color:var(--muted);line-height:1.5;margin-top:4px}
code{font-family:var(--mono);font-size:10px;background:var(--surface-2);padding:1px 4px;border-radius:3px;border:1px solid var(--border)}

/* ── BOTTOM STATUS BAR ───────────────── */
.status-bar{
  height:24px;background:var(--surface);border-top:1px solid var(--border);
  display:flex;align-items:center;padding:0 14px;gap:12px;flex-shrink:0;
}
.status-dot{width:6px;height:6px;border-radius:50%;background:var(--success)}
.status-text{font-size:11px;color:var(--muted)}

/* ── PAGE SIDEBAR ────────────────────── */
.pages-list{padding:6px 8px}
.page-row{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:var(--r-sm);cursor:pointer;font-size:12px;color:var(--ink-2);transition:background .12s}
.page-row:hover{background:var(--surface-2)}
.page-row.active{background:var(--brand-light);color:var(--brand)}
.page-row i{font-size:14px;flex-shrink:0}

/* ── COMPONENT PREVIEWS ──────────────── */
.prev-label{font-size:11px;color:var(--muted);margin-bottom:4px;font-weight:500}
.prev-input{width:100%;padding:6px 10px;border:1px solid var(--border-2);border-radius:var(--r-sm);font-size:12px;color:var(--ink);background:var(--surface);pointer-events:none}
.prev-select{width:100%;padding:6px 10px;border:1px solid var(--border-2);border-radius:var(--r-sm);font-size:12px;background:var(--surface);pointer-events:none}
.prev-btn-primary{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--r-sm);background:var(--brand);color:#fff;font-size:12px;font-weight:500;pointer-events:none}
.prev-btn-secondary{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--r-sm);background:var(--surface);color:var(--ink);font-size:12px;font-weight:500;border:1px solid var(--border-2);pointer-events:none}
.prev-table{width:100%;border-collapse:collapse;font-size:11px}
.prev-table th{padding:5px 8px;background:var(--surface-2);border:1px solid var(--border);color:var(--muted);font-weight:500;text-align:left}
.prev-table td{padding:5px 8px;border:1px solid var(--border);color:var(--ink-2)}
.prev-metric{background:var(--surface-2);border-radius:var(--r-md);padding:10px 12px;border:1px solid var(--border)}
.prev-metric-val{font-size:22px;font-weight:600;color:var(--ink);line-height:1}
.prev-metric-lbl{font-size:11px;color:var(--muted);margin-bottom:4px}
.prev-metric-trend{font-size:11px;color:var(--success);margin-top:3px}
.prev-bars{display:flex;align-items:flex-end;gap:4px;height:52px;padding:4px 0}
.prev-bar{flex:1;border-radius:3px 3px 0 0;background:var(--brand);opacity:.75}
.prev-textarea{width:100%;padding:6px 10px;border:1px solid var(--border-2);border-radius:var(--r-sm);font-size:12px;background:var(--surface);resize:none;pointer-events:none;color:var(--ink)}
.prev-badge-success{display:inline-flex;padding:3px 10px;border-radius:var(--r-pill);background:var(--success-bg);color:var(--success);font-size:11px;font-weight:500}
.prev-badge-danger{display:inline-flex;padding:3px 10px;border-radius:var(--r-pill);background:var(--danger-bg);color:var(--danger);font-size:11px;font-weight:500}
.prev-badge-warning{display:inline-flex;padding:3px 10px;border-radius:var(--r-pill);background:var(--warning-bg);color:var(--warning);font-size:11px;font-weight:500}
.prev-divider{border:none;border-top:1px solid var(--border);margin:6px 0}
.prev-heading{font-size:16px;font-weight:600;color:var(--ink)}
.prev-text{font-size:13px;color:var(--ink-2);line-height:1.5}
.prev-caption{font-size:11px;color:var(--muted)}
.prev-container{border:1px solid var(--border);border-radius:var(--r-md);padding:12px;background:var(--surface-2);min-height:48px;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--muted)}
.prev-columns{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.prev-col-box{background:var(--surface-2);border:1px dashed var(--border-2);border-radius:var(--r-sm);height:40px;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--muted)}
.prev-tabs{display:flex;gap:2px;background:var(--surface-2);padding:3px;border-radius:var(--r-sm)}
.prev-tab{flex:1;text-align:center;padding:4px 8px;font-size:11px;border-radius:4px}
.prev-tab.active{background:var(--surface);color:var(--brand);font-weight:500}
.prev-tab:not(.active){color:var(--muted)}

/* ── DASHBOARD / LOGIN LAYOUT ────────── */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg)}
.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:32px;box-shadow:var(--shadow-lg)}
.auth-logo{font-size:22px;font-weight:700;color:var(--brand);text-align:center;margin-bottom:6px;letter-spacing:-.4px}
.auth-tagline{font-size:13px;color:var(--muted);text-align:center;margin-bottom:28px}

.dash-shell{display:flex;height:100vh;overflow:hidden}
.dash-sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}
.dash-main{flex:1;overflow-y:auto;background:var(--bg)}
.dash-content{padding:28px 32px;max-width:1000px}
.dash-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.dash-title{font-size:20px;font-weight:600}
.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.app-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;cursor:pointer;transition:all .15s;position:relative}
.app-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand-mid)}
.app-card-icon{width:42px;height:42px;border-radius:var(--r-md);background:var(--brand-light);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:10px}
.app-card-name{font-size:13px;font-weight:600;margin-bottom:3px}
.app-card-desc{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:10px}
.app-card-meta{display:flex;align-items:center;gap:8px}
.app-card-actions{position:absolute;top:10px;right:10px;display:none;gap:4px}
.app-card:hover .app-card-actions{display:flex}

.sidebar-logo{padding:16px;font-size:18px;font-weight:700;color:var(--brand);border-bottom:1px solid var(--border);letter-spacing:-.3px}
.sidebar-section{padding:12px 10px 4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.sidebar-item{display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:var(--r-md);margin:1px 6px;font-size:13px;color:var(--ink-2);cursor:pointer;transition:all .12s}
.sidebar-item:hover{background:var(--surface-2);color:var(--ink)}
.sidebar-item.active{background:var(--brand-light);color:var(--brand)}
.sidebar-item i{font-size:16px;flex-shrink:0}
.sidebar-bottom{margin-top:auto;padding:12px;border-top:1px solid var(--border)}
.sidebar-user{display:flex;align-items:center;gap:8px;padding:6px;border-radius:var(--r-md);cursor:pointer}
.sidebar-user:hover{background:var(--surface-2)}
.sidebar-user-info{flex:1;min-width:0}
.sidebar-user-name{font-size:12px;font-weight:500;color:var(--ink)}
.sidebar-user-role{font-size:11px;color:var(--muted)}
