:root{--color-brand-blue:#1b52d4;--color-brand-blue-light:#eff6ff;--color-brand-blue-hover:#1642b0;--color-white:#fff;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-300:#d1d5db;--color-gray-500:#6b7280;--color-gray-700:#374151;--color-gray-900:#111827;--color-alert-amber-bg:#fef3c7;--color-alert-amber-text:#92400e;--color-alert-pink-bg:#fce7f3;--color-alert-pink-text:#9d174d;--font-sans:"Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;font-family:var(--font-sans);color:var(--color-gray-700);background:var(--color-white);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}*,:before,:after{box-sizing:border-box}body{margin:0}h1,h2,h3,h4{font-family:var(--font-sans);color:var(--color-gray-900);margin:0}p{margin:0}#root{min-height:100svh}.splash{min-height:100svh;color:var(--color-gray-500);justify-content:center;align-items:center;font-size:15px;display:flex}.login-container{background:var(--color-gray-50);justify-content:center;align-items:center;min-height:100svh;padding:20px;display:flex}.login-card{background:var(--color-white);border:1px solid var(--color-gray-300);text-align:center;border-radius:12px;width:100%;max-width:380px;padding:40px 32px;box-shadow:0 4px 16px #00000014}.login-logo{background:var(--color-brand-blue);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 16px;font-size:22px;font-weight:700;display:flex}.login-card h1{letter-spacing:-.5px;color:var(--color-gray-900);margin:0 0 4px;font-size:24px;font-weight:600}.login-subtitle{color:var(--color-gray-500);margin:0 0 28px;font-size:14px}.field{text-align:left;margin-bottom:14px}.field label{color:var(--color-gray-700);margin-bottom:5px;font-size:13px;font-weight:500;display:block}.field input{border:1px solid var(--color-gray-300);width:100%;font-size:14px;font-family:var(--font-sans);background:var(--color-white);color:var(--color-gray-900);border-radius:6px;padding:9px 12px;transition:border-color .15s}.field input:focus{border-color:var(--color-brand-blue);outline:none;box-shadow:0 0 0 3px #1b52d41f}.login-card button[type=submit]{background:var(--color-brand-blue);color:#fff;width:100%;font-size:14px;font-weight:500;font-family:var(--font-sans);cursor:pointer;border:none;border-radius:6px;margin-top:8px;padding:10px;transition:background .15s}.login-card button[type=submit]:hover{background:var(--color-brand-blue-hover)}.login-card button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.app-container{flex-direction:column;min-height:100svh;display:flex}.app-header{border-bottom:1px solid var(--color-gray-300);background:var(--color-white);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex}.header-brand{align-items:center;gap:10px;display:flex}.header-logo{background:var(--color-brand-blue);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;font-weight:700;display:flex}.header-title{color:var(--color-gray-900);letter-spacing:-.3px;font-size:16px;font-weight:600}.header-right{align-items:center;gap:14px;display:flex}.user-label{color:var(--color-gray-500);font-size:13px}.logout-btn{font-size:13px;font-family:var(--font-sans);border:1px solid var(--color-gray-300);color:var(--color-gray-700);cursor:pointer;background:0 0;border-radius:6px;padding:5px 12px;transition:background .15s,border-color .15s}.logout-btn:hover{background:var(--color-gray-50);border-color:var(--color-gray-500)}.app-body{flex:1;display:flex;overflow:hidden}.app-sidebar{background:var(--color-white);border-right:1px solid var(--color-gray-300);flex-shrink:0;width:220px;padding:12px 0;overflow-y:auto}.sidebar-group-label{color:var(--color-gray-500);letter-spacing:.06em;text-transform:uppercase;padding:16px 16px 4px;font-size:11px;font-weight:600}.sidebar-item{color:var(--color-gray-700);cursor:pointer;text-align:left;width:100%;font-size:14px;font-weight:400;font-family:var(--font-sans);background:0 0;border:none;border-radius:0;align-items:center;gap:8px;padding:8px 16px;transition:background .1s;display:flex}.sidebar-item:hover{background:var(--color-gray-50)}.sidebar-item.active{background:var(--color-brand-blue-light);color:var(--color-brand-blue);font-weight:500}.sidebar-item-icon{opacity:.75;flex-shrink:0;width:18px;height:18px}.sidebar-item.active .sidebar-item-icon{opacity:1}.app-main{background:var(--color-white);flex:1;padding:28px 32px;overflow-y:auto}.page-heading{color:var(--color-gray-900);margin:0 0 20px;font-size:20px;font-weight:600}.count-badge{color:var(--color-gray-500);margin-left:8px;font-size:13px;font-weight:400;display:inline-block}.status-msg{color:var(--color-gray-500);padding:12px 0;font-size:14px}.error-msg{color:#dc2626;padding:12px 0;font-size:14px}.error{color:#dc2626;text-align:left;margin:8px 0 0;font-size:13px}.table-wrapper{border:1px solid var(--color-gray-300);border-radius:8px;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead tr{background:var(--color-gray-50)}th{text-align:left;color:var(--color-gray-700);border-bottom:1px solid var(--color-gray-300);white-space:nowrap;padding:10px 16px;font-size:13px;font-weight:500}td{border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-700);padding:10px 16px}tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--color-brand-blue-light)}.role-badge{border-radius:9999px;padding:2px 9px;font-size:12px;font-weight:500;display:inline-block}.role-badge.admin{background:var(--color-brand-blue-light);color:var(--color-brand-blue)}.role-badge.viewer{background:var(--color-gray-100);color:var(--color-gray-700)}
