*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#1f2937;background:#f3f4f6;height:100%}a{color:inherit;text-decoration:none}button{font-family:inherit}.layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:240px;background:#111827;color:#d1d5db;display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:16px;font-weight:700;font-size:18px;color:#fff;border-bottom:1px solid #374151}.sidebar-nav{flex:1 1;overflow-y:auto;padding:8px 0}.sidebar-item{display:block;padding:10px 16px;font-size:14px;transition:background .15s}.sidebar-item:hover{background:#1f2937;color:#fff}.sidebar-item.active{background:#2563eb;color:#fff}.main{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:56px;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}.topbar-title{font-weight:600;font-size:16px}.topbar-user{font-size:14px;color:#6b7280}.content{flex:1 1;overflow-y:auto;padding:24px}.page-header{margin-bottom:20px}.page-header h1{margin:0 0 4px;font-size:22px;font-weight:700}.page-header p{margin:0;color:#6b7280;font-size:14px}.card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.badge{display:inline-block;padding:2px 10px;border-radius:9999px;font-size:12px;font-weight:600}.badge-default{background:#e5e7eb;color:#374151}.badge-blue{background:#dbeafe;color:#1e40af}.badge-green{background:#d1fae5;color:#065f46}.badge-red{background:#fee2e2;color:#991b1b}.table{width:100%;border-collapse:collapse;font-size:14px}.table td,.table th{padding:12px;text-align:left;border-bottom:1px solid #e5e7eb}.table th{font-weight:600;color:#6b7280;background:#f9fafb}.empty-state,.loading-state{display:flex;align-items:center;justify-content:center;padding:48px;color:#6b7280}.empty-state,.error-state{flex-direction:column}.error-state{display:flex;align-items:center;justify-content:center;padding:48px;color:#991b1b}.error-state .code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;color:#6b7280;margin-top:8px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:6px;font-size:14px;font-weight:500;border:1px solid transparent;cursor:pointer;transition:background .15s,border-color .15s}.btn-primary{background:#2563eb;color:#fff;border-color:#2563eb}.btn-primary:hover{background:#1d4ed8}.btn-danger{background:#dc2626;color:#fff;border-color:#dc2626}.btn-danger:hover{background:#b91c1c}.btn-ghost{background:transparent;color:#374151;border-color:#d1d5db}.btn-ghost:hover{background:#f3f4f6}.btn-sm{padding:4px 10px;font-size:13px}.actions{gap:8px}.actions,.modal-overlay{display:flex;align-items:center}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);justify-content:center;z-index:50}.modal{background:#fff;border-radius:8px;width:480px;max-width:90vw;padding:24px;box-shadow:0 10px 25px rgba(0,0,0,.15)}.modal h2{margin:0 0 16px;font-size:18px}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:#374151}.form-group input{width:100%;padding:8px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.form-group input:focus{outline:none;border-color:#2563eb}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}