/* ═══════════════════════════════════════════════════════════════
   Wechat SaaS — v3 Commercial Console
   ═══════════════════════════════════════════════════════════════ */

:root {
  --c-bg: #f5f6fa;
  --c-surface: #ffffff;
  --c-surface-inset: #f7f8fb;
  --c-border: #e5e7ed;
  --c-border-light: #eef0f4;
  --c-border-strong: #d1d5de;

  --c-text: #1a1d26;
  --c-text-secondary: #4e5969;
  --c-text-muted: #86909c;
  --c-text-placeholder: #c2c6cf;

  --c-brand: #2563eb;
  --c-brand-hover: #1d4ed8;
  --c-brand-light: #eff4ff;
  --c-brand-bg: #f0f5ff;

  --c-success: #10b981;
  --c-success-bg: #ecfdf5;
  --c-warning: #f59e0b;
  --c-warning-bg: #fef9c3;
  --c-danger: #ef4444;
  --c-danger-bg: #fef2f2;

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 2px 8px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.08);
  --shadow-xl: 0 16px 48px rgba(0,0,0,0.10);

  --r-xs: 4px; --r-sm: 6px; --r-md: 8px; --r-lg: 12px; --r-xl: 16px; --r-2xl: 20px;

  --font: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Noto Sans SC", "Segoe UI", system-ui, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);color:var(--c-text);background:var(--c-bg);
  min-height:100vh;font-size:14px;line-height:1.57;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ── Layout ───────────────────────────────────────────────── */
.app-shell{min-height:100vh}
.layout-shell{min-height:100vh;display:grid;grid-template-columns:240px 1fr}
.nav-drawer-toggle{
  position:fixed;opacity:0;pointer-events:none;
  width:1px;height:1px;overflow:hidden;
}

/* ── Sidebar ──────────────────────────────────────────────── */
.sidebar{
  background:var(--c-surface);border-right:1px solid var(--c-border);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;overflow-y:auto;z-index:20;
}
.sidebar-backdrop{
  position:fixed;inset:0;background:rgba(15,23,42,0.36);
  opacity:0;pointer-events:none;transition:opacity 180ms ease;
  z-index:24;
}
.sidebar-brand{
  display:flex;align-items:center;gap:12px;
  padding:24px 20px 16px;border-bottom:1px solid var(--c-border-light);
}
.sidebar-brand-main{display:flex;align-items:center;gap:12px;min-width:0}
.sidebar-logo{
  width:36px;height:36px;border-radius:var(--r-md);
  overflow:hidden;flex-shrink:0;
  box-shadow:0 8px 18px rgba(37,99,235,0.18);
  background:rgba(37,99,235,0.08);
}
.sidebar-logo img{
  width:100%;height:100%;display:block;object-fit:cover;
}
.sidebar-title{font-size:15px;font-weight:700;color:var(--c-text);letter-spacing:-0.01em}
.sidebar-subtitle{margin-top:2px;font-size:11px;color:var(--c-text-muted);font-weight:500}
.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:16px 12px;flex:1}
.sidebar-nav a{
  color:var(--c-text-secondary);padding:9px 12px;border-radius:var(--r-sm);
  font-size:13px;font-weight:500;transition:all 120ms ease;
  display:flex;align-items:center;gap:8px;position:relative;
}
.sidebar-nav a:hover{background:var(--c-surface-inset);color:var(--c-text)}
.sidebar-nav a.active{background:var(--c-brand-light);color:var(--c-brand);font-weight:600}
.sidebar-nav a.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:18px;border-radius:0 2px 2px 0;background:var(--c-brand);
}
.sidebar-toggle-btn{
  display:none;align-items:center;justify-content:center;flex-shrink:0;
  width:40px;height:40px;border-radius:var(--r-md);
  border:1px solid var(--c-border);background:var(--c-surface);
  color:var(--c-text);cursor:pointer;transition:all 120ms ease;
}
.sidebar-toggle-btn:hover{background:var(--c-surface-inset)}
.sidebar-toggle-open{flex-direction:column;gap:4px}
.sidebar-toggle-open span{
  display:block;width:16px;height:2px;border-radius:999px;background:currentColor;
}
.sidebar-toggle-close{
  position:relative;margin-left:auto;
  background:transparent;border-color:transparent;
}
.sidebar-toggle-close span{
  position:absolute;width:16px;height:2px;border-radius:999px;background:currentColor;
}
.sidebar-toggle-close span:first-child{transform:rotate(45deg)}
.sidebar-toggle-close span:last-child{transform:rotate(-45deg)}

/* ── Main ─────────────────────────────────────────────────── */
.layout-main{min-width:0;display:flex;flex-direction:column;background:var(--c-bg)}
.workspace-header{
  height:56px;background:var(--c-surface);border-bottom:1px solid var(--c-border);
  display:flex;align-items:center;justify-content:space-between;padding:0 24px;
  position:sticky;top:0;z-index:10;
}
.workspace-headline{display:flex;align-items:center;gap:12px;min-width:0}
.workspace-title{margin:0;font-size:16px;color:var(--c-text);font-weight:600;line-height:1.3}
.workspace-actions{display:flex;align-items:center;gap:4px}
.header-link{color:var(--c-text-muted);font-size:13px;padding:6px 10px;border-radius:var(--r-sm);font-weight:500;transition:all 120ms ease}
.header-link:hover{background:var(--c-surface-inset);color:var(--c-text)}
.workspace-content{padding:20px 24px 40px;display:flex;flex-direction:column;gap:16px}

/* ── Page Head ────────────────────────────────────────────── */
.page-head{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.page-head h1{margin:0;font-size:20px;color:var(--c-text);font-weight:700;letter-spacing:-0.02em}
.page-head-hero h1{font-size:22px}
.head-actions{display:flex;gap:8px;flex-wrap:wrap}
.eyebrow{color:var(--c-text-muted);font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:4px}
.muted,.footnote,.panel-head p{color:var(--c-text-muted);font-size:13px;line-height:1.6;margin:0}

/* ── Grids ────────────────────────────────────────────────── */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.stat-grid-5{grid-template-columns:repeat(5,1fr)}
.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;align-items:stretch}
.card-grid-wide{grid-template-columns:1.4fr 1fr;align-items:stretch}
.card-grid-wide>.panel-card{display:flex;flex-direction:column}
.card-grid-wide>.panel-card .table-card-list,.card-grid-wide>.panel-card .table-list,.card-grid-wide>.panel-card .stack-top{flex:1}
.section-split,.submit-layout,.admin-detail-grid,.billing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.submit-layout-featured{grid-template-columns:1.4fr 1fr}

/* ── Cards ────────────────────────────────────────────────── */
.panel-card{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm);
}
.panel-card-priority{box-shadow:var(--shadow-md)}
.panel-card-side{background:var(--c-surface)}
.panel-head{margin-bottom:14px}
.panel-head-inline{display:flex;align-items:center;justify-content:space-between;gap:12px}
.panel-head h2,.quick-card h3{margin:0;font-size:14px;color:var(--c-text);font-weight:600}
.panel-head p{margin:4px 0 0}

/* ── Stat Cards ───────────────────────────────────────────── */
.stat-card{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-sm);
  position:relative;overflow:hidden;
}
.stat-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--c-border);transition:background 200ms ease;
}
.stat-card-emphasis{background:var(--c-brand);border-color:transparent}
.stat-card-emphasis::before{background:rgba(255,255,255,0.2)}
.stat-card-emphasis .stat-label{color:rgba(255,255,255,0.7)}
.stat-card-emphasis .stat-value{color:#fff}
.stat-label{color:var(--c-text-muted);font-size:11px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase}
.stat-value{display:block;margin-top:6px;font-size:24px;font-weight:700;color:var(--c-text);letter-spacing:-0.02em;line-height:1.2}
.stat-value-sm{font-size:18px}

/* ── Summary Grid ─────────────────────────────────────────── */
.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0}
.summary-grid div{
  padding:10px 12px;border-bottom:1px solid var(--c-border-light);
  display:flex;flex-direction:column;gap:2px;
}
.summary-grid div:nth-child(odd){border-right:1px solid var(--c-border-light)}
.summary-grid div:nth-last-child(-n+2){border-bottom:none}
.summary-grid div span{font-size:11px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;color:var(--c-text-muted)}
.summary-grid div strong{font-size:13px;color:var(--c-text);font-weight:600;word-break:break-all;line-height:1.4}
.summary-grid-compact div{min-height:58px}
.micro-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.story-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.quick-grid,.audit-filter-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}

/* ── Tables ───────────────────────────────────────────────── */
.table-list{display:grid}
.table-list .table-row{display:grid;align-items:center}
.table-list .table-row.table-grid-wechat-jobs{grid-template-columns:200px 160px minmax(200px,1fr)}
.table-list .table-row.table-grid-batches{grid-template-columns:minmax(220px,1.3fr) minmax(140px,0.8fr) 80px 100px}
.table-header-grid{
  display:grid;gap:12px;padding:8px 12px;
  background:var(--c-surface-inset);border-radius:var(--r-sm) var(--r-sm) 0 0;
  border-bottom:1px solid var(--c-border);
}
.table-header-grid span{color:var(--c-text-muted);font-size:11px;font-weight:700;letter-spacing:0.05em;text-transform:uppercase}
.table-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 12px;border-bottom:1px solid var(--c-border-light);transition:background 100ms ease;
}
.table-row:last-child{border-bottom:none}
.table-row:hover{background:var(--c-surface-inset)}
.table-row-wide{align-items:flex-start;flex-wrap:wrap}
.table-row>div,.table-row>form{min-width:0}
.table-row>div:first-child{display:flex;flex-direction:column;gap:2px}
.table-row strong{font-size:13px;color:var(--c-text);font-weight:600}
.table-row span{font-size:12px;color:var(--c-text-muted)}

.table-grid-audit,.table-header-audit{grid-template-columns:minmax(180px,1fr) minmax(200px,1.5fr) minmax(120px,0.7fr)}
.table-grid-people-admin,.table-header-people-admin{grid-template-columns:minmax(180px,1.2fr) 120px 100px}
.table-grid-people-user,.table-header-people-user{grid-template-columns:minmax(180px,1.2fr) 100px 140px 100px}
.table-grid-tenant,.table-header-tenant{grid-template-columns:minmax(180px,1.2fr) 120px 100px minmax(140px,0.8fr)}
.table-grid-batches,.table-header-batches{grid-template-columns:minmax(220px,1.3fr) minmax(140px,0.8fr) 80px 100px}
.table-grid-publishes,.table-header-publishes{grid-template-columns:minmax(180px,1fr) 120px minmax(180px,1fr)}
.table-grid-channel-health,.table-header-channel-health{grid-template-columns:minmax(180px,1fr) 100px minmax(220px,1.2fr) 100px}
.table-grid-channel-map,.table-header-channel-map{grid-template-columns:minmax(180px,1fr) minmax(120px,0.9fr) minmax(120px,0.9fr) 100px}
.table-grid-channel-app,.table-header-channel-app{grid-template-columns:minmax(180px,1fr) 120px 120px 100px}
.table-grid-tenant-admin,.table-header-tenant-admin{grid-template-columns:minmax(130px,1fr) 100px 60px 80px 100px 100px minmax(340px,1.8fr)}
.table-grid-tenant-admin{display:grid}
.table-grid-admin-list,.table-header-admin-list{grid-template-columns:minmax(140px,1fr) 120px 100px minmax(140px,0.8fr) minmax(200px,1.2fr)}
.table-grid-admin-list{display:grid}
.table-grid-admin-maintain,.table-header-admin-maintain{grid-template-columns:minmax(120px,1fr) 100px 90px minmax(120px,0.8fr) 80px minmax(300px,1.6fr)}
.table-grid-billing-admin,.table-header-billing-admin{grid-template-columns:minmax(140px,1fr) 100px 100px 90px 130px minmax(260px,1.2fr)}
.table-grid-channel-ops,.table-header-channel-ops{grid-template-columns:minmax(130px,1fr) 100px 100px minmax(140px,1fr) 120px 130px 80px}
.table-grid-task-audit,.table-header-task-audit{grid-template-columns:100px 110px 90px 90px minmax(120px,0.8fr) minmax(140px,1fr) 100px 80px}
.table-grid-wechat-jobs,.table-header-wechat-jobs{grid-template-columns:200px 160px minmax(200px,1fr)}
.table-grid-logs,.table-header-logs{grid-template-columns:100px 120px minmax(160px,1fr) 90px 80px minmax(160px,1fr)}
.table-grid-logs{display:grid;align-items:center}
.table-grid-logs>div:first-child{display:block}
.table-grid-logs .status-pill{justify-self:start}
.trace-stage-cell,
.trace-result-cell{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:4px;
}
.trace-result-cell strong,
.trace-result-cell span,
.trace-stage-cell span{
  line-height:1.5;
  word-break:break-word;
}
.table-console-model,.table-header-console-model{grid-template-columns:minmax(140px,1fr) 120px minmax(140px,1fr) 80px}
.table-console-model{display:grid;gap:12px;align-items:center}
.list-stack{display:grid;gap:8px}
.list-empty{color:var(--c-text-muted);padding:20px 12px;font-size:13px;text-align:center}
.row-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.row-actions .inline-form{margin:0}

.admin-dialog{
  border:none;
  padding:0;
  background:transparent;
  max-width:min(560px, calc(100vw - 32px));
  width:100%;
}
.admin-dialog::backdrop{background:rgba(15,23,42,0.44);backdrop-filter:blur(2px)}
.admin-dialog-card{
  background:var(--c-surface);
  border:1px solid var(--c-border);
  border-radius:var(--r-xl);
  box-shadow:var(--shadow-xl);
  padding:20px;
}
.admin-dialog-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:16px;
}
.admin-dialog-head h2{
  margin:0;
  font-size:18px;
  color:var(--c-text);
  font-weight:700;
}
.admin-dialog-form{display:grid;gap:16px}
.admin-checklist{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
}
.admin-check-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border:1px solid var(--c-border);
  border-radius:var(--r-md);
  background:var(--c-surface-inset);
  cursor:pointer;
  transition:border-color 120ms ease, background 120ms ease, box-shadow 120ms ease;
}
.admin-check-item:hover{
  border-color:var(--c-brand);
  background:var(--c-brand-light);
}
.admin-check-item input{
  width:16px;
  height:16px;
  margin:0;
  accent-color:var(--c-brand);
  flex-shrink:0;
}
.admin-check-item span{
  font-size:13px;
  color:var(--c-text);
  font-weight:600;
}
.admin-dialog-actions{
  display:flex;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}

/* ── Forms ────────────────────────────────────────────────── */
.form-grid{display:grid;gap:6px}
.form-grid-spacious{gap:8px}
.filter-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;align-items:end}
.filter-grid label{font-size:11px;font-weight:600;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:0.04em;margin-bottom:4px;display:block}
.filter-grid input,.filter-grid select{width:100%;border:1px solid var(--c-border);background:#fff;border-radius:var(--r-sm);padding:8px 10px;font-size:13px;font-family:var(--font);color:var(--c-text);outline:none;transition:border-color 120ms ease,box-shadow 120ms ease}
.filter-grid input:focus,.filter-grid select:focus{border-color:var(--c-brand);box-shadow:0 0 0 3px rgba(37,99,235,0.08)}
.filter-actions{align-self:end}
.two-column-form{grid-template-columns:repeat(2,1fr);gap:10px}
.form-span-full{grid-column:1/-1}
.form-grid label{font-size:12px;font-weight:600;color:var(--c-text-secondary);margin-bottom:1px}
.form-grid input,.form-grid select,.form-grid textarea{
  width:100%;border:1px solid var(--c-border-strong);background:#fff;
  border-radius:var(--r-sm);padding:9px 11px;color:var(--c-text);
  font-size:13px;font-family:var(--font);outline:none;
  transition:border-color 120ms ease,box-shadow 120ms ease;
}
.form-grid textarea{min-height:100px;resize:vertical}
.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus{
  border-color:var(--c-brand);box-shadow:0 0 0 3px rgba(37,99,235,0.08);
}
.form-grid input::placeholder,.form-grid textarea::placeholder{color:var(--c-text-placeholder)}

/* ── Buttons ──────────────────────────────────────────────── */
.btn{
  border:1px solid transparent;border-radius:var(--r-sm);
  padding:8px 16px;display:inline-flex;align-items:center;justify-content:center;
  gap:6px;font-weight:600;font-size:13px;font-family:var(--font);
  cursor:pointer;transition:all 150ms ease;white-space:nowrap;line-height:1.4;
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--c-brand);color:#fff;border-color:var(--c-brand)}
.btn-primary:hover{background:var(--c-brand-hover);border-color:var(--c-brand-hover)}
.btn-secondary{background:#fff;color:var(--c-text);border-color:var(--c-border-strong)}
.btn-secondary:hover{background:var(--c-surface-inset)}
.btn-ghost{background:transparent;color:var(--c-text-muted);border-color:var(--c-border)}
.btn-ghost:hover{background:var(--c-surface-inset);color:var(--c-text)}
.btn-danger{background:var(--c-danger);color:#fff;border-color:var(--c-danger)}
.btn-danger:hover{background:#dc2626}
.btn-small{padding:5px 10px;font-size:12px;border-radius:var(--r-sm)}
.btn-block{width:100%;justify-content:center}
.btn-pulse{animation:btnPulse 1.6s ease-in-out infinite}
@keyframes btnPulse{
  0%{box-shadow:0 0 0 0 rgba(37,99,235,0.32)}
  70%{box-shadow:0 0 0 10px rgba(37,99,235,0)}
  100%{box-shadow:0 0 0 0 rgba(37,99,235,0)}
}

/* ── Status ───────────────────────────────────────────────── */
.status-pill{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:0.02em;
}
.status-pill::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0}
.status-healthy{background:var(--c-success-bg);color:var(--c-success)}
.status-healthy::before{background:var(--c-success)}
.status-warning{background:var(--c-warning-bg);color:#b45309}
.status-warning::before{background:var(--c-warning)}
.status-critical{background:var(--c-danger-bg);color:var(--c-danger)}
.status-critical::before{background:var(--c-danger)}

/* ── Admin Row Form ────────────────────────────────────────── */
.admin-row-form .admin-row-fields{
  display:grid;grid-template-columns:1fr 1fr 100px 1fr auto;
  gap:10px;align-items:end;
}
.admin-row-form .admin-row-fields label{
  font-size:10px;font-weight:600;color:var(--c-text-muted);
  text-transform:uppercase;letter-spacing:0.04em;margin-bottom:4px;display:block;
}
.admin-row-form .admin-row-fields input,
.admin-row-form .admin-row-fields select{
  width:100%;border:1px solid var(--c-border);background:#fff;
  border-radius:var(--r-xs);padding:6px 8px;font-size:12px;
  font-family:var(--font);color:var(--c-text);outline:none;
  transition:border-color 120ms ease;
}
.admin-row-form .admin-row-fields input:focus{
  border-color:var(--c-brand);box-shadow:0 0 0 2px rgba(37,99,235,0.06);
}
@media(max-width:768px){
  .admin-row-form .admin-row-fields{grid-template-columns:1fr;}
  .admin-checklist{grid-template-columns:1fr}
}

/* ── Inline Forms in Tables ────────────────────────────────── */
.inline-form,.inline-password-form{display:inline-flex;gap:6px;flex-wrap:wrap;margin:0;align-items:center}
.admin-inline-stack{
  display:flex;flex-direction:column;gap:10px;
  padding:8px 0;
}
/* Higher specificity to override form-grid styles */
.panel-card .admin-inline-stack .inline-form{
  display:flex;flex-wrap:wrap;gap:6px;align-items:center;
  padding:8px 10px;
  background:var(--c-surface-inset);
  border-radius:var(--r-sm);
  border:1px solid var(--c-border-light);
}
.panel-card .admin-inline-stack .inline-form input,
.panel-card .admin-inline-stack .inline-form textarea{
  border:1px solid var(--c-border);
  background:#fff;
  border-radius:var(--r-xs);
  padding:5px 8px;
  font-size:12px;
  font-family:var(--font);
  color:var(--c-text);
  outline:none;
  transition:border-color 120ms ease;
  min-width:0;
  width:120px;
  box-shadow:none;
}
.panel-card .admin-inline-stack .inline-form input:focus,
.panel-card .admin-inline-stack .inline-form textarea:focus{
  border-color:var(--c-brand);
  box-shadow:0 0 0 2px rgba(37,99,235,0.06);
}
.panel-card .admin-inline-stack .inline-form input::placeholder,
.panel-card .admin-inline-stack .inline-form textarea::placeholder{color:var(--c-text-placeholder)}
.panel-card .admin-inline-stack .inline-form textarea{min-height:40px;resize:vertical;font-size:11px;width:140px}
.panel-card .admin-inline-stack .inline-form input[type="hidden"]{display:none}
.panel-card .admin-inline-stack .inline-form input[type="password"]{width:140px}

/* ── Menu Visibility Grid ─────────────────────────────────── */
.menu-visibility-grid{
  display:flex;flex-wrap:wrap;gap:4px 8px;
  padding:8px 10px;
  border:1px solid var(--c-border-light);
  border-radius:var(--r-sm);
  background:var(--c-surface-inset);
}
.menu-check{
  display:inline-flex;align-items:center;gap:5px;
  font-size:12px;font-weight:500;color:var(--c-text-secondary);
  cursor:pointer;padding:3px 0;
}
.menu-check input[type="checkbox"]{
  width:15px;height:15px;margin:0;
  accent-color:var(--c-brand);
  cursor:pointer;
}
.stack-top{margin-top:12px}
.table-scroll-3{max-height:246px;overflow-y:auto;padding-right:4px}
.table-scroll-5{max-height:220px;overflow-y:auto}
.table-scroll-8{max-height:360px;overflow-y:auto;padding-right:4px}
.table-scroll-7{max-height:320px;overflow-y:auto}
.table-scroll-10{max-height:420px;overflow-y:auto}
.tone-soft{background:var(--c-surface-inset)}
.text-area{line-height:1.65}

/* ── Upload / Paste Zone ─────────────────────────────────── */
.upload-input-hidden{
  display:none !important;
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  clip-path:inset(50%) !important;
  white-space:nowrap !important;
  border:0 !important;
  opacity:0 !important;
  pointer-events:none !important;
}
.upload-picker-row{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 16px;
  border:1px solid var(--c-border);
  border-radius:var(--r-md);
  background:var(--c-surface);
}
.upload-trigger-btn{
  min-width:136px;
  justify-content:center;
  cursor:pointer;
  flex-shrink:0;
}
.upload-picker-meta{
  display:grid;
  gap:2px;
  min-width:0;
}
.upload-picker-meta strong{
  color:var(--c-text);
  font-size:13px;
  font-weight:600;
}
.upload-picker-meta span{
  color:var(--c-text-muted);
  font-size:12px;
}
.paste-zone{
  border:2px dashed var(--c-border-strong);
  background:linear-gradient(180deg, #fbfcff 0%, var(--c-surface-inset) 100%);
  border-radius:var(--r-lg);
  padding:30px 28px;
  display:grid;
  gap:6px;
  text-align:center;
  transition:all 150ms ease;
  cursor:pointer;
  outline:none;
}
.paste-zone strong{color:var(--c-text);font-size:14px;line-height:1.5}
.paste-zone span{color:var(--c-text-muted);font-size:12px;line-height:1.6}
.paste-zone:focus{
  border-color:var(--c-brand);
  background:var(--c-brand-bg);
  box-shadow:0 0 0 3px rgba(37,99,235,0.08);
}
.paste-zone-active,
.paste-zone:hover{
  border-color:var(--c-brand);
  background:var(--c-brand-bg);
}
.paste-zone-has-files{
  border-style:solid;
}
.upload-summary{
  color:var(--c-text-muted);
  font-size:12px;
  font-weight:500;
  min-height:18px;
}

/* ── Submission Result ────────────────────────────────────── */
.submission-result{margin-top:12px;padding:12px 14px;border-radius:var(--r-md);display:grid;gap:3px;font-size:13px;border:1px solid}
.submission-result strong{font-size:13px}
.submission-result span{font-size:12px;color:var(--c-text-secondary)}
.submission-result.status-healthy{background:var(--c-success-bg);border-color:rgba(16,185,129,0.15)}
.submission-result.status-warning{background:var(--c-warning-bg);border-color:rgba(245,158,11,0.15)}
.submission-result.status-critical{background:var(--c-danger-bg);border-color:rgba(239,68,68,0.15)}

/* ── Quick Actions ────────────────────────────────────────── */
.quick-action-list{display:grid;gap:6px}
.quick-action-item{
  display:flex;align-items:center;gap:12px;padding:12px 14px;
  border:1px solid var(--c-border);border-radius:var(--r-md);background:#fff;
  transition:all 150ms ease;
}
.quick-action-item:hover{border-color:var(--c-brand);background:var(--c-brand-bg);box-shadow:var(--shadow-sm)}
.quick-action-item strong{font-size:13px;font-weight:600;color:var(--c-text)}
.quick-action-item span{font-size:12px;color:var(--c-text-muted)}

/* ── Binding Cards ───────────────────────────────────────── */
.binding-list{display:grid;gap:10px}
.binding-card{
  border:1px solid var(--c-border);border-radius:var(--r-md);
  background:#fff;padding:14px 16px;display:grid;gap:8px;
}
.binding-meta{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.binding-meta strong{display:block;font-size:14px}
.binding-meta span{font-size:12px;color:var(--c-text-muted)}
.binding-submeta{display:flex;gap:14px;flex-wrap:wrap;color:var(--c-text-muted);font-size:12px}
.binding-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ── QR Box ───────────────────────────────────────────────── */
.qr-box{
  min-height:180px;border:2px dashed var(--c-border-strong);border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;text-align:center;
  padding:24px;background:var(--c-surface-inset);color:var(--c-text);font-weight:600;font-size:14px;
}

/* ── Console Banner ───────────────────────────────────────── */
.console-banner{padding:20px;border-radius:var(--r-lg);background:var(--c-brand);color:#fff}
.console-banner p{color:rgba(255,255,255,0.7);font-size:13px}

/* ── Admin Model ──────────────────────────────────────────── */
.admin-model-form{
  padding:18px 0;border-bottom:1px solid var(--c-border-light);
}
.admin-model-form:last-child{border-bottom:none}
.admin-model-head{
  margin-bottom:14px;display:flex;
  justify-content:space-between;gap:12px;align-items:flex-start;
}
.admin-model-head strong{font-size:14px}
.admin-model-head span{font-size:12px;color:var(--c-text-muted)}
.admin-model-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.admin-model-notes{grid-column:1/-1}
/* Model card grid — responsive cards */
.model-card-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:16px;
}
.model-health-intro{display:grid;gap:14px}
.model-health-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;
}
.model-health-grid div{
  display:flex;flex-direction:column;gap:8px;padding:12px 14px;
  border:1px solid var(--c-border-light);border-radius:var(--r-md);
  background:var(--c-surface-inset);
}
.model-health-grid strong{
  font-size:13px;font-weight:600;color:var(--c-text);line-height:1.5;
}
.model-card-head{
  display:flex;justify-content:space-between;gap:10px;align-items:flex-start;
  margin-bottom:14px;
}
.model-card-head strong{font-size:14px;display:block}
.model-card-head span{font-size:12px;color:var(--c-text-muted);display:block;margin-top:2px}
.model-card-badges{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.model-card-fields{
  display:grid;grid-template-columns:repeat(2,1fr);gap:10px;
}
.model-card-fields label{
  font-size:11px;font-weight:600;color:var(--c-text-muted);
  text-transform:uppercase;letter-spacing:0.04em;margin-bottom:4px;display:block;
}
.model-card-fields input{
  width:100%;border:1px solid var(--c-border);background:#fff;
  border-radius:var(--r-sm);padding:8px 10px;font-size:13px;
  font-family:var(--font);color:var(--c-text);outline:none;
  transition:border-color 120ms ease,box-shadow 120ms ease;
}
.model-card-fields input:focus{
  border-color:var(--c-brand);box-shadow:0 0 0 3px rgba(37,99,235,0.08);
}
.model-card-notes{grid-column:1/-1}
.model-health-note{
  margin-top:12px;padding:12px 14px;border-radius:var(--r-md);
  background:var(--c-surface-inset);border:1px solid var(--c-border-light);
}
.model-health-note label{
  display:block;margin-bottom:6px;font-size:11px;font-weight:700;
  color:var(--c-text-muted);letter-spacing:0.04em;text-transform:uppercase;
}
.model-health-note p{
  margin:0;font-size:13px;line-height:1.6;color:var(--c-text-secondary);
  word-break:break-word;
}
.model-card-footer{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:14px;padding-top:12px;border-top:1px solid var(--c-border-light);
}
/* Model form grid — 3 columns, clean labels */
.panel-card .admin-model-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
}
.panel-card .admin-model-grid label{
  font-size:11px;font-weight:600;color:var(--c-text-muted);
  text-transform:uppercase;letter-spacing:0.04em;margin-bottom:4px;display:block;
}
.panel-card .admin-model-grid input{
  width:100%;border:1px solid var(--c-border);background:#fff;
  border-radius:var(--r-sm);padding:8px 10px;font-size:13px;
  font-family:var(--font);color:var(--c-text);outline:none;
  transition:border-color 120ms ease,box-shadow 120ms ease;
}
.panel-card .admin-model-grid input:focus{
  border-color:var(--c-brand);box-shadow:0 0 0 3px rgba(37,99,235,0.08);
}
.panel-card .admin-model-grid .admin-model-notes{grid-column:1/-1}

/* ═══════════════════════════════════════════════════════════════
   Public Pages — Login / Register / Index
   ═══════════════════════════════════════════════════════════════ */

.public-page{
  max-width:100%;margin:0;padding:0;
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:#0a0e1a;
  background-image:
    radial-gradient(ellipse at 15% 50%, rgba(37,99,235,0.08) 0%, transparent 55%),
    radial-gradient(ellipse at 85% 15%, rgba(124,58,237,0.06) 0%, transparent 45%),
    radial-gradient(ellipse at 50% 90%, rgba(37,99,235,0.05) 0%, transparent 40%);
}
.public-page:has(.landing-shell){align-items:flex-start;padding-top:0}

/* ── Auth Layout — single unified card ────────────────────── */
.auth-layout{
  display:grid;grid-template-columns:1fr 0.85fr;
  width:100%;max-width:920px;
  border-radius:var(--r-2xl);overflow:hidden;
  box-shadow:0 24px 80px rgba(0,0,0,0.4);
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.06);
  margin:24px;
  backdrop-filter:blur(12px);
}
.auth-panel{padding:44px 40px;display:flex;flex-direction:column;justify-content:center;background:rgba(15,20,35,0.85)}
.auth-panel h1{font-size:24px;font-weight:700;letter-spacing:-0.025em;margin:0 0 4px;color:#fff}
.auth-panel .eyebrow{margin-bottom:2px;color:rgba(255,255,255,0.45)}
.auth-panel .muted{color:rgba(255,255,255,0.45)}
.auth-panel .form-grid{margin-top:20px;gap:10px}
.auth-panel .form-grid label{font-size:13px;font-weight:500;color:rgba(255,255,255,0.55)}
.auth-panel .form-grid input{
  padding:11px 14px;font-size:14px;border-radius:var(--r-md);
  border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.06);color:#fff;
}
.auth-panel .form-grid input:focus{border-color:var(--c-brand);box-shadow:0 0 0 3px rgba(37,99,235,0.15);background:rgba(255,255,255,0.08)}
.auth-panel .form-grid input::placeholder{color:rgba(255,255,255,0.25)}
.auth-panel .btn[type="submit"]{
  margin-top:10px;width:100%;padding:12px;font-size:15px;
  border-radius:var(--r-md);font-weight:600;
}
.auth-panel .hero-link-row{margin-top:16px}
.auth-panel .hero-link-row .btn{padding:9px 16px;font-size:13px}

.side-story{
  background:linear-gradient(160deg, #1e293b 0%, #0f172a 100%);
  color:#fff;padding:44px 36px;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}
.side-story::before{
  content:'';position:absolute;top:-40%;right:-20%;width:300px;height:300px;
  background:radial-gradient(circle, rgba(37,99,235,0.15) 0%, transparent 70%);
  border-radius:50%;
}
.side-story .eyebrow{color:rgba(255,255,255,0.4)}
.side-story h1{color:#fff;position:relative}
.side-story .lede{color:rgba(255,255,255,0.5);margin:0 0 8px;position:relative;font-size:14px}

.story-metrics{margin-top:20px;gap:10px;position:relative}
.story-metrics div{
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--r-md);padding:14px 16px;
  display:flex;flex-direction:column;gap:3px;
}
.story-metrics span{font-size:11px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:rgba(255,255,255,0.4)}
.story-metrics strong{font-size:15px;font-weight:600;color:#fff}

/* ── Hero / Landing (Index) ──────────────────────────────── */
.hero-copy h1{
  font-size:clamp(30px,4.5vw,46px);letter-spacing:-0.04em;line-height:1.12;
  font-weight:800;color:var(--c-text);margin:0 0 16px;
}
.lede{color:var(--c-text-secondary);line-height:1.7;font-size:15px;max-width:440px}
.hero-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:18px}
.hero-badge{
  padding:6px 14px;border-radius:999px;background:var(--c-brand-light);
  color:var(--c-brand);font-size:12px;font-weight:600;
  border:1px solid rgba(37,99,235,0.12);letter-spacing:0.01em;
}
.hero-actions{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap;align-items:center}
.btn-hero{padding:12px 28px;font-size:15px;border-radius:var(--r-md);font-weight:700;letter-spacing:-0.01em;box-shadow:0 2px 8px rgba(37,99,235,0.25)}
.btn-hero:hover{box-shadow:0 4px 16px rgba(37,99,235,0.35)}
.hero-link-row{display:flex;gap:8px;flex-wrap:wrap}
.metric-card{
  padding:18px 20px;border-radius:var(--r-lg);
  background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--shadow-sm);
}
.metric-card.emphasis{background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);border-color:transparent;color:#fff;box-shadow:0 4px 16px rgba(37,99,235,0.2)}
.metric-card.emphasis .metric-label{color:rgba(255,255,255,0.65)}
.metric-card.emphasis .metric-value{color:#fff}
.metric-label{font-size:11px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:var(--c-text-muted);margin-bottom:6px}
.metric-value{font-size:14px;font-weight:600;color:var(--c-text);line-height:1.5}

.landing-shell{
  width:100%;
  max-width:1180px;
  margin:0 auto;
  display:grid;
  gap:22px;
  padding:40px 24px 60px;
}
.landing-hero{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0, 1.08fr) minmax(340px, 0.92fr);
  gap:28px;
  align-items:stretch;
}
.landing-copy,
.landing-showcase{
  position:relative;
}
.landing-copy{
  padding:44px 10px 22px 0;
}
.landing-copy h1{
  margin:0 0 18px;
  font-size:clamp(34px, 5.2vw, 58px);
  line-height:1.05;
  letter-spacing:-0.05em;
  font-weight:850;
  color:var(--c-text);
}
.landing-copy .lede{
  max-width:620px;
  font-size:16px;
  line-height:1.85;
}
.landing-actions{margin-top:28px}
.landing-badges{margin-top:18px}
.landing-proof-row{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-top:28px;
}
.landing-proof-card{
  padding:16px 18px;
  border:1px solid var(--c-border);
  border-radius:var(--r-lg);
  background:rgba(255,255,255,0.78);
  backdrop-filter:blur(8px);
  box-shadow:var(--shadow-sm);
}
.landing-proof-card span{
  display:block;
  font-size:11px;
  font-weight:700;
  letter-spacing:0.05em;
  text-transform:uppercase;
  color:var(--c-text-muted);
  margin-bottom:6px;
}
.landing-proof-card strong{
  font-size:14px;
  line-height:1.65;
  color:var(--c-text);
}
.landing-showcase{
  min-height:540px;
  padding:22px;
  border-radius:28px;
  overflow:hidden;
  background:linear-gradient(160deg, #0f172a 0%, #111827 42%, #1d4ed8 140%);
  box-shadow:0 26px 80px rgba(15,23,42,0.18);
  display:grid;
  align-content:start;
  gap:14px;
}
.showcase-glow{
  position:absolute;
  inset:auto -20% -18% auto;
  width:320px;
  height:320px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(96,165,250,0.34) 0%, rgba(96,165,250,0.08) 38%, transparent 72%);
  pointer-events:none;
}
.showcase-card{
  position:relative;
  z-index:1;
  padding:20px 20px 18px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.06);
  backdrop-filter:blur(10px);
  color:#fff;
}
.showcase-card-primary{
  padding:24px 24px 22px;
  background:linear-gradient(180deg, rgba(255,255,255,0.16) 0%, rgba(255,255,255,0.09) 100%);
}
.showcase-card-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}
.showcase-label{
  font-size:11px;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.62);
  margin-bottom:8px;
}
.showcase-title{
  font-size:28px;
  line-height:1.18;
  letter-spacing:-0.04em;
  font-weight:800;
  max-width:360px;
}
.showcase-flow{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:18px;
}
.showcase-flow span{
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.08);
  font-size:12px;
  font-weight:600;
}
.showcase-stats{
  display:grid;
  gap:12px;
  margin-top:20px;
}
.showcase-stats div{
  padding:14px 16px;
  border-radius:16px;
  background:rgba(10,18,34,0.28);
  border:1px solid rgba(255,255,255,0.06);
}
.showcase-stats span,
.showcase-card p{
  color:rgba(255,255,255,0.64);
  font-size:12px;
  line-height:1.7;
}
.showcase-stats strong{
  display:block;
  margin-top:6px;
  color:#fff;
  font-size:15px;
  line-height:1.6;
}
.showcase-kpi{
  font-size:24px;
  line-height:1.15;
  letter-spacing:-0.03em;
  font-weight:800;
  margin-bottom:8px;
}
.landing-feature-grid,
.landing-bottom-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
}
.landing-feature-card,
.landing-info-card{
  padding:26px 28px;
  border-radius:24px;
  background:var(--c-surface);
  border:1px solid var(--c-border);
  box-shadow:var(--shadow-md);
}
.feature-card-dark{
  background:linear-gradient(155deg, #111827 0%, #0f172a 58%, #172554 130%);
  border-color:rgba(255,255,255,0.08);
  color:#fff;
}
.feature-card-dark .metric-label,
.feature-card-dark .signal-list,
.feature-card-dark h2,
.feature-card-dark li{
  color:#fff;
}
.feature-card-dark .metric-label{color:rgba(255,255,255,0.58)}
.feature-card-dark h2{
  margin:0 0 14px;
  font-size:28px;
  line-height:1.2;
  letter-spacing:-0.035em;
}
.landing-signal-list{font-size:14px;line-height:1.9}
.landing-step-list{display:grid;gap:16px;margin-top:8px}
.landing-step-item{
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:14px 0;
  border-bottom:1px solid var(--c-border-light);
}
.landing-step-item:last-child{border-bottom:none;padding-bottom:0}
.landing-step-num{
  width:42px;
  height:42px;
  border-radius:14px;
  background:linear-gradient(180deg, var(--c-brand-light) 0%, #dbeafe 100%);
  color:var(--c-brand);
  display:grid;
  place-items:center;
  font-size:12px;
  font-weight:800;
  letter-spacing:0.05em;
  flex-shrink:0;
}
.landing-step-item strong{
  display:block;
  margin-bottom:6px;
  color:var(--c-text);
  font-size:16px;
  font-weight:700;
}
.landing-step-item span{
  color:var(--c-text-muted);
  font-size:13px;
  line-height:1.8;
}
.landing-mini-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-top:8px;
}
.landing-mini-grid div{
  padding:16px 18px;
  border-radius:18px;
  background:var(--c-surface-inset);
  border:1px solid var(--c-border-light);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.landing-mini-grid span{
  font-size:11px;
  color:var(--c-text-muted);
  font-weight:700;
  letter-spacing:0.04em;
  text-transform:uppercase;
}
.landing-mini-grid strong{
  font-size:14px;
  color:var(--c-text);
  line-height:1.7;
}
.landing-info-card-accent{
  background:linear-gradient(180deg, #f8fbff 0%, #eef4ff 100%);
}
.landing-link-list{
  display:grid;
  gap:10px;
  margin-top:8px;
}
.landing-link-list a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:15px 18px;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(37,99,235,0.1);
  color:var(--c-text);
  font-size:14px;
  font-weight:600;
  box-shadow:var(--shadow-sm);
  transition:all 150ms ease;
}
.landing-link-list a:hover{
  transform:translateY(-1px);
  border-color:rgba(37,99,235,0.2);
  box-shadow:var(--shadow-md);
}
.landing-link-list a::after{
  content:'→';
  color:var(--c-brand);
  font-size:15px;
}

/* ── Message Panel ────────────────────────────────────────── */
.message-panel{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-xl);padding:32px;max-width:480px;
  box-shadow:var(--shadow-lg);text-align:center;margin:0 auto;
}
.message-panel h1{font-size:20px}
.message-panel .btn{margin-top:16px}

/* ── Lists ────────────────────────────────────────────────── */
.signal-list{margin:0;padding-left:18px;line-height:1.8;color:var(--c-text);font-size:13px}
.signal-list li{padding:2px 0}
.check-row{display:flex;align-items:center;gap:8px}
.check-row input{width:auto}

/* ── Steps ────────────────────────────────────────────────── */
.step-list{display:grid;gap:0}
.step-item{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--c-border-light)}
.step-item:last-child{border-bottom:none}
.step-index{
  width:32px;height:32px;border-radius:50%;
  background:var(--c-brand-light);color:var(--c-brand);
  display:grid;place-items:center;font-weight:700;font-size:14px;flex-shrink:0;
}
.step-item strong{display:block;margin-bottom:2px;font-size:14px}
.step-item span{color:var(--c-text-muted);font-size:13px}

/* ── Info Row ─────────────────────────────────────────────── */
.info-row{display:grid;grid-template-columns:1fr 1fr;gap:0}
.info-cell{
  padding:9px 12px;border-bottom:1px solid var(--c-border-light);
  display:flex;flex-direction:column;gap:1px;
}
.info-cell:nth-child(odd){border-right:1px solid var(--c-border-light)}
.info-cell:nth-last-child(-n+2){border-bottom:none}
.info-cell .info-label{font-size:10px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--c-text-muted)}
.info-cell .info-value{font-size:13px;font-weight:600;color:var(--c-text);word-break:break-all;line-height:1.4}
.info-cell .info-value a{color:var(--c-brand);text-decoration:underline;text-decoration-color:rgba(37,99,235,0.3)}

/* ── Status Hero ──────────────────────────────────────────── */
.status-hero{
  display:flex;align-items:center;gap:16px;padding:20px;
  border-radius:var(--r-lg);border:1px solid var(--c-border);
  background:var(--c-surface);box-shadow:var(--shadow-sm);
}
.status-hero-dot{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;flex-shrink:0}
.status-hero-dot.ok{background:var(--c-success-bg);color:var(--c-success)}
.status-hero-dot.warn{background:var(--c-warning-bg);color:var(--c-warning)}
.status-hero-dot.err{background:var(--c-danger-bg);color:var(--c-danger)}
.status-hero-dot::after{content:'';width:14px;height:14px;border-radius:50%}
.status-hero-dot.ok::after{background:var(--c-success)}
.status-hero-dot.warn::after{background:var(--c-warning)}
.status-hero-dot.err::after{background:var(--c-danger)}
.status-hero-text h3{margin:0;font-size:18px;font-weight:700;color:var(--c-text)}
.status-hero-text p{margin:2px 0 0;font-size:12px;color:var(--c-text-muted)}

/* ── Action Bar ───────────────────────────────────────────── */
.action-bar{display:flex;gap:8px;flex-wrap:wrap;padding:16px 0 0;border-top:1px solid var(--c-border-light);margin-top:12px}
.action-bar-compact{border-top:none;padding-top:0;margin-top:0}
.section-gap{margin-top:4px}

/* ── Responsive ───────────────────────────────────────────── */
@media(max-width:768px){
  .layout-shell{grid-template-columns:1fr}
  .sidebar-toggle-btn{display:inline-flex}
  .sidebar{
    position:fixed;left:0;top:0;bottom:0;width:min(82vw,300px);max-width:300px;
    height:100vh;border-right:1px solid var(--c-border);border-bottom:none;
    box-shadow:var(--shadow-xl);transform:translateX(-104%);transition:transform 180ms ease;
    z-index:30;
  }
  .nav-drawer-toggle:checked ~ .layout-shell .sidebar{transform:translateX(0)}
  .nav-drawer-toggle:checked ~ .layout-shell .sidebar-backdrop{opacity:1;pointer-events:auto}
  .sidebar-brand{justify-content:space-between;padding:18px 16px 14px}
  .sidebar-title,.sidebar-subtitle{display:block}
  .sidebar-nav{
    flex-direction:column;flex-wrap:nowrap;
    padding:12px;gap:6px;
  }
  .sidebar-nav a{
    justify-content:flex-start;font-size:14px;height:auto;
    padding:11px 14px;
  }
  .sidebar-nav a.active::before{display:block}
  .layout-main{min-width:0}
  .workspace-header{
    height:auto;min-height:60px;padding:12px 16px;gap:12px;
    flex-direction:column;align-items:stretch;
  }
  .workspace-title{font-size:15px}
  .workspace-actions{
    width:100%;justify-content:flex-start;flex-wrap:wrap;gap:8px;
  }
  .header-link{
    min-height:40px;padding:9px 12px;border:1px solid var(--c-border);
    background:var(--c-surface-inset);
  }
  .workspace-content{padding:16px 16px 28px;gap:14px}
  .page-head,.workspace-header{align-items:flex-start}
  .page-head h1{font-size:18px}
  .page-head-hero h1{font-size:20px}
  .hero-copy h1{font-size:26px}
  .landing-copy h1{font-size:32px}
  .stat-value{font-size:20px}
  .stat-grid,.card-grid,.section-split,.submit-layout,.admin-detail-grid,.billing-grid,
  .summary-grid,.micro-grid,.story-metrics,.quick-grid,.audit-filter-grid,.admin-model-grid,
  .auth-layout,.two-column-form,.info-row,.filter-grid,.model-card-grid,.model-card-fields,
  .landing-hero,.landing-feature-grid,.landing-bottom-grid,.landing-mini-grid,.landing-proof-row,.showcase-card-grid{
    grid-template-columns:1fr;
  }
  .card-grid-wide,.submit-layout-featured{grid-template-columns:1fr}
  .landing-shell{gap:16px}
  .landing-copy{padding:12px 0 0}
  .landing-showcase{min-height:auto;padding:18px}
  .showcase-title{font-size:24px}
  .landing-feature-card,.landing-info-card{padding:22px 20px}
  .head-actions,.action-bar,.binding-actions,.row-actions{width:100%}
  .head-actions > *,.action-bar > *,.binding-actions > *,.row-actions > *{
    flex:1 1 calc(50% - 8px);
  }
  .head-actions .btn,.action-bar .btn,.binding-actions .btn,.row-actions .btn{width:100%}
  .btn-block{flex-basis:100%}
  .filter-actions{width:100%}
  .filter-actions .btn{width:100%}
  .btn{
    min-height:44px;padding:10px 16px;font-size:14px;
  }
  .btn-small{
    min-height:40px;padding:8px 12px;font-size:13px;
  }
  .form-grid input,.form-grid select,.form-grid textarea,
  .filter-grid input,.filter-grid select,
  .panel-card .admin-inline-stack .inline-form input,
  .panel-card .admin-inline-stack .inline-form textarea,
  .model-card-fields input{
    font-size:16px;
  }
  .summary-grid div,.info-cell{border-right:none !important}
  .summary-grid div:last-child,.info-row .info-cell:last-child{border-bottom:none}
  .table-list{gap:10px}
  .table-row{
    gap:10px;padding:14px;border:1px solid var(--c-border);
    border-radius:var(--r-md);background:#fff;
  }
  .table-row:last-child{border-bottom:1px solid var(--c-border)}
  .table-card-list .table-header-grid{display:none}
  .table-card-list .table-row{
    display:grid !important;grid-template-columns:1fr !important;align-items:flex-start;
  }
  .table-card-list .table-row > div,
  .table-card-list .table-row > form{
    display:flex;flex-direction:column;align-items:flex-start;gap:4px;min-width:0;
  }
  .table-card-list .table-row > div[data-label]::before,
  .table-card-list .table-row > form[data-label]::before{
    content:attr(data-label);
    color:var(--c-text-muted);font-size:10px;font-weight:700;
    letter-spacing:0.05em;text-transform:uppercase;
  }
  .table-card-list .table-row .status-pill{align-self:flex-start}
  .table-card-list .table-row .inline-form,
  .table-card-list .table-row .row-actions,
  .table-card-list .table-row .admin-inline-stack{
    width:100%;
  }
  .table-card-list .table-row .inline-form{
    display:flex;flex-wrap:wrap;gap:8px;
  }
  .table-card-list .table-row .inline-form input,
  .table-card-list .table-row .inline-form textarea,
  .table-card-list .table-row .inline-form select{
    flex:1 1 100%;width:100%;
  }
  .table-card-list .table-row .inline-form .btn,
  .table-card-list .table-row .row-actions > *,
  .table-card-list .table-row .admin-inline-stack > *{
    flex:1 1 100%;
  }
  .table-card-list .table-row .row-actions .btn,
  .table-card-list .table-row .admin-inline-stack .btn{
    width:100%;
  }
  .panel-card .admin-inline-stack .inline-form{
    padding:10px 12px;
  }
  .binding-meta{flex-direction:column}
  .binding-submeta{flex-direction:column;gap:6px}
  .quick-action-item{align-items:flex-start}
  .upload-picker-row{
    flex-direction:column;
    align-items:flex-start;
  }
  .upload-picker-row .btn,
  .upload-trigger-btn{
    width:100%;
    min-width:0;
  }
  .paste-zone{padding:20px 16px}
  .status-hero{align-items:flex-start}
  .model-card-grid{grid-template-columns:1fr}
  .model-health-grid{grid-template-columns:1fr}
  .model-card-footer{
    flex-direction:column;align-items:flex-start;gap:10px;
  }
  .auth-layout{border-radius:var(--r-lg);margin:12px}
  .auth-panel{padding:28px 24px}
  .side-story{padding:28px 24px}
}
