/* Webworked ERP — Design System */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  --sidebar:#0D1117; --sidebar-2:#161B22; --sidebar-line:#21262D;
  --bg:#F6F8FA; --teal:#00B8A2; --teal-d:#009E8B; --teal-soft:#E2F7F4;
  --card:#FFFFFF; --ink:#0D1117; --ink-2:#3D4754; --muted:#6B7682;
  --line:#E6EAEF; --line-2:#EFF2F5;
  --green:#38A169; --green-bg:#E4F4EA; --blue:#2F6FED; --blue-bg:#E7EFFE;
  --orange:#DD6B20; --orange-bg:#FBEBDD; --yellow:#C9A21A; --yellow-bg:#FBF3D5;
  --red:#E53E3E; --red-bg:#FCE6E6; --grey:#8A94A0; --grey-bg:#EEF1F4; --purple:#7A5AF8; --purple-bg:#ECE8FE;
  --shadow-sm:0 1px 2px rgba(13,17,23,.04),0 1px 3px rgba(13,17,23,.06);
  --shadow:0 1px 3px rgba(13,17,23,.06),0 8px 24px rgba(13,17,23,.07);
  --shadow-lg:0 16px 50px rgba(13,17,23,.18);
  --r:14px; --r-sm:10px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;letter-spacing:-.01em}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
a{color:inherit;text-decoration:none}

/* brand */
.brand{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:-.03em}
.brand .glyph{width:34px;height:34px;border-radius:9px;background:linear-gradient(150deg,var(--teal),#0BD3BB);display:grid;place-items:center;color:#04211D;font-size:17px;font-weight:800;box-shadow:0 4px 14px rgba(0,184,162,.35);flex:0 0 auto}
.brand .wm{font-size:19px;color:#fff}
.brand .wm b{color:var(--teal)}

/* ============ AUTH ============ */
.auth-stage{position:fixed;inset:0;display:grid;place-items:center;padding:24px;z-index:50;
  background:radial-gradient(1100px 700px at 80% -10%,rgba(0,184,162,.16),transparent 60%),radial-gradient(900px 600px at 0% 110%,rgba(0,184,162,.08),transparent 55%),#0A0E13}
.auth-shell{width:100%;max-width:880px;min-height:540px;background:#0F151B;border:1px solid #1C232C;border-radius:24px;display:grid;grid-template-columns:1fr 1fr;overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.55)}
.auth-brand{padding:38px 34px;display:flex;flex-direction:column;background:linear-gradient(160deg,#11181F,#0B1015);border-right:1px solid #1C232C;position:relative;overflow:hidden}
.auth-brand::after{content:"";position:absolute;right:-80px;bottom:-80px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(0,184,162,.18),transparent 70%)}
.auth-brand-mid{margin-top:auto;margin-bottom:auto}
.auth-brand-mid h2{color:#fff;font-size:24px;font-weight:800;letter-spacing:-.03em;line-height:1.25}
.auth-brand-mid p{color:#8B96A2;font-size:13.5px;margin-top:14px;line-height:1.65;max-width:300px}
.auth-brand-foot{color:#6B7682;font-size:12px;display:flex;align-items:center;gap:9px}
.auth-brand-foot i{color:var(--teal)}
.auth-form-panel{padding:32px 36px;display:flex;flex-direction:column;background:#0F151B}
.auth-tabs{display:flex;gap:6px;background:#0A0E13;border:1px solid #1C232C;border-radius:12px;padding:5px;margin-bottom:26px}
.auth-tab{flex:1;padding:10px;border-radius:8px;color:#8B96A2;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;transition:.15s;border:none;background:none;cursor:pointer;font-family:inherit}
.auth-tab.active{background:var(--teal);color:#04211D}
.auth-tab:hover:not(.active){color:#d6dde4}
.auth-pane{display:none;flex-direction:column}
.auth-pane.active{display:flex}
.auth-pane h3{color:#fff;font-size:19px;font-weight:700;letter-spacing:-.02em;margin-bottom:20px}
.pane-sub{color:#8B96A2;font-size:13px;margin-bottom:20px}
.auth-field{margin-bottom:14px}
.auth-field label{display:block;font-size:12.5px;font-weight:600;color:#A9B4BF;margin-bottom:7px}
.input-wrap{position:relative;display:flex;align-items:center}
.input-wrap .lead-icon{position:absolute;left:14px;color:#5C6772;font-size:13px;pointer-events:none}
.auth-field input{width:100%;background:#0A0E13;border:1px solid #232B34;border-radius:11px;color:#EAF0F5;font-size:14.5px;padding:13px 14px 13px 40px;transition:.18s}
.auth-field input::placeholder{color:#525C66}
.auth-field input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,184,162,.16)}
.pw-toggle{position:absolute;right:8px;width:34px;height:34px;border-radius:8px;color:#7A858F;display:grid;place-items:center;cursor:pointer}
.pw-toggle:hover{color:#cfd6dd;background:#161D24}
.btn-auth{width:100%;background:var(--teal);color:#04211D;font-weight:700;font-size:14.5px;padding:13px;border-radius:11px;transition:.16s;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:9px;border:none;cursor:pointer;font-family:inherit}
.btn-auth:hover{background:#0BD3BB;transform:translateY(-1px)}
.auth-err{background:rgba(229,62,62,.12);border:1px solid rgba(229,62,62,.35);color:#FF9A9A;font-size:13px;padding:10px 13px;border-radius:10px;margin-bottom:14px;display:flex;align-items:center;gap:9px}
.auth-ok{background:rgba(56,161,105,.12);border:1px solid rgba(56,161,105,.35);color:#86efac;font-size:13px;padding:10px 13px;border-radius:10px;margin-bottom:14px;display:flex;align-items:center;gap:9px}
.demo-hint{margin-top:auto;background:#0A0E13;border:1px dashed #2A333D;border-radius:11px;padding:11px 13px;font-size:11.5px;color:#7E8995;line-height:1.7}
.demo-hint b{color:#A9B4BF;font-weight:600}
.link-btn{color:var(--teal);font-size:13px;font-weight:600;background:none;border:none;cursor:pointer;font-family:inherit}
.link-btn:hover{text-decoration:underline}
.back-link{align-self:flex-start;color:#8B96A2;font-size:13px;display:flex;align-items:center;gap:7px;margin-bottom:16px;background:none;border:none;cursor:pointer;font-family:inherit}
.back-link:hover{color:#fff}
.otp-row{display:flex;gap:10px;justify-content:space-between;margin:6px 0 18px}
.otp-row input{width:100%;height:56px;text-align:center;font-size:22px;font-weight:700;background:#0A0E13;border:1px solid #232B34;border-radius:12px;color:#fff;transition:.16s;padding:0}
.otp-row input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,184,162,.16)}
.otp-row input.filled{border-color:#34404B}
.pane-foot{text-align:center;margin-top:18px}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}

/* ============ ERP SHELL ============ */
.erp-root{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:var(--sidebar);color:#9aa4b0;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;border-right:1px solid var(--sidebar-line);z-index:30}
.side-top{padding:20px 20px 16px;border-bottom:1px solid var(--sidebar-line)}
.side-sub{font-size:11px;color:#5a6470;margin-top:8px;letter-spacing:.06em;text-transform:uppercase;font-weight:600}
.nav{padding:12px;display:flex;flex-direction:column;gap:3px;flex:1;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:13px;padding:10px 13px;border-radius:10px;color:#8a95a2;font-size:14px;font-weight:500;transition:.14s;position:relative;text-align:left;width:100%;background:none;border:none;cursor:pointer;font-family:inherit;text-decoration:none}
.nav-item i{width:18px;text-align:center;font-size:15px;flex:0 0 auto}
.nav-item:hover{background:var(--sidebar-2);color:#d6dde4}
.nav-item.active{background:rgba(0,184,162,.12);color:#fff;font-weight:600}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--teal)}
.nav-item.active i{color:var(--teal)}
.nav-badge{margin-left:auto;font-size:11px;color:#cdd5dd;font-weight:600;background:var(--sidebar-2);padding:1px 8px;border-radius:20px;min-width:22px;text-align:center}
.nav-item.active .nav-badge{background:rgba(0,184,162,.2);color:var(--teal)}
.nav-badge.danger{background:rgba(229,62,62,.2);color:#f98080}
.side-foot{padding:14px 18px;border-top:1px solid var(--sidebar-line);font-size:11px;color:#5a6470;display:flex;align-items:center;gap:9px}
.side-foot .dot{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 3px rgba(0,184,162,.2);flex:0 0 auto}
.collapse-btn{margin-left:auto;color:#5a6470;width:30px;height:30px;border-radius:8px;display:grid;place-items:center;cursor:pointer}
.collapse-btn:hover{background:var(--sidebar-2);color:#d6dde4}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:20;background:rgba(246,248,250,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:0 24px;height:62px;display:flex;align-items:center;gap:14px}
.topbar h1{font-size:16px;font-weight:700;letter-spacing:-.02em}
.topbar h1 span{color:var(--teal-d)}
.top-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.top-date{color:var(--muted);font-size:13px}
.btn-soft{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 12px;font-size:13px;font-weight:600;color:var(--ink-2);transition:.14s;box-shadow:var(--shadow-sm);white-space:nowrap;text-decoration:none;cursor:pointer;font-family:inherit}
.btn-soft:hover{border-color:var(--teal);color:var(--teal-d)}
.btn-soft.icon{padding:8px 11px}
.user-chip{display:flex;align-items:center;gap:10px;padding-left:12px;border-left:1px solid var(--line)}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(140deg,var(--teal),#0BD3BB);color:#04211D;display:grid;place-items:center;font-weight:700;font-size:13px;flex:0 0 auto}
.user-chip .nm{font-size:13px;font-weight:600;line-height:1.2}
.user-chip .ml{font-size:11px;color:var(--muted)}
.icon-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:var(--muted);transition:.14s;background:none;border:none;cursor:pointer;font-family:inherit;text-decoration:none;font-size:16px}
.icon-btn:hover{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.icon-btn.danger:hover{color:var(--red)}
.mobile-menu-btn{display:none;width:36px;height:36px;border-radius:10px;align-items:center;justify-content:center;color:var(--muted);background:none;border:none;cursor:pointer;font-size:16px}
.content{padding:24px;flex:1}

/* module header */
.mod-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.mod-head .ti h2{font-size:23px;font-weight:800;letter-spacing:-.03em}
.mod-head .ti p{color:var(--muted);font-size:13.5px;margin-top:3px}
.mod-actions{margin-left:auto;display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.search-box{position:relative;display:flex;align-items:center}
.search-box i{position:absolute;left:13px;color:var(--muted);font-size:13px}
.search-box input{background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px 14px 9px 36px;font-size:13.5px;width:240px;transition:.14s;box-shadow:var(--shadow-sm)}
.search-box input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,184,162,.12)}
.btn-add{display:flex;align-items:center;gap:8px;background:var(--teal);color:#04211D;font-weight:700;font-size:13.5px;padding:9px 15px;border-radius:10px;transition:.14s;box-shadow:0 2px 8px rgba(0,184,162,.25);text-decoration:none;border:none;cursor:pointer;font-family:inherit}
.btn-add:hover{background:#0BD3BB;transform:translateY(-1px)}

/* KPI cards */
.kpi-grid{display:grid;gap:15px;margin-bottom:16px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:17px 19px;box-shadow:var(--shadow-sm);transition:.18s;position:relative;overflow:hidden}
.kpi:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.kpi .lab{font-size:12.5px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:8px}
.kpi .lab .ic{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;font-size:12px;flex:0 0 auto}
.kpi .val{font-size:26px;font-weight:800;letter-spacing:-.03em;margin-top:10px}
.kpi .sub{font-size:12px;color:var(--muted);margin-top:4px}
.kpi.accent{background:linear-gradient(155deg,#0D1117,#1A222C);border-color:#0D1117;color:#fff}
.kpi.accent .lab{color:#9aa4b0}.kpi.accent .val{color:#fff}.kpi.accent .sub{color:var(--teal)}

/* cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm)}
.card.pad{padding:20px}
.card-h{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.card-h h3{font-size:14.5px;font-weight:700}
.card-h .ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:var(--teal-soft);color:var(--teal-d);font-size:13px;flex:0 0 auto}
.card-h .tools{margin-left:auto;display:flex;gap:8px;align-items:center}
.grid{display:grid;gap:16px}

/* tables */
.tbl-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);overflow:hidden}
.tbl-wrap{overflow-x:auto}
.table-wrap{overflow-x:auto}
table.tbl,table{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th,table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700;padding:11px 16px;border-bottom:1px solid var(--line);white-space:nowrap;background:#FbFcfd}
table.tbl th a,table th a{color:inherit;text-decoration:none;display:flex;align-items:center;gap:5px}
table.tbl td,table td{padding:12px 16px;border-bottom:1px solid var(--line-2);color:var(--ink-2);white-space:nowrap;vertical-align:middle}
table.tbl tbody tr,table tbody tr{transition:.12s}
table.tbl tbody tr:hover,table tbody tr:hover{background:var(--bg)}
table.tbl tbody tr:last-child td,table tbody tr:last-child td{border-bottom:none}
table.tbl tr.inactief{opacity:.55}
.t-strong{color:var(--ink);font-weight:600}
.num{font-variant-numeric:tabular-nums;text-align:right}
th.num,td.num{text-align:right}
.row-link{color:var(--teal-d);font-weight:700}
.muted{color:var(--muted)}
.nosort{cursor:default}

/* pagination */
.pager{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--line-2);font-size:13px;color:var(--muted);flex-wrap:wrap;gap:10px}
.pager-btns{display:flex;gap:6px}
.pg{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;font-size:12.5px;font-weight:600;color:var(--ink-2);transition:.12s;text-decoration:none}
.pg:hover{border-color:var(--teal);color:var(--teal-d)}
.pg.active{background:var(--teal);border-color:var(--teal);color:#04211D}

/* pills */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap}
.pill .d{width:6px;height:6px;border-radius:50%;background:currentColor;flex:0 0 auto}
.pill.green{background:var(--green-bg);color:var(--green)}
.pill.blue{background:var(--blue-bg);color:var(--blue)}
.pill.orange{background:var(--orange-bg);color:var(--orange)}
.pill.yellow{background:var(--yellow-bg);color:#917208}
.pill.red{background:var(--red-bg);color:var(--red)}
.pill.grey{background:var(--grey-bg);color:#5d6772}
.pill.teal{background:var(--teal-soft);color:var(--teal-d)}
.pill.purple{background:var(--purple-bg);color:var(--purple)}

/* filter chips */
.filters{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.fchip{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:9px;padding:7px 13px;font-size:13px;font-weight:600;color:var(--ink-2);transition:.13s;box-shadow:var(--shadow-sm);text-decoration:none}
.fchip:hover{border-color:var(--teal)}
.fchip.active{background:var(--sidebar);color:#fff;border-color:var(--sidebar)}
.fchip.active .cnt{background:rgba(255,255,255,.18);color:#fff}
.fchip .cnt{font-size:11px;background:var(--grey-bg);color:#5d6772;padding:0 7px;border-radius:20px;font-weight:700}
.fsel{background:#fff;border:1px solid var(--line);border-radius:9px;padding:7px 11px;font-size:13px;font-weight:600;color:var(--ink-2);box-shadow:var(--shadow-sm)}

/* empty */
.empty{padding:44px 18px;text-align:center;color:var(--muted);font-size:13.5px}
.empty i{font-size:30px;color:var(--line);display:block;margin-bottom:12px}
.empty .big{font-size:15px;color:var(--ink-2);font-weight:600;margin-bottom:4px}

/* signal cards */
.signal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}
.signal{border-radius:var(--r);padding:17px 19px;border:1px solid;display:flex;flex-direction:column;gap:4px}
.signal.red{background:var(--red-bg);border-color:#F3C9C9}
.signal.orange{background:var(--orange-bg);border-color:#F0D3B3}
.signal.green{background:var(--green-bg);border-color:#BfE6CD}
.signal .sh{display:flex;align-items:center;gap:9px;font-size:12.5px;font-weight:700}
.signal.red .sh{color:var(--red)}.signal.orange .sh{color:var(--orange)}.signal.green .sh{color:var(--green)}
.signal .sv{font-size:28px;font-weight:800;letter-spacing:-.03em;color:var(--ink)}
.signal .sx{font-size:12px;color:var(--ink-2)}
.signal ul{list-style:none;margin-top:6px;display:flex;flex-direction:column;gap:5px}
.signal ul li{font-size:12px;color:var(--ink-2);display:flex;justify-content:space-between;gap:10px;padding:4px 0;border-top:1px solid rgba(0,0,0,.05)}

/* goal bar */
.goal-bar{height:16px;border-radius:20px;background:var(--grey-bg);overflow:hidden}
.goal-bar .fill{height:100%;border-radius:20px;background:linear-gradient(90deg,var(--teal),#0BD3BB)}
.big-number{display:flex;align-items:baseline;gap:9px}
.big-number .n{font-size:32px;font-weight:800;letter-spacing:-.03em}
.big-number .l{font-size:13px;color:var(--muted)}
.chart-box{position:relative;height:260px}

/* detail page */
.detail-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.back-btn{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px 14px;font-size:13px;font-weight:600;color:var(--ink-2);box-shadow:var(--shadow-sm);transition:.13s;text-decoration:none;cursor:pointer;font-family:inherit}
.back-btn:hover{border-color:var(--teal);color:var(--teal-d)}
.detail-title{display:flex;align-items:center;gap:14px}
.detail-title .big-ic{width:52px;height:52px;border-radius:14px;background:linear-gradient(150deg,var(--sidebar),#1A222C);color:var(--teal);display:grid;place-items:center;font-size:22px;font-weight:800;flex:0 0 auto}
.detail-title h2{font-size:22px;font-weight:800;letter-spacing:-.03em}
.detail-title .sub{font-size:13px;color:var(--muted);margin-top:2px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:20px;overflow-x:auto}
.tab{padding:11px 16px;font-size:13.5px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;transition:.13s;white-space:nowrap;background:none;border:none;cursor:pointer;font-family:inherit;text-decoration:none;border-bottom:2px solid transparent}
.tab:hover{color:var(--ink-2)}
.tab.active{color:var(--teal-d);border-bottom-color:var(--teal)}
.tab-pane{display:none}
.tab-pane.active{display:block}
.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1px;background:var(--line-2);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.info-cell{background:#fff;padding:14px 16px}
.info-cell .k{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700;margin-bottom:5px}
.info-cell .v{font-size:14px;color:var(--ink);font-weight:500}
.subcard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px;margin-top:16px}
.subcard h4{font-size:14px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:9px}
.subcard h4 .tools{margin-left:auto}

/* mini list */
.mini-list{display:flex;flex-direction:column;gap:8px}
.mini-row{display:flex;align-items:center;gap:12px;padding:11px 13px;border:1px solid var(--line-2);border-radius:10px;transition:.12s;text-decoration:none;color:inherit}
.mini-row:hover{border-color:var(--line);background:var(--bg)}
.mini-row .mt{font-weight:600;font-size:13.5px;color:var(--ink)}
.mini-row .ms{font-size:12px;color:var(--muted)}
.mini-row .mr{margin-left:auto;text-align:right}

/* kanban */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:start}
.kcol{background:var(--grey-bg);border-radius:14px;padding:11px;min-height:120px}
.kcol-h{display:flex;align-items:center;gap:9px;padding:5px 8px 11px;font-size:12.5px;font-weight:700;color:var(--ink-2)}
.kcol-h .dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.kcol-h .cnt{margin-left:auto;background:#fff;color:var(--muted);font-size:11px;padding:1px 8px;border-radius:20px;font-weight:700}
.kcard{background:#fff;border:1px solid var(--line);border-radius:11px;padding:13px;margin-bottom:9px;cursor:pointer;transition:.14s;border-left:3px solid var(--grey)}
.kcard:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.kcard h5{font-size:13.5px;font-weight:700;margin-bottom:3px}
.kcard .kc-sub{font-size:11.5px;color:var(--muted);margin-bottom:9px}
.kcard .kc-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:8px}
.kcard .kc-amt{font-size:14px;font-weight:800;letter-spacing:-.02em}
.kcard.blue{border-left-color:var(--blue)}.kcard.purple{border-left-color:var(--purple)}.kcard.teal{border-left-color:var(--teal)}.kcard.orange{border-left-color:var(--orange)}.kcard.green{border-left-color:var(--green)}

/* modal */
.modal-back{position:fixed;inset:0;background:rgba(13,17,23,.5);backdrop-filter:blur(3px);z-index:150;display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.modal{background:#fff;border-radius:18px;width:100%;box-shadow:var(--shadow-lg);margin:auto}
.modal.sm{max-width:420px}.modal.md{max-width:560px}.modal.lg{max-width:760px}
.modal-h{display:flex;align-items:center;gap:12px;padding:22px 26px;border-bottom:1px solid var(--line)}
.modal-h .mic{width:38px;height:38px;border-radius:10px;background:var(--teal-soft);color:var(--teal-d);display:grid;place-items:center;font-size:15px;flex:0 0 auto}
.modal-h h3{font-size:17px;font-weight:700;letter-spacing:-.02em}
.modal-h p{font-size:12.5px;color:var(--muted);margin-top:2px}
.modal-h .mclose{margin-left:auto;width:34px;height:34px;border-radius:9px;color:var(--muted);display:grid;place-items:center;background:none;border:none;cursor:pointer;font-size:16px}
.modal-h .mclose:hover{background:var(--bg);color:var(--ink)}
.modal-body{padding:22px 26px;max-height:64vh;overflow-y:auto}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:18px 26px;border-top:1px solid var(--line);background:#FbFcfd;border-radius:0 0 18px 18px}

/* form elements */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid.one{grid-template-columns:1fr}
.fg{display:flex;flex-direction:column;gap:6px}
.fg.full{grid-column:1/-1}
.fg label{font-size:12.5px;font-weight:600;color:var(--ink-2)}
.fg label .req{color:var(--red)}
.fg input,.fg select,.fg textarea{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 13px;font-size:14px;color:var(--ink);transition:.14s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,184,162,.12)}
.fg input.err,.fg select.err{border-color:var(--red)}
.fg textarea{resize:vertical;min-height:74px;line-height:1.55}
.fg .hint{font-size:11.5px;color:var(--muted)}
.section-divider{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700;margin:8px 0 2px;grid-column:1/-1;display:flex;align-items:center;gap:10px}
.section-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.btn-modal{font-weight:700;font-size:13.5px;padding:10px 18px;border-radius:10px;transition:.14s;display:flex;align-items:center;gap:8px;border:none;cursor:pointer;font-family:inherit}
.btn-modal.primary{background:var(--teal);color:#04211D}.btn-modal.primary:hover{background:#0BD3BB}
.btn-modal.ghost{background:#fff;border:1px solid var(--line);color:var(--ink-2)}.btn-modal.ghost:hover{border-color:var(--ink-2)}
.btn-modal.danger{background:var(--red);color:#fff}.btn-modal.danger:hover{background:#c93535}

/* inline forms */
.form-section{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow-sm)}
.form-section h3{font-size:15px;font-weight:700;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:9px}
.form-actions{display:flex;gap:10px;margin-top:20px;padding-top:18px;border-top:1px solid var(--line);flex-wrap:wrap}
.btn-primary-form{display:inline-flex;align-items:center;gap:8px;background:var(--teal);color:#04211D;font-weight:700;font-size:13.5px;padding:10px 20px;border-radius:10px;border:none;cursor:pointer;font-family:inherit;transition:.14s}
.btn-primary-form:hover{background:#0BD3BB}
.btn-secondary-form{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);color:var(--ink-2);font-weight:600;font-size:13.5px;padding:10px 18px;border-radius:10px;cursor:pointer;font-family:inherit;transition:.14s;text-decoration:none}
.btn-secondary-form:hover{border-color:var(--teal);color:var(--teal-d)}
.btn-danger-form{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;font-weight:700;font-size:13.5px;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;font-family:inherit;transition:.14s}
.btn-danger-form:hover{background:#c93535}

/* alert */
.alert{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:12px;font-size:13.5px;margin-bottom:14px;border:1px solid;line-height:1.55}
.alert.green,.alert-success{background:var(--green-bg);border-color:#bce6cd;color:var(--green)}
.alert.red,.alert-danger{background:var(--red-bg);border-color:#f3c9c9;color:var(--red)}
.alert.orange,.alert-warning{background:var(--orange-bg);border-color:#f0d3b3;color:var(--orange)}
.alert.blue,.alert-info{background:var(--blue-bg);border-color:#c3d9f8;color:var(--blue)}

/* toasts */
.toast-wrap{position:fixed;right:22px;bottom:22px;z-index:300;display:flex;flex-direction:column;gap:10px;max-width:360px;pointer-events:none}
.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:11px;background:#fff;border:1px solid var(--line);border-left:4px solid var(--grey);border-radius:12px;padding:13px 15px;box-shadow:var(--shadow-lg);font-size:13px;color:var(--ink-2)}
.toast i.tic{font-size:15px;margin-top:1px;flex:0 0 auto}
.toast.green{border-left-color:var(--green)}.toast.green i.tic{color:var(--green)}
.toast.orange{border-left-color:var(--orange)}.toast.orange i.tic{color:var(--orange)}
.toast.red{border-left-color:var(--red)}.toast.red i.tic{color:var(--red)}
.toast .tt{font-weight:700;color:var(--ink);margin-bottom:1px}
.toast .tx{margin-left:auto;color:var(--muted);cursor:pointer;padding:0 2px;flex:0 0 auto}

/* ============ PORTAAL (client) ============ */
.portal-top{background:#fff;border-bottom:1px solid var(--line);padding:0 32px;height:68px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:20}
.portal-top .brand .wm{color:var(--ink)}.portal-top .brand .wm b{color:var(--teal-d)}
.portal-top .pt-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.portal-top .pt-name{font-size:13.5px;font-weight:600}
.portal-top .pt-name small{display:block;color:var(--muted);font-weight:500;font-size:11.5px}
.portal-wrap{max-width:920px;margin:0 auto;padding:34px 24px 70px}
.portal-hero{margin-bottom:28px}
.portal-hero h1{font-size:27px;font-weight:800;letter-spacing:-.03em}
.portal-hero p{color:var(--muted);font-size:14.5px;margin-top:5px}
.portal-tabs{display:flex;gap:6px;background:#fff;border:1px solid var(--line);border-radius:13px;padding:6px;margin-bottom:24px;box-shadow:var(--shadow-sm);overflow-x:auto}
.portal-tab{padding:9px 18px;border-radius:9px;font-size:13.5px;font-weight:600;color:var(--muted);transition:.14s;display:flex;align-items:center;gap:9px;text-decoration:none;white-space:nowrap}
.portal-tab.active{background:var(--teal);color:#04211D}
.portal-pane{display:none}
.portal-pane.active{display:block}
.portal-card{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:18px}
.portal-card-h{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:11px}
.portal-card-h h3{font-size:16px;font-weight:700}
.portal-card-h .ic{width:34px;height:34px;border-radius:10px;background:var(--teal-soft);color:var(--teal-d);display:grid;place-items:center;flex:0 0 auto}
.sub-card{display:flex;align-items:center;gap:16px;padding:18px 22px;border-bottom:1px solid var(--line-2)}
.sub-card:last-child{border-bottom:none}
.sub-card .sc-ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:18px;background:var(--teal-soft);color:var(--teal-d);flex:0 0 auto}
.sub-card .sc-body{flex:1;min-width:0}
.sub-card .sc-body h4{font-size:15px;font-weight:700}
.sub-card .sc-body p{font-size:12.5px;color:var(--muted);margin-top:2px}
.sub-card .sc-price{font-size:16px;font-weight:800;letter-spacing:-.02em;text-align:right;flex:0 0 auto}
.sub-card .sc-price small{display:block;font-size:11px;color:var(--muted);font-weight:500}
.readonly-note{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;color:var(--muted);background:var(--bg);padding:4px 10px;border-radius:20px}

/* ============ RESPONSIVE ============ */
@media(max-width:1180px){.signal-grid{grid-template-columns:1fr}.kanban{grid-template-columns:1fr 1fr}}
@media(max-width:1024px){
  .erp-root{grid-template-columns:1fr}
  .sidebar{position:fixed;top:0;left:0;bottom:0;width:248px;transform:translateX(-100%);transition:transform .25s cubic-bezier(.2,.7,.2,1);z-index:60;box-shadow:0 24px 70px rgba(0,0,0,.45)}
  .erp-root.draw-open .sidebar{transform:none}
  .collapse-btn{display:none}
  .mobile-menu-btn{display:flex}
  #erp-overlay{display:block;position:fixed;inset:0;background:rgba(13,17,23,.5);z-index:55;opacity:0;pointer-events:none;transition:.25s}
  #erp-overlay.show{opacity:1;pointer-events:auto}
  .btn-soft span{display:none}.btn-soft{padding:8px 11px}
  .top-date,.user-chip .ml{display:none}
  .auth-shell{grid-template-columns:1fr;max-width:440px;min-height:0}
  .auth-brand{display:none}
  .form-grid{grid-template-columns:1fr}
}
@media(max-width:900px){.kpi-grid{grid-template-columns:repeat(2,1fr)!important}.content .grid{grid-template-columns:1fr!important}}
@media(max-width:680px){
  .content{padding:14px}
  .kanban{grid-template-columns:1fr}
  .mod-actions{width:100%;flex-wrap:wrap}
  .search-box{flex:1}.search-box input{width:100%}
  .portal-top{padding:0 16px}.portal-wrap{padding:24px 16px 60px}
}
@media(max-width:520px){
  .kpi-grid{grid-template-columns:1fr!important}
  .topbar{padding:0 12px;gap:8px}
  .topbar h1{font-size:15px}
  .user-chip .nm{display:none}.user-chip{padding-left:8px}
}
