.forbidden{text-align:center;max-width:32rem;margin:5rem auto}.forbidden h1{margin-bottom:.75rem;font-size:1.4rem}.forbidden p{color:var(--text-muted);margin-bottom:1.5rem;line-height:1.6}.forbidden code{background:var(--surface-muted);border-radius:4px;padding:.1rem .35rem;font-size:.85em}.error-page{text-align:center;max-width:32rem;margin:4rem auto}.error-page h1{margin-bottom:.5rem;font-size:1.3rem}.error-page p{color:var(--text-muted);margin-bottom:1.5rem}.layout{min-height:100vh}.layout-header{border-bottom:1px solid var(--border);background:#fff;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex}.layout-brand{color:var(--text);font-size:1.05rem;font-weight:600;text-decoration:none}.layout-user{align-items:center;gap:.875rem;display:flex}.layout-email{color:var(--text-muted);font-size:.9rem}.layout-progress.is-busy{background:var(--accent)}.layout-main{max-width:60rem;margin:0 auto;padding:1.75rem 1.5rem}.banner{border:1px solid #0000;border-radius:6px;padding:.625rem .875rem;font-size:.9rem}.banner-error{color:#8a1c12;background:#fdecea;border-color:#f5c6c2}.banner-success{color:#1d6f3f;background:#e9f7ef;border-color:#bde5cb}.banner-info{color:#2a4d80;background:#eef3fb;border-color:#cdddf2}.modal-overlay{z-index:50;background:#0f172a73;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:10px;width:100%;max-width:26rem;box-shadow:0 10px 40px #0f172a40}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.875rem 1.125rem;display:flex}.modal-header h2{margin:0;font-size:1.05rem}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;font-size:1.4rem;line-height:1}.modal-close:hover{color:var(--text)}.modal-body{padding:1.125rem}.confirm-message{color:var(--text);margin:0 0 1.25rem;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:.625rem;display:flex}.detail-page{flex-direction:column;gap:1.25rem;display:flex}.detail-back{color:var(--text-muted);width:fit-content;font-size:.9rem;text-decoration:none}.detail-back:hover{color:var(--text)}.detail-card{border:1px solid var(--border);background:#fff;border-radius:8px;padding:1.25rem}.detail-card h2{margin:0 0 1rem;font-size:1rem}.detail-card-head{align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.detail-card-head h1{margin:0;font-size:1.2rem}.detail-fields{grid-template-columns:repeat(auto-fit,minmax(12rem,1fr));gap:.875rem;margin-bottom:1.25rem;display:grid}.detail-fields label{color:var(--text-muted);flex-direction:column;gap:.3rem;font-size:.85rem;display:flex}.detail-actions{flex-wrap:wrap;gap:.625rem;display:flex}.role-chips{flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;display:flex}.role-empty{color:var(--text-muted);font-size:.9rem}.role-chip{background:var(--surface-muted);border:1px solid var(--border);border-radius:999px;align-items:center;gap:.4rem;padding:.25rem .4rem .25rem .7rem;font-size:.85rem;display:inline-flex}.role-chip-remove{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0 .2rem;font-size:1rem;line-height:1}.role-chip-remove:hover{color:var(--danger)}.role-add{gap:.625rem;display:flex}.table{border-collapse:collapse;border:1px solid var(--border);background:#fff;border-radius:8px;width:100%;overflow:hidden}.table th,.table td{text-align:left;border-bottom:1px solid var(--border);padding:.625rem .875rem}.table th{background:var(--surface-muted);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-size:.78rem}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--surface-muted)}.table-empty{text-align:center;color:var(--text-muted);border:1px dashed var(--border);background:#fff;border-radius:8px;padding:2rem}.users-toolbar{gap:.75rem;margin-bottom:1.25rem;display:flex}.users-search{flex:1}.create-form{flex-direction:column;gap:.875rem;display:flex}.create-form label{color:var(--text-muted);flex-direction:column;gap:.3rem;font-size:.85rem;display:flex}.create-actions{justify-content:flex-end;gap:.625rem;margin-top:.5rem;display:flex}:root{--text:#1f2937;--text-muted:#6b7280;--border:#e3e6ea;--surface:#f6f7f9;--surface-muted:#f0f2f5;--accent:#2563eb;--accent-hover:#1d4ed8;--danger:#c0392b;--danger-hover:#a93226;color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--surface)}h1,h2,h3{color:var(--text)}a{color:var(--accent)}input,select{font:inherit;border:1px solid var(--border);color:var(--text);background:#fff;border-radius:6px;padding:.45rem .6rem}input:focus,select:focus{outline:2px solid var(--accent);outline-offset:-1px}input:disabled{background:var(--surface-muted);color:var(--text-muted)}.btn{font:inherit;border:1px solid var(--border);color:var(--text);cursor:pointer;background:#fff;border-radius:6px;align-items:center;padding:.45rem .9rem;text-decoration:none;display:inline-flex}.btn:hover:not(:disabled){background:var(--surface-muted)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}.badge{border-radius:999px;padding:.15rem .55rem;font-size:.78rem;font-weight:500;display:inline-block}.badge-on{color:#1d6f3f;background:#e9f7ef}.badge-off{color:#8a1c12;background:#fdecea}
