:root{--blue:#0d7ff2;--blue-dark:#096bd1;--nav:#222b35;--nav-2:#2e3945;--bg:#f3f6fb;--surface:#fff;--muted:#6b7280;--text:#111827;--line:#dfe5ee;--green:#20a947;--yellow:#f7b500;--red:#ee4b4b;--cyan:#20a6b8;--orange:#f59e0b}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0;font-family:Arial,Helvetica,sans-serif}a{color:inherit;text-decoration:none}.small{color:var(--muted);font-size:12px}.text-muted{color:var(--muted)}.badge{white-space:nowrap;border-radius:999px;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:700;display:inline-flex}.badge.green{color:#16843b;background:#e9f8ef}.badge.red{color:#d92d20;background:#fff0f0}.badge.yellow{color:#9a6b00;background:#fff8df}.badge.blue{color:#0d65c5;background:#e9f2ff}.badge.gray{color:#4b5563;background:#eef1f5}.badge.purple{color:#6d28d9;background:#f2e9ff}.btn{color:#111827;cursor:pointer;background:#eef1f5;border:0;border-radius:4px;align-items:center;gap:6px;padding:9px 14px;font-size:13px;font-weight:700;display:inline-flex}.btn.primary{background:var(--blue);color:#fff}.btn.primary:hover{background:var(--blue-dark)}.btn.danger{background:var(--red);color:#fff}.btn.outline{border:1px solid var(--line);background:#fff}.btn.warning{background:var(--yellow);color:#111827}.btn.sm{border-radius:3px;padding:6px 8px;font-size:11px}.btn.block{justify-content:center;width:100%}.input,.select,.textarea{color:#111827;background:#fff;border:1px solid #ccd5e1;border-radius:4px;width:100%;min-height:38px;padding:8px 10px;font-family:inherit;font-size:13px}.input:focus,.select:focus,.textarea:focus{border-color:var(--blue);outline:2px solid #0d7ff259}.textarea{resize:vertical;min-height:90px}label{color:#4b5563;margin-bottom:6px;font-size:12px;font-weight:700;display:block}.field-error{color:#d92d20;margin-top:4px;font-size:12px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.form-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.form-grid .full{grid-column:1/-1}.form-section{border:1px solid var(--line);background:#fff;border-radius:6px;margin-bottom:16px;overflow:hidden}.form-section .section-title{background:var(--blue);color:#fff;padding:10px 14px;font-size:13px;font-weight:800}.form-section .section-body{padding:16px}.form-actions{justify-content:flex-end;gap:10px;margin-bottom:20px;display:flex}.check-line{align-items:center;gap:7px;margin:8px 0;font-size:13px;display:flex}.checkbox{width:16px;height:16px;accent-color:var(--blue)}.auth-page{background:#dce2ea;justify-content:center;align-items:center;min-height:100vh;padding:30px;display:flex}.auth-card{background:#fff;border:1px solid #cfd8e3;border-radius:8px;width:420px;padding:28px 32px;box-shadow:0 15px 30px #00000014}.logo{justify-content:center;align-items:center;gap:9px;margin-bottom:7px;font-weight:800;display:flex}.logo-icon{background:var(--blue);color:#fff;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;font-weight:900;display:flex}.auth-title{text-align:center;margin:0 0 5px;font-size:21px;font-weight:800}.auth-subtitle{text-align:center;color:#6b7280;margin-bottom:22px;font-size:12px}.auth-actions{justify-content:space-between;align-items:center;margin:9px 0 16px;font-size:12px;display:flex}.auth-link{color:var(--blue)}.layout{min-height:100vh;display:flex}.sidebar{background:var(--nav);color:#cbd5e1;z-index:5;width:245px;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;box-shadow:8px 0 20px #00000014}.sidebar-header{border-bottom:1px solid #ffffff14;padding:18px}.sidebar .brand{color:#fff;align-items:center;gap:10px;font-size:16px;font-weight:800;display:flex}.sidebar .user{border-bottom:1px solid #ffffff14;align-items:center;gap:10px;padding:14px 18px;display:flex}.avatar{color:#111827;background:#e5e7eb;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-weight:900;display:flex;overflow:hidden}.avatar.lg{width:84px;height:84px;font-size:26px}.avatar.md{width:50px;height:50px}.nav-title{text-transform:uppercase;letter-spacing:.08em;color:#7f8b9a;padding:14px 18px 6px;font-size:10px;font-weight:800}.nav-item{color:#cbd5e1;border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 18px;font-size:13px;display:flex}.nav-item.active{background:var(--blue);color:#fff;border-left-color:#8cc7ff}.nav-item:hover{color:#fff;background:#2a3540}.nav-item .soon{letter-spacing:.04em;color:#9fb0c3;text-transform:uppercase;background:#ffffff1f;border-radius:999px;margin-left:auto;padding:2px 6px;font-size:9px;font-weight:800}.content{width:calc(100% - 245px);min-height:100vh;margin-left:245px}.topbar{border-bottom:1px solid var(--line);z-index:3;background:#fff;justify-content:space-between;align-items:center;height:60px;padding:0 22px;display:flex;position:sticky;top:0}.topbar-right{align-items:center;gap:14px;display:flex}.breadcrumb{color:#6b7280;font-size:12px}.breadcrumb a:hover{color:var(--blue)}.page{padding:22px}.page-header{justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:16px;display:flex}.page-title{margin:0;font-size:22px;font-weight:800}.page-desc{color:#6b7280;margin:4px 0 0;font-size:13px}.page-actions{flex-shrink:0;gap:8px;display:flex}.card-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px;display:grid}.card{border:1px solid var(--line);background:#fff;border-radius:7px;box-shadow:0 1px 2px #1018280a}.metric{padding:18px;position:relative;overflow:hidden}.metric .value{margin-bottom:5px;font-size:28px;font-weight:900}.metric .label{color:#6b7280;font-size:13px}.metric.blue{border-top:4px solid var(--blue)}.metric.green{border-top:4px solid var(--green)}.metric.yellow{border-top:4px solid var(--yellow)}.metric.red{border-top:4px solid var(--red)}.metric.cyan{border-top:4px solid var(--cyan)}.metric:after{content:"";background:#0d7ff214;border-radius:50%;width:80px;height:80px;position:absolute;bottom:-20px;right:-20px}.toolbar{border:1px solid var(--line);background:#fff;border-radius:7px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding:14px;display:flex}.toolbar-left,.toolbar-right{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.table-card{border:1px solid var(--line);background:#fff;border-radius:7px;margin-bottom:16px;overflow:hidden}.table-title{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:10px;padding:14px 16px;font-weight:800;display:flex}.table-wrap{overflow-x:auto}table{border-collapse:collapse;background:#fff;width:100%}th,td{border-bottom:1px solid var(--line);vertical-align:middle;text-align:left;padding:12px;font-size:13px}th{color:#475569;background:#f8fafc;font-size:12px}tr:hover td{background:#fbfdff}.actions{gap:6px;display:flex}.table-empty{text-align:center;color:var(--muted);padding:26px;font-size:13px}.table-footer{justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.tabs{border-bottom:1px solid var(--line);background:#fff;gap:0;display:flex}.tab{color:#64748b;border-bottom:3px solid #0000;padding:12px 16px;font-size:13px;font-weight:700}.tab.active{color:var(--blue);border-bottom-color:var(--blue)}.split{grid-template-columns:320px 1fr;gap:16px;display:grid}.split.even{grid-template-columns:1fr 1fr}.profile-card{text-align:center;padding:20px}.profile-card h3{margin:10px 0 4px}.permission-table th,.permission-table td{text-align:center}.permission-table th:first-child,.permission-table td:first-child{text-align:left}.help-box{border-left:4px solid var(--blue);color:#334155;background:#eef6ff;border-radius:4px;margin-bottom:14px;padding:12px 14px;font-size:13px}.alert{color:#991b1b;background:#fff5f5;border:1px solid #fecaca;border-radius:5px;padding:12px;font-size:13px}.alert.success{color:#14652f;background:#effaf3;border-color:#bbe8c8}.note{color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:10px 12px;font-size:13px}.flash{margin-bottom:14px}.tree{border:1px solid var(--line);background:#fff;border-radius:7px;padding:18px}.tree ul{margin:0;padding-left:24px;list-style:none}.tree>ul{padding-left:0}.tree li{margin:12px 0;position:relative}.tree ul ul li:before{content:"";background:#cbd5e1;width:12px;height:1px;position:absolute;top:11px;left:-14px}.tree-node{border:1px solid var(--line);background:#fff;border-radius:6px;align-items:center;gap:8px;padding:9px 12px;font-size:13px;font-weight:700;display:inline-flex;box-shadow:0 1px 2px #0000000a}.workflow{flex-wrap:wrap;align-items:center;gap:10px;margin:12px 0;display:flex}.workflow-step{border:1px solid var(--line);text-align:center;background:#fff;border-radius:7px;min-width:150px;padding:12px 14px}.arrow{color:#64748b;font-weight:900}.dual-list{grid-template-columns:1fr 64px 1fr;align-items:start;gap:16px;display:grid}.user-list{border:1px solid var(--line);background:#fff;border-radius:7px;min-height:360px;padding:12px}.user-list h3{margin-top:4px}.user-row{background:#fff;border:1px solid #edf1f7;border-radius:6px;align-items:center;gap:10px;margin-bottom:8px;padding:10px;display:flex}.center-actions{justify-content:center;gap:10px;padding-top:60px;display:grid}.modal-overlay{z-index:50;background:#0f172aa6;justify-content:center;align-items:center;padding:30px;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal-card{background:#fff;border-radius:8px;width:460px;max-width:100%;overflow:hidden;box-shadow:0 18px 60px #00000038}.modal-head{border-bottom:1px solid var(--line);justify-content:space-between;padding:14px 16px;font-weight:800;display:flex}.modal-close{cursor:pointer;color:var(--muted);background:0 0;border:0;font-size:16px;font-weight:800}.modal-body{padding:18px}.modal-foot{background:#f8fafc;justify-content:flex-end;gap:8px;padding:14px 16px;display:flex}.map-placeholder,.chart-placeholder{color:#64748b;text-align:center;background:#f8fafc;border:2px dashed #c3cfde;border-radius:8px;justify-content:center;align-items:center;min-height:260px;padding:20px;font-size:13px;font-weight:700;display:flex}.coming-soon{border:1px solid var(--line);text-align:center;background:#fff;border-radius:8px;padding:70px 30px}.coming-soon .icon{margin-bottom:12px;font-size:44px}.coming-soon h2{margin:0 0 8px;font-size:22px}.coming-soon p{color:var(--muted);max-width:460px;margin:0 auto 20px;font-size:14px}.detail-table th{background:#f8fafc;width:220px}@media (width<=1000px){.sidebar{width:100%;position:static}.layout{display:block}.content{width:100%;margin-left:0}.card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid,.form-grid.three,.form-grid.four,.split,.split.even,.dual-list{grid-template-columns:1fr}.center-actions{grid-auto-flow:column;padding-top:0}.toolbar{flex-direction:column;align-items:stretch}.page-header{flex-direction:column}}@media (width<=640px){.card-grid{grid-template-columns:1fr}}
