:root{color:#1f2937;background:#f4f6f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}code{font-family:Cascadia Code,SFMono-Regular,Consolas,monospace}a{color:inherit;text-decoration:none}.dashboard-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:#111827;color:#f9fafb;padding:24px 18px}.sidebar-brand{margin-bottom:32px;font-size:20px;font-weight:700}.sidebar-nav{display:grid;gap:8px}.sidebar-group{border-top:1px solid rgba(203,213,225,.16);display:grid;gap:8px;margin-top:10px;padding-top:14px}.sidebar-group p{color:#94a3b8;font-size:12px;font-weight:800;letter-spacing:0;margin:0 0 2px;text-transform:uppercase}.sidebar-subnav{display:grid;gap:6px}.sidebar-link{border:0;border-radius:8px;background:transparent;color:#cbd5e1;display:block;font-weight:600;padding:11px 12px;text-align:left;width:100%}.sidebar-sublink{padding-left:18px}.sidebar-link.active,.sidebar-link:hover{background:#243041;color:#fff}.dashboard-content{display:flex;flex-direction:column;min-width:0}.header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;min-height:82px;padding:18px 32px}.header h1{font-size:24px;line-height:1.2;margin:2px 0 0}.header-kicker,.panel-label{color:#6b7280;font-size:13px;font-weight:700;letter-spacing:0;margin:0;text-transform:uppercase}.header-actions{align-items:center;display:flex;gap:14px}.header-user{display:grid;gap:2px;text-align:right}.header-user span{font-size:14px;font-weight:700}.header-user small{color:#6b7280;font-size:12px;text-transform:capitalize}.logout-button,.primary-button{border:0;border-radius:8px;font-weight:700}.logout-button{background:#fff7ed;color:#9a3412;padding:10px 13px}.logout-button:hover{background:#ffedd5}.dashboard-main{padding:32px}.dashboard-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;max-width:920px;padding:28px}.dashboard-panel h2{font-size:30px;line-height:1.25;margin:8px 0 10px}.panel-copy{color:#4b5563;margin:0}.page-heading{margin-bottom:22px;max-width:760px}.page-heading h2{font-size:30px;line-height:1.25;margin:8px 0}.page-heading p:last-child{color:#4b5563;margin:0}.state-panel,.roles-panel,.permissions-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px}.state-panel{color:#4b5563;padding:22px}.rbac-grid{align-items:start;display:grid;gap:22px;grid-template-columns:minmax(240px,340px) minmax(0,1fr)}.roles-panel,.permissions-panel{overflow:hidden}.section-heading{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;gap:16px;justify-content:space-between;padding:18px 20px}.section-heading h3{font-size:18px;line-height:1.25;margin:0}.section-heading p{color:#6b7280;font-size:13px;margin:3px 0 0}.section-heading span{background:#ecfdf5;border:1px solid #bbf7d0;border-radius:999px;color:#166534;flex:0 0 auto;font-size:12px;font-weight:800;padding:7px 10px}.roles-list{display:grid}.role-row{align-items:center;background:#fff;border:0;border-bottom:1px solid #eef2f7;color:#111827;display:flex;gap:12px;justify-content:space-between;min-height:58px;padding:14px 18px;text-align:left}.role-row:last-child{border-bottom:0}.role-row:hover,.role-row.active{background:#fff7ed}.role-row span{font-weight:800}.role-row small{color:#6b7280;flex:0 0 auto;font-size:12px}.permission-groups{display:grid;gap:18px;padding:20px}.permission-group{display:grid;gap:10px}.permission-group h4{color:#374151;font-size:14px;margin:0}.permission-list{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.permission-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:grid;gap:4px;padding:12px}.permission-item span{color:#111827;font-size:14px;font-weight:700}.permission-item code{color:#6b7280;font-size:12px;overflow-wrap:anywhere}.login-page{align-items:stretch;background:linear-gradient(120deg,#111827e0,#2b4c38d6),url(https://images.unsplash.com/photo-1556911220-bff31c812dba?auto=format&fit=crop&w=1600&q=80);background-position:center;background-size:cover;display:grid;grid-template-columns:minmax(0,1fr) 430px;min-height:100vh}.login-hero{color:#fff;display:flex;flex-direction:column;justify-content:center;max-width:720px;padding:56px}.login-kicker{color:#fed7aa;font-size:14px;font-weight:800;letter-spacing:0;margin:0 0 14px;text-transform:uppercase}.login-hero h1{font-size:46px;line-height:1.08;margin:0 0 16px;max-width:680px}.login-hero p{color:#f3f4f6;font-size:18px;margin:0;max-width:560px}.login-card{align-self:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 24px 80px #0f172a3d;margin:32px;padding:30px}.login-card-header h2{font-size:28px;line-height:1.2;margin:6px 0 24px}.login-form{display:grid;gap:18px}.login-form label{color:#374151;display:grid;font-size:14px;font-weight:700;gap:8px}.login-form input{background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;color:#111827;min-height:46px;outline:none;padding:11px 12px;width:100%}.login-form input:focus{background:#fff;border-color:#f97316;box-shadow:0 0 0 3px #f9731629}.password-field{align-items:center;display:grid;grid-template-columns:1fr auto}.password-field input{border-radius:8px 0 0 8px}.password-field button{align-self:stretch;background:#f3f4f6;border:1px solid #d1d5db;border-left:0;border-radius:0 8px 8px 0;color:#374151;font-weight:700;padding:0 13px}.form-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;font-size:14px;margin:0;padding:10px 12px}.primary-button{background:#ea580c;color:#fff;min-height:48px;padding:12px 16px}.compact-button{min-height:42px;padding:10px 14px}.secondary-button{background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;color:#374151;font-weight:800;min-height:42px;padding:10px 14px}.primary-button:hover:not(:disabled){background:#c2410c}.primary-button:disabled{cursor:not-allowed;opacity:.7}.split-heading{align-items:flex-start;display:flex;gap:18px;justify-content:space-between;max-width:none}.data-toolbar{background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:grid;gap:12px;grid-template-columns:minmax(220px,1fr) 220px 180px;margin-bottom:18px;padding:14px}.two-column-toolbar{grid-template-columns:minmax(220px,1fr) 180px}.data-toolbar input,.data-toolbar select,.user-form input,.user-form select{background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;color:#111827;min-height:42px;outline:none;padding:10px 12px;width:100%}.data-toolbar input:focus,.data-toolbar select:focus,.user-form input:focus,.user-form select:focus{background:#fff;border-color:#f97316;box-shadow:0 0 0 3px #f9731629}.table-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.users-table{border-collapse:collapse;width:100%}.users-table th,.users-table td{border-bottom:1px solid #eef2f7;padding:14px 16px;text-align:left;vertical-align:middle}.users-table th{background:#f9fafb;color:#4b5563;font-size:12px;text-transform:uppercase}.users-table td strong,.users-table td span,.users-table td small{display:block}.users-table td strong{color:#111827}.users-table td span,.users-table td small{color:#6b7280;font-size:13px}.role-badge,.status-badge{border-radius:999px;display:inline-flex;font-size:12px;font-weight:800;padding:6px 9px;width:fit-content}.role-badge{background:#eef2ff;color:#3730a3}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.inactive{background:#f3f4f6;color:#4b5563}.table-actions{display:flex;flex-wrap:wrap;gap:8px}.table-actions button,.icon-button{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;font-size:13px;font-weight:800;min-height:34px;padding:7px 10px}.table-actions button:hover,.icon-button:hover,.secondary-button:hover{background:#f9fafb}.modal-backdrop{align-items:center;background:#1118279e;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;padding:24px;position:fixed;z-index:20}.modal-panel{background:#fff;border-radius:8px;box-shadow:0 30px 90px #0f172a47;max-height:min(820px,calc(100vh - 48px));max-width:760px;overflow:auto;width:100%}.narrow-modal{max-width:640px}.modal-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;gap:16px;justify-content:space-between;padding:20px 22px}.modal-header h3{font-size:22px;line-height:1.25;margin:4px 0 0}.user-form{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr));padding:22px}.user-form label{color:#374151;display:grid;font-size:14px;font-weight:800;gap:7px}.user-form label small{color:#b91c1c;font-weight:700}.modal-actions{display:flex;gap:10px;grid-column:1 / -1;justify-content:flex-end;padding-top:8px}@media(max-width:760px){.login-page{background:linear-gradient(150deg,#111827e6,#2b4c38e0),url(https://images.unsplash.com/photo-1556911220-bff31c812dba?auto=format&fit=crop&w=1000&q=80);background-position:center;background-size:cover;grid-template-columns:1fr;padding:18px}.login-hero{justify-content:flex-end;padding:28px 0 10px}.login-hero h1{font-size:32px}.login-hero p{font-size:16px}.login-card{margin:18px 0 0;padding:22px}.dashboard-shell{grid-template-columns:1fr}.sidebar{padding:18px}.sidebar-brand{margin-bottom:16px}.sidebar-nav{display:flex;gap:8px;overflow-x:auto}.sidebar-group{border-top:0;display:flex;flex:0 0 auto;gap:8px;margin-top:0;padding-top:0}.sidebar-group p{align-self:center;margin:0;white-space:nowrap}.sidebar-subnav{display:flex;gap:8px}.sidebar-link{flex:0 0 auto;text-align:center;width:auto}.sidebar-sublink{padding-left:12px}.header{align-items:flex-start;gap:16px;flex-wrap:wrap;padding:18px}.header-actions{justify-content:space-between;width:100%}.header-user{text-align:left}.dashboard-main{padding:18px}.rbac-grid,.permission-list{grid-template-columns:1fr}.section-heading{align-items:flex-start;flex-direction:column}.split-heading{display:grid}.data-toolbar,.two-column-toolbar{grid-template-columns:1fr}.users-table,.users-table thead,.users-table tbody,.users-table tr,.users-table th,.users-table td{display:block}.users-table thead{display:none}.users-table tr{border-bottom:1px solid #e5e7eb;padding:12px 14px}.users-table td{border-bottom:0;display:grid;gap:4px;padding:9px 0}.users-table td:before{color:#6b7280;content:attr(data-label);font-size:12px;font-weight:800;text-transform:uppercase}.modal-backdrop{align-items:flex-end;padding:12px}.modal-panel{max-height:calc(100vh - 24px)}.user-form{grid-template-columns:1fr;padding:18px}.modal-actions{display:grid}}
