.navbar{background-color:#fff;border-bottom:2px solid #e0e0e0;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:1000}.navbar-content{max-width:1200px;margin:0 auto;padding:15px 20px;display:flex;justify-content:space-between;align-items:center}.navbar-brand{font-size:20px;font-weight:700;color:#333;text-decoration:none;transition:color .2s ease}.navbar-brand:hover{color:#4a90e2}.navbar-links{display:flex;gap:20px;align-items:center}.navbar-toggle{display:none;background:transparent;border:1px solid #e0e0e0;border-radius:6px;padding:8px;cursor:pointer}.navbar-toggle-bar{display:block;width:22px;height:2px;background-color:#333;border-radius:2px}.navbar-toggle-bar+.navbar-toggle-bar{margin-top:5px}.navbar-link{color:#333;text-decoration:none;font-size:15px;font-weight:500;padding:8px 16px;border-radius:4px;transition:all .2s ease}.navbar-link:hover{background-color:#f5f5f5;color:#4a90e2}.navbar-link.active{background-color:#4a90e2;color:#fff}.navbar-link.active:hover{background-color:#357abd;color:#fff}@media(max-width:768px){.navbar-content{position:relative}.navbar-toggle{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:0}.navbar-links{position:absolute;top:100%;left:0;right:0;display:none;flex-direction:column;align-items:stretch;gap:8px;padding:12px 16px 16px;background:#fff;border-bottom:2px solid #e0e0e0;box-shadow:0 8px 12px #00000014}.navbar-links.is-open{display:flex}.navbar-link{width:100%;padding:10px 12px}}.login-container{width:100%;max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.login-card{max-width:420px;margin:0 auto;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:2.5rem;box-shadow:0 2px 8px #00000014}.login-card h1{margin:0 0 .5rem;font-size:2rem;color:#2c2c2c}.login-subtitle{margin:0 0 2rem;color:#666}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-form-group{display:flex;flex-direction:column;gap:.5rem}.login-form-group label{font-weight:600;color:#333}.login-form-group input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit}.login-form-group input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.login-form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.login-error{padding:.75rem 1rem;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:4px}.login-submit{padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:4px;background:#007bff;color:#fff;cursor:pointer;transition:opacity .2s}.login-submit:disabled{opacity:.7;cursor:not-allowed}@media(max-width:600px){.login-container{padding:1.5rem 1rem}.login-card{padding:2rem 1.5rem}}.user-management-container{max-width:1000px;margin:0 auto;padding:2rem}.user-management-container h1{text-align:center;margin-bottom:2rem}.user-management-card{background:#fff;border:1px solid #ddd;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.user-form{display:grid;gap:1rem}.roles-section{display:grid;gap:1rem;border-top:1px solid #eee;padding-top:1rem}.roles-group{display:grid;gap:.75rem}.roles-title{font-weight:600;color:#333}.roles-options{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem}.role-checkbox{display:inline-flex;align-items:center;gap:.5rem;font-size:.95rem}.client-roles{display:grid;gap:1rem}.client-role-group{border:1px solid #eee;border-radius:6px;padding:.75rem;display:grid;gap:.5rem}.client-name{font-weight:600;color:#2c2c2c}.user-list-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.user-list{display:flex;flex-direction:column;gap:.75rem}.user-row{display:flex;justify-content:space-between;gap:1rem;padding:.75rem;border:1px solid #eee;border-radius:6px}.user-name{font-weight:600;color:#333}.user-email{color:#666;font-size:.9rem}.user-roles{margin-top:.5rem;color:#555;font-size:.9rem;display:grid;gap:.25rem}.role-line{display:flex;gap:.5rem}.role-label{font-weight:600}.user-meta{color:#999;font-size:.85rem;display:flex;flex-direction:column;align-items:flex-end;gap:.75rem}.error-message{color:#d32f2f;background-color:#ffebee;border:1px solid #ffcdd2}@media(max-width:768px){.user-management-container,.user-management-card{padding:1rem}.user-row{flex-direction:column;align-items:flex-start}.user-list-header{flex-direction:column;align-items:stretch}.form-actions{flex-direction:column}.primary-button,.secondary-button{width:100%}.user-meta{width:100%;align-items:flex-start}}.client-management-container{max-width:1000px;margin:0 auto;padding:2rem}.client-management-container h1{text-align:center;margin-bottom:2rem}.client-management-card{background:#fff;border:1px solid #ddd;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.client-form{display:grid;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-field input:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e21a}.form-actions{display:flex;gap:1rem}.primary-button,.secondary-button{padding:.75rem 1.5rem;font-size:1rem;border-radius:4px;border:none;cursor:pointer;transition:background-color .2s}.primary-button{background-color:#4a90e2;color:#fff}.primary-button:hover:not(:disabled){background-color:#357abd}.secondary-button{background-color:#f0f0f0;color:#333}.secondary-button:hover:not(:disabled){background-color:#e0e0e0}.secondary-button.danger{background-color:#d32f2f;color:#fff}.secondary-button.danger:hover:not(:disabled){background-color:#b71c1c}.primary-button:disabled,.secondary-button:disabled{background-color:#ccc;cursor:not-allowed}.client-list-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.client-list{display:flex;flex-direction:column;gap:1rem}.client-row{display:flex;justify-content:space-between;gap:1rem;padding:1rem;border:1px solid #eee;border-radius:6px}.client-info{flex:1}.client-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.client-name{font-weight:600;color:#333;font-size:1.1rem}.client-meta-text{color:#999;font-size:.85rem}.client-actions{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.api-keys-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.api-keys-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.api-keys-title{font-weight:600;color:#555;font-size:.9rem}.api-key-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;border:1px solid #eee;border-radius:4px;margin-bottom:.5rem;gap:1rem}.api-key-row.inactive{opacity:.6;background-color:#f9f9f9}.api-key-info{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.api-key-value{font-family:monospace;font-size:.85rem;background:#f5f5f5;padding:.25rem .5rem;border-radius:3px}.api-key-status{font-size:.75rem;padding:.125rem .5rem;border-radius:12px}.api-key-status.active{background-color:#e8f5e9;color:#2e7d32}.api-key-status.inactive{background-color:#ffebee;color:#c62828}.api-key-last-used{font-size:.75rem;color:#999}.api-key-actions{display:flex;gap:.5rem}.no-keys-message{font-size:.85rem;color:#999;font-style:italic}.small-button{padding:.375rem .75rem;font-size:.8rem;border-radius:4px;border:1px solid #ddd;background:#fff;cursor:pointer;transition:background-color .2s}.small-button:hover:not(:disabled){background-color:#f5f5f5}.small-button:disabled{opacity:.6;cursor:not-allowed}.small-button.danger{color:#d32f2f;border-color:#ffcdd2}.small-button.danger:hover:not(:disabled){background-color:#ffebee}.new-key-alert{background-color:#e8f5e9;border:1px solid #a5d6a7;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.new-key-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.new-key-warning{color:#2e7d32;font-size:.9rem;margin-bottom:.75rem}.new-key-value{display:flex;gap:.5rem;align-items:center;background:#fff;padding:.75rem;border-radius:4px;border:1px solid #c8e6c9}.new-key-value code{flex:1;word-break:break-all;font-family:monospace;font-size:.9rem}.status-message,.empty-message,.error-message{text-align:center;padding:1rem;border-radius:4px}.error-message{color:#d32f2f;background-color:#ffebee;border:1px solid #ffcdd2;margin-bottom:1.5rem}.status-message,.empty-message{color:#666;background-color:#fafafa;border:1px solid #eee}@media(max-width:768px){.client-management-container,.client-management-card{padding:1rem}.client-row{flex-direction:column;align-items:flex-start}.client-header{flex-direction:column;align-items:flex-start;gap:.25rem}.client-actions{flex-direction:row;width:100%;margin-top:1rem}.client-list-header{flex-direction:column;align-items:stretch}.form-actions{flex-direction:column}.primary-button,.secondary-button{width:100%}.api-key-row{flex-direction:column;align-items:flex-start;gap:.75rem}.api-key-actions{width:100%;justify-content:flex-start}.new-key-value{flex-direction:column;align-items:stretch}.new-key-value code{text-align:center}}.app-container{min-height:100vh;display:flex;flex-direction:column}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;background-color:#f5f5f5}#root{width:100%;min-height:100vh}
