.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-box h1{text-align:center;margin-bottom:.5rem;color:#1e3a8a}.subtitle{text-align:center;color:#6b7280;margin-bottom:2rem;font-size:.875rem}.form-group input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.error-message{background:#fee2e2;color:#dc2626;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem}.login-btn{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-btn:disabled{opacity:.6;cursor:not-allowed}.dashboard h1{margin-bottom:2rem;color:#1e3a8a}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.stat-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:1rem;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px}.stat-content h3{font-size:.875rem;color:#6b7280;margin-bottom:.5rem;font-weight:500}.stat-value{font-size:1.75rem;font-weight:700;color:#1e3a8a;margin:0}.loading,.error{text-align:center;padding:2rem;color:#6b7280}.error{color:#dc2626}.clients{width:100%}.clients-table{width:100%;border-collapse:collapse}.clients-table thead{background:#f3f4f6}.clients-table th{padding:1rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.clients-table td{padding:1rem;border-top:1px solid #e5e7eb;color:#6b7280}.clients-table tbody tr:hover{background:#f9fafb}.clients-table code{background:#f3f4f6;padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.875rem}.role-badge,.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.role-application_client{background:#dbeafe;color:#1e40af}.role-metrics_collector{background:#fce7f3;color:#9f1239}.status-select{padding:.5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;cursor:pointer;background:#fff}.status-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.metrics{width:100%}.metrics h1{margin-bottom:2rem;color:#1e3a8a}.table-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.metrics-table{width:100%;border-collapse:collapse}.metrics-table thead{background:#f3f4f6}.metrics-table th{padding:1rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.metrics-table td{padding:1rem;border-top:1px solid #e5e7eb;color:#6b7280}.metrics-table tbody tr:hover{background:#f9fafb}.metrics-table code{background:#f3f4f6;padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.875rem}.analytics{width:100%}.analytics h1{margin-bottom:2rem;color:#1e3a8a}.charts-grid{display:grid;grid-template-columns:1fr;gap:2rem}.chart-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.chart-card h2{margin-bottom:1.5rem;color:#374151;font-size:1.25rem}.models{width:100%}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{color:#1e3a8a}.error-message{background:#fee2e2;color:#dc2626;padding:1rem;border-radius:6px;margin-bottom:1rem}.provider-selector{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;display:flex;align-items:center;gap:1rem}.provider-selector label{font-weight:600;color:#374151}.select-input{flex:1;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;cursor:pointer}.select-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.models-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.provider-info{padding:2rem;border-bottom:1px solid #e5e7eb;background:#f9fafb}.provider-info h2{margin-bottom:.5rem;color:#1e3a8a}.provider-description{color:#6b7280;margin-bottom:1rem}.provider-status{display:flex;gap:.5rem}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-active{background:#d1fae5;color:#065f46}.status-disabled{background:#fee2e2;color:#991b1b}.models-list{padding:2rem}.empty-state{text-align:center;padding:3rem;color:#9ca3af}.models-table{width:100%;border-collapse:collapse}.models-table thead{background:#f3f4f6}.models-table th{padding:1rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.models-table td{padding:1rem;border-top:1px solid #e5e7eb;color:#6b7280}.models-table tbody tr:hover{background:#f9fafb}.models-table code{background:#f3f4f6;padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.875rem}.action-buttons{display:flex;gap:.5rem}.btn-edit,.btn-delete{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-edit{background:#dbeafe;color:#1e40af}.btn-edit:hover{background:#bfdbfe}.btn-delete{background:#fee2e2;color:#dc2626}.btn-delete:hover{background:#fecaca}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;color:#1e3a8a}.modal-close{background:none;border:none;font-size:2rem;color:#6b7280;cursor:pointer;line-height:1;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f3f4f6;color:#374151}.modal-content form{padding:1.5rem}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{background:#f3f4f6;cursor:not-allowed}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.playground{width:100%;height:calc(100vh - 4rem);display:flex;flex-direction:column}.playground-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.playground-header h1{color:#1e3a8a;margin:0}.playground-container{display:flex;gap:1.5rem;flex:1;min-height:0}.playground-sidebar{width:300px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.config-section h3,.response-info h3{margin:0 0 1rem;color:#1e3a8a;font-size:1.125rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#374151;font-weight:500;font-size:.875rem}.select-input,.textarea-input,.number-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s;font-family:inherit}.select-input:focus,.textarea-input:focus,.number-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.select-input:disabled{background:#f3f4f6;cursor:not-allowed}.textarea-input{resize:vertical;min-height:60px}.slider-input{width:100%;height:6px;border-radius:3px;background:#e5e7eb;outline:none;-webkit-appearance:none}.slider-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer}.slider-input::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer;border:none}.slider-labels{display:flex;justify-content:space-between;font-size:.75rem;color:#6b7280;margin-top:.25rem}.number-input{width:100%}.response-info{background:#f9fafb;padding:1rem;border-radius:6px;border:1px solid #e5e7eb}.info-item{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.875rem}.info-item:last-child{margin-bottom:0}.info-label{color:#6b7280;font-weight:500}.info-value{color:#374151}.playground-chat{flex:1;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;min-height:0}.messages-container{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.message{display:flex;flex-direction:column;gap:.5rem}.message-user{align-items:flex-end}.message-assistant{align-items:flex-start}.message-system{align-items:center}.message-header{display:flex;align-items:center;gap:.5rem}.message-role{font-size:.75rem;color:#6b7280;font-weight:500}.message-content{max-width:80%;padding:1rem;border-radius:12px;background:#f3f4f6;color:#374151;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.message-user .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.message-assistant .message-content{background:#f3f4f6;color:#374151}.message-system .message-content{background:#fef3c7;color:#92400e;font-style:italic}.message-input{width:100%;max-width:80%;padding:1rem;border:2px solid #d1d5db;border-radius:12px;font-size:1rem;font-family:inherit;resize:vertical;transition:border-color .2s}.message-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.chat-actions{padding:1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.error-message{background:#fee2e2;color:#dc2626;padding:1rem;border-radius:6px;margin:1rem 1.5rem 0}.btn-primary{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:.75rem 1.5rem;background:#f3f4f6;color:#374151;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#e5e7eb}.layout{display:flex;min-height:100vh}.sidebar{width:250px;background:linear-gradient(180deg,#1e3a8a,#1e40af);color:#fff;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000001a}.sidebar-header{padding:2rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h1{font-size:1.5rem;margin-bottom:.25rem}.sidebar-header p{font-size:.875rem;opacity:.8}.nav-menu{list-style:none;padding:1rem 0;flex:1}.nav-menu li{margin:.25rem 0}.nav-menu a{display:block;padding:.75rem 1.5rem;color:#fff;text-decoration:none;transition:all .2s;border-left:3px solid transparent}.nav-menu a:hover{background:#ffffff1a;border-left-color:#60a5fa}.nav-menu a.active{background:#ffffff26;border-left-color:#60a5fa;font-weight:600}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.logout-btn{width:100%;padding:.75rem;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s}.logout-btn:hover{background:#fff3}.content{flex:1;padding:2rem;overflow-y:auto}*{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;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
