/* Method8 App UI kit — chrome specifics layered on colors_and_type.css */
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:var(--m8-font);font-feature-settings:var(--m8-feature-settings);background:var(--m8-bg-secondary);color:var(--m8-text-primary)}
#root{height:100%}
button{font-family:inherit}

/* ---- Shell ---- */
.app-shell{display:flex;min-height:100vh}
.app-main{flex:1;min-width:0;display:flex;flex-direction:column}

/* ---- Sidebar ---- */
.sb{width:250px;flex:0 0 250px;background:#fff;border-right:1px solid var(--m8-border-secondary);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sb.collapsed{width:80px;flex-basis:80px}
.sb-logo{height:64px;display:flex;align-items:center;gap:12px;padding:0 24px;border-bottom:1px solid var(--m8-border-secondary)}
.sb.collapsed .sb-logo{justify-content:center;padding:0}
.sb-logo .wm{font-size:18px;font-weight:600;color:var(--m8-gray-700);letter-spacing:-.01em}
.sb-scroll{flex:1;overflow-y:auto;padding:16px 0}
.sb-section{padding:0 28px;font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--m8-gray-600);margin-bottom:8px;text-transform:uppercase}
.sb.collapsed .sb-section{text-align:center;padding:0 8px}
.sb-divider{margin-top:28px}
.sb-menu{display:flex;flex-direction:column;gap:4px;padding:0 16px}
.sb.collapsed .sb-menu{padding:0 8px;align-items:center}
.sb-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:8px;font-size:14px;font-weight:500;color:var(--m8-nav-fg);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}
.sb-item .ic{display:flex;color:var(--m8-nav-icon-fg);flex:0 0 auto}
.sb.collapsed .sb-item{justify-content:center;width:48px;height:48px;padding:0}
.sb-item:hover{background:var(--m8-blue-100);color:var(--m8-nav-fg-active)}
.sb-item:hover .ic{color:var(--m8-nav-fg-active)}
.sb-item.active{background:var(--m8-nav-bg-current);color:var(--m8-nav-fg-active)}
.sb-item.active .ic{color:var(--m8-nav-fg-active)}
.sb-item .lbl{flex:1}
.sb.collapsed .sb-item .lbl{display:none}
.sb-profile{margin:16px;padding:4px;border:1px solid var(--m8-border-secondary);border-radius:10px}
.sb-profile-row{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:8px;cursor:pointer}
.sb.collapsed .sb-profile-row{justify-content:center;padding:8px 0}
.avatar{flex:0 0 auto;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:600}
.sb-profile .nm{font-size:14px;font-weight:600;color:var(--m8-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-profile .em{font-size:12px;color:var(--m8-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb.collapsed .sb-profile .meta,.sb.collapsed .sb-profile .more{display:none}

/* ---- Topbar ---- */
.tb{height:64px;flex:0 0 64px;background:#fff;border-bottom:1px solid var(--m8-border-secondary);box-shadow:0 1px 3px rgba(16,24,40,.06);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:20}
.tb-left{display:flex;align-items:center;gap:12px}
.tb-toggle{width:32px;height:32px;border:none;background:none;border-radius:8px;display:grid;place-items:center;color:var(--m8-gray-400);cursor:pointer}
.tb-toggle:hover{background:var(--m8-gray-100)}
.tb-divider{width:1px;height:20px;background:var(--m8-border-secondary);margin:0 4px}
.crumb{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--m8-text-tertiary)}
.crumb .cur{color:var(--m8-text-primary);font-weight:600}
.tb-right{display:flex;align-items:center;gap:14px}
.icon-btn{width:36px;height:36px;border:1px solid var(--m8-border-secondary);background:#fff;border-radius:8px;display:grid;place-items:center;color:var(--m8-gray-500);cursor:pointer}
.icon-btn:hover{background:var(--m8-gray-50)}

/* ---- Buttons (antd-ish) ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:500;border-radius:8px;padding:9px 16px;cursor:pointer;border:1px solid transparent;transition:background .15s,box-shadow .15s}
.btn-primary{background:var(--m8-btn-primary-bg);color:#fff}
.btn-primary:hover{background:var(--m8-btn-primary-bg-hover)}
.btn-secondary{background:#fff;color:var(--m8-btn-secondary-fg);border-color:var(--m8-btn-secondary-border);box-shadow:var(--m8-shadow-xs)}
.btn-secondary:hover{background:var(--m8-gray-50)}
.btn-ghost{background:transparent;color:var(--m8-text-tertiary)}
.btn-ghost:hover{background:var(--m8-gray-100)}

/* ---- Content ---- */
.content{padding:28px 24px 40px;flex:1}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px}
.page-title{font-size:24px;font-weight:600;letter-spacing:-.02em;margin:0}
.page-sub{font-size:14px;color:var(--m8-text-tertiary);margin:4px 0 0}

/* ---- KPI ---- */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.kpi{background:#fff;border:1px solid var(--m8-gray-200);border-radius:12px;padding:18px 20px;box-shadow:var(--m8-shadow-xs)}
.kpi-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.kpi-lab{font-size:13px;color:var(--m8-text-tertiary)}
.kpi-ic{width:36px;height:36px;border-radius:8px;display:grid;place-items:center}
.kpi-val{font-size:30px;font-weight:700;letter-spacing:-.02em}
.kpi-delta{font-size:12px;font-weight:500;margin-top:4px}

/* ---- Card ---- */
.card{background:#fff;border:1px solid var(--m8-gray-200);border-radius:12px;box-shadow:var(--m8-shadow-xs)}
.card-head{padding:18px 20px;border-bottom:1px solid var(--m8-gray-100);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:16px;font-weight:600;margin:0}
.card-sub{font-size:13px;color:var(--m8-text-tertiary);margin:2px 0 0}

/* ---- Table ---- */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:12px;font-weight:500;color:var(--m8-text-tertiary);padding:11px 20px;background:var(--m8-gray-50);border-bottom:1px solid var(--m8-gray-200);white-space:nowrap}
.tbl td{padding:14px 20px;border-bottom:1px solid var(--m8-gray-100);font-size:14px;color:var(--m8-text-secondary);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--m8-gray-25)}
.cell-name{font-weight:600;color:var(--m8-text-primary)}
.avatars{display:flex}
.avatars .avatar{width:28px;height:28px;font-size:11px;border:2px solid #fff;margin-left:-8px}
.avatars .avatar:first-child{margin-left:0}

/* ---- Status pill ---- */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;padding:3px 10px;border-radius:999px;border:1px solid}
.pill .dot{width:7px;height:7px;border-radius:50%}
.pill.success{background:var(--m8-success-50);color:var(--m8-success-700);border-color:var(--m8-success-200)}
.pill.blue{background:var(--m8-blue-50);color:var(--m8-blue-700);border-color:var(--m8-blue-200)}
.pill.warning{background:var(--m8-warning-50);color:var(--m8-warning-700);border-color:var(--m8-warning-200)}
.pill.error{background:var(--m8-error-50);color:var(--m8-error-700);border-color:var(--m8-error-200)}
.pill.gray{background:var(--m8-gray-50);color:var(--m8-gray-700);border-color:var(--m8-gray-200)}

/* ---- Progress ---- */
.prog{height:8px;border-radius:999px;background:var(--m8-gray-100);overflow:hidden;width:100%}
.prog>span{display:block;height:100%;border-radius:999px;background:var(--m8-blue-500)}

/* ---- Filters ---- */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--m8-gray-300);border-radius:8px;padding:8px 12px;min-width:260px;box-shadow:var(--m8-shadow-xs)}
.search input{border:none;outline:none;font:400 14px var(--m8-font);color:var(--m8-gray-900);width:100%;background:transparent}
.chip{font-size:13px;font-weight:500;padding:7px 12px;border-radius:8px;border:1px solid var(--m8-gray-300);background:#fff;color:var(--m8-text-secondary);cursor:pointer}
.chip.on{background:var(--m8-blue-50);border-color:var(--m8-blue-300);color:var(--m8-blue-700)}

/* ---- Tag ---- */
.tag{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:1px 8px;border-radius:4px;background:var(--m8-blue-50);color:var(--m8-blue-700)}

/* ---- Login ---- */
.login-wrap{min-height:100vh;display:grid;place-items:center;background:var(--m8-gray-50);padding:24px}
.login-card{width:100%;max-width:400px;background:#fff;border:1px solid var(--m8-gray-200);border-radius:16px;box-shadow:var(--m8-shadow-lg);padding:32px}
.login-card .logo{display:flex;justify-content:center;margin-bottom:24px}
.login-h{font-size:24px;font-weight:600;text-align:center;letter-spacing:-.02em;margin:0 0 4px}
.login-p{font-size:14px;color:var(--m8-text-tertiary);text-align:center;margin:0 0 24px}
.fld{margin-bottom:16px}
.fld label{display:block;font-size:14px;font-weight:500;color:var(--m8-gray-700);margin-bottom:6px}
.fld input{width:100%;min-height:44px;padding:10px 14px;border:1px solid var(--m8-gray-300);border-radius:8px;font:400 16px var(--m8-font);color:var(--m8-gray-900);box-shadow:var(--m8-shadow-xs)}
.fld input:focus{outline:none;border-color:var(--m8-brand-600);box-shadow:var(--m8-shadow-focus)}
.login-foot{text-align:center;font-size:12px;color:var(--m8-gray-400);margin-top:22px}

/* ---- Donut legend ---- */
.legend{display:flex;flex-direction:column;gap:10px}
.legend-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--m8-text-secondary)}
.legend-row .sw{width:10px;height:10px;border-radius:3px}
.legend-row b{margin-left:auto;color:var(--m8-text-primary)}

/* ---- modal ---- */
.overlay{position:fixed;inset:0;background:rgba(12,17,29,.5);display:grid;place-items:center;z-index:40;padding:24px}
.modal{width:100%;max-width:460px;background:#fff;border-radius:14px;box-shadow:var(--m8-shadow-2xl);overflow:hidden}
.modal-head{padding:20px 24px;border-bottom:1px solid var(--m8-gray-100);display:flex;justify-content:space-between;align-items:center}
.modal-body{padding:24px}
.modal-foot{padding:16px 24px;border-top:1px solid var(--m8-gray-100);display:flex;justify-content:flex-end;gap:10px}
