:root{--bg:#f6f5f2;--card:#fff;--text:#18181b;--muted:#71717a;--line:#e4e4e7;--accent:#f97316;--ok:#059669;--warn:#d97706;--err:#dc2626;--radius:20px}
*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto}
.hidden{display:none!important}.app-shell{display:flex;min-height:100vh}.app-main-wrap{flex:1;display:flex;flex-direction:column}.app-main{flex:1;padding:16px;padding-bottom:84px}
.topbar{position:sticky;top:0;background:rgba(246,245,242,.95);backdrop-filter:blur(8px);z-index:20;border-bottom:1px solid var(--line)}
.sidebar{display:none}.toast-container{position:fixed;right:16px;top:16px;z-index:100}.toast{background:#111;color:#fff;border-radius:12px;padding:10px 12px;margin-bottom:8px;font-size:13px}
.offline-banner{position:fixed;left:12px;right:12px;top:12px;z-index:120;background:#111;color:#fff;padding:10px 12px;border-radius:12px;font-size:13px}
.card{background:var(--card);border-radius:var(--radius);padding:14px;box-shadow:0 4px 14px rgba(0,0,0,.06)}
.kpi{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.kpi .value{font-weight:800;font-size:24px}.muted{color:var(--muted)}
.btn{border:none;border-radius:14px;padding:10px 14px;font-weight:700;cursor:pointer}.btn-primary{background:#111;color:#fff}.btn-ghost{background:#fff;border:1px solid var(--line)}
.badge{font-size:11px;padding:4px 8px;border-radius:999px;font-weight:700}.badge-ok{background:#dcfce7;color:#166534}.badge-warn{background:#ffedd5;color:#9a3412}.badge-err{background:#fee2e2;color:#991b1b}
.search{display:flex;gap:8px;background:#fff;border-radius:16px;padding:10px 12px;border:1px solid var(--line)}.search input{border:none;outline:none;background:transparent;flex:1}
.list{display:grid;gap:10px}.row{display:flex;justify-content:space-between;gap:8px;align-items:center}
