:root{--bg:#f7f9fb;--surface:#ffffff;--surface-strong:#f0f4f7;--text:#18212b;--muted:#667382;--line:#dfe6ed;--accent:#138a64;--accent-strong:#0f6f51;--warn:#bd7b11;--danger:#c2413d;--blue:#2563eb;--shadow:0 14px 38px rgba(24,33,43,0.08)}*{box-sizing:border-box}body,html{margin:0;min-height:100%;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;letter-spacing:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app-shell{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}.sidebar{position:-webkit-sticky;position:sticky;top:0;height:100vh;padding:22px 18px;background:#101820;color:#eef6f3}.sidebar-head{display:grid;grid-gap:14px;gap:14px}.brand{display:flex;align-items:center;gap:10px;margin-bottom:24px;font-weight:750;font-size:18px}.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:8px;background:var(--accent);color:white}.mobile-menu{display:none}.nav-group{display:grid;grid-gap:6px;gap:6px}.nav-link{display:flex;align-items:center;gap:10px;padding:10px 11px;border-radius:8px;color:#c8d5dc;font-size:14px}.nav-link:hover{background:rgba(255,255,255,.08);color:#ffffff}.main{min-width:0;padding:22px 28px 40px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px}.topbar h1{margin:0;font-size:24px;line-height:1.15}.topbar p{margin:5px 0 0;color:var(--muted);font-size:14px}.role-chip{border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:8px 10px;color:var(--muted);font-size:13px}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(180deg,rgba(19,138,100,.08),rgba(37,99,235,.04)),var(--bg)}.login-card{width:min(100%,420px);padding:24px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:22px;font-size:17px;font-weight:780}.login-heading{margin-bottom:18px}.login-heading h1{margin:0;font-size:24px;line-height:1.15}.login-heading p{margin:7px 0 0;color:var(--muted);font-size:14px;line-height:1.55}.login-terms{align-items:flex-start;font-size:13px;line-height:1.6}.login-terms input{flex:0 0 auto;margin-top:3px}.login-submit{width:100%}.grid{display:grid;grid-gap:16px;gap:16px;min-width:0}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.panel{min-width:0;background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;padding:16px 18px;border-bottom:1px solid var(--line)}.panel-header h2{margin:0;font-size:16px}.panel-header p{margin:4px 0 0;color:var(--muted);font-size:13px}.panel-body{min-width:0;max-width:100%;padding:18px;overflow-x:auto}.metric{padding:16px}.metric-label{color:var(--muted);font-size:13px}.metric-value{margin-top:8px;font-size:25px;font-weight:780}.metric-foot{margin-top:8px;color:var(--muted);font-size:12px}.button-row{display:flex;flex-wrap:wrap;gap:10px;min-width:0}.btn,.button-row{align-items:center}.btn{display:inline-flex;justify-content:center;gap:8px;min-height:36px;padding:8px 12px;border-radius:8px;border:1px solid var(--line);background:var(--surface);color:var(--text);cursor:pointer;font-size:14px;font-weight:650}.btn.primary{border-color:var(--accent);background:var(--accent);color:#ffffff}.btn.primary:hover{background:var(--accent-strong)}.btn.warn{border-color:rgba(189,123,17,.25);color:var(--warn)}.btn.danger{border-color:rgba(194,65,61,.25);color:var(--danger)}.table{width:100%;min-width:720px;border-collapse:collapse;font-size:14px}.table td,.table th{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.table th{color:var(--muted);font-size:12px;font-weight:700}.table tr:last-child td{border-bottom:0}.badge{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:3px 9px;background:var(--surface-strong);color:var(--muted);font-size:12px;font-weight:700}.badge.green{background:#e7f7ef;color:var(--accent-strong)}.badge.amber{background:#fff4df;color:var(--warn)}.badge.red{background:#fdebea;color:var(--danger)}.alert{border:1px solid var(--line);border-radius:8px;margin-bottom:16px;padding:12px 14px;font-size:14px;font-weight:700}.alert.danger{background:#fdebea;border-color:#f4c7c3;color:var(--danger)}.form{display:grid;grid-gap:14px;gap:14px}.compact-form{min-width:220px;gap:8px}.compact-form .field{gap:4px}.compact-form .field input{min-height:34px;padding:7px 9px}.field{display:grid;grid-gap:7px;gap:7px}.field label{font-size:13px;font-weight:700}.field input,.field select,.field textarea{width:100%;min-height:40px;border:1px solid var(--line);border-radius:8px;padding:9px 10px;background:white;color:var(--text)}.field textarea{min-height:88px;resize:vertical}.checkbox-grid{display:grid;grid-gap:8px;gap:8px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.check-line{display:flex;align-items:center;gap:8px;min-height:34px;font-weight:600}.check-line input{width:16px;min-height:16px}.qr-box{display:grid;justify-items:center;grid-gap:10px;gap:10px;padding:18px;border:1px dashed #b9c6d2;border-radius:8px;background:#fbfcfd}.qr-box img{width:210px;height:210px}.muted{color:var(--muted)}.mono{font-family:SFMono-Regular,Consolas,monospace;overflow-wrap:anywhere}.workflow{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:14px;gap:14px}.workflow-step{min-height:140px;padding:16px;background:var(--surface);border:1px solid var(--line);border-radius:8px}.workflow-step svg{color:var(--accent);margin-bottom:12px}.workflow-step h3{margin:0 0 8px;font-size:15px}.workflow-step p{margin:0;color:var(--muted);font-size:13px;line-height:1.55}.empty{padding:28px;text-align:center;color:var(--muted)}@media (max-width:960px){.app-shell{grid-template-columns:1fr;grid-template-rows:auto 1fr}.sidebar{position:-webkit-sticky;position:sticky;z-index:10;height:auto;padding:12px 14px;box-shadow:0 8px 22px rgba(16,24,32,.18)}.sidebar-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.brand{min-width:0;margin-bottom:0;font-size:16px}.brand span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brand-mark{width:32px;height:32px;flex:0 0 32px}.desktop-nav{display:none}.mobile-menu{display:block;flex:0 0 auto;position:relative}.mobile-menu summary{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:34px;padding:7px 10px;border:1px solid rgba(255,255,255,.16);border-radius:8px;color:#eef6f3;cursor:pointer;font-size:14px;font-weight:700;list-style:none}.mobile-menu summary::-webkit-details-marker{display:none}.mobile-menu[open] .nav-group{position:absolute;right:0;top:calc(100% + 10px);width:min(78vw,260px);max-height:calc(100vh - 82px);overflow-y:auto;padding:8px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:#101820;box-shadow:0 16px 34px rgba(16,24,32,.24)}.nav-link{min-height:40px}.main{padding:18px 14px 32px}.login-shell{align-items:flex-start;padding:18px 14px}.login-card{padding:18px}.login-heading h1{font-size:22px}.topbar{align-items:flex-start;flex-direction:column;gap:12px;margin-bottom:16px}.topbar h1{font-size:21px}.topbar .button-row{width:100%}.button-row>*,.grid>*,.panel-body>*,.panel-header>*{min-width:0}.panel-header{align-items:flex-start;flex-direction:column}.panel-header .btn,.panel-header .button-row,.panel-header form{max-width:100%}.compact-form{min-width:0;width:100%}.qr-box{padding:14px}.qr-box img{max-width:100%;height:auto}.role-chip{max-width:100%;overflow-wrap:anywhere}.grid.cols-2,.grid.cols-3,.grid.cols-4,.workflow{grid-template-columns:1fr}}