*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f0f2f5;min-height:100vh;color:#333}.container{max-width:1200px;margin:0 auto;padding:2rem}.hidden{display:none!important}.header{background:#fff;box-shadow:0 2px 4px #00000014;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:2rem}.header h1{color:#1a73e8;font-size:1.5rem;white-space:nowrap}.tab-nav{display:flex;gap:.25rem;background:#f0f2f5;border-radius:8px;padding:.25rem}.tab-btn{padding:.5rem 1.25rem;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;background:transparent;color:#666;transition:all .2s}.tab-btn:hover{color:#333}.tab-btn.active{background:#fff;color:#1a73e8;box-shadow:0 1px 3px #0000001a}.tab-content{display:none}.tab-content.active{display:block}.login-card{background:#fff;border-radius:12px;padding:3rem;box-shadow:0 10px 40px #0000001f;max-width:400px;margin:10vh auto}.login-card h1{color:#1a73e8;margin-bottom:2rem;text-align:center}.form-group{margin-bottom:1.5rem;flex:1}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#555}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s;font-family:inherit}.form-group textarea{resize:vertical;min-height:100px;font-family:Courier New,monospace;font-size:.875rem;line-height:1.5}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#1a73e8}.form-group input[readonly]{background:#f5f5f5;color:#888}.form-row{display:flex;gap:1rem;margin-bottom:1rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:#1a73e8;color:#fff}.btn-primary:hover{background:#1557b0;box-shadow:0 2px 8px #1a73e84d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-danger{background:#dc3545;color:#fff;padding:.5rem 1rem;font-size:.875rem}.btn-danger:hover{background:#c82333}.btn-success{background:#28a745;color:#fff;padding:.5rem 1rem;font-size:.875rem}.btn-success:hover{background:#218838}.btn-warning{background:#ffc107;color:#333;padding:.5rem 1rem;font-size:.875rem}.btn-warning:hover{background:#e0a800}.btn-small{padding:.5rem 1rem;font-size:.875rem}.error-message{color:#dc3545;background:#f8d7da;border:1px solid #f5c6cb;padding:.75rem;border-radius:8px;margin-top:1rem}.success-message{color:#155724;background:#d4edda;border:1px solid #c3e6cb;padding:.75rem;border-radius:8px;margin-top:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000000f;text-align:center}.stat-card h3{color:#666;font-size:.8rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:1rem}.stat-value{font-size:2.5rem;font-weight:700;color:#1a73e8}.section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000000f;margin-bottom:2rem}.section h2{color:#333;margin-bottom:1.5rem;font-size:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.section-header h2{margin-bottom:0}.section-desc{color:#666;font-size:.875rem;margin-bottom:1.5rem;line-height:1.5}.code-form{max-width:800px}.loading{text-align:center;padding:2rem;color:#666}.codes-list{display:flex;flex-direction:column;gap:1rem}.code-item{border:2px solid #e0e0e0;border-radius:8px;padding:1.5rem;transition:border-color .2s}.code-item:hover{border-color:#1a73e8}.code-item.inactive{opacity:.6;background:#f8f9fa}.code-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.code-title{flex:1}.code-name{font-size:1.25rem;font-weight:700;color:#333;margin-bottom:.25rem;font-family:Courier New,monospace}.code-description{color:#666;font-size:.875rem}.code-status{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.code-status.active{background:#d4edda;color:#155724}.code-status.inactive{background:#f8d7da;color:#721c24}.code-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem;padding:1rem;background:#f8f9fa;border-radius:6px}.code-detail{display:flex;flex-direction:column}.code-detail-label{font-size:.75rem;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.code-detail-value{font-size:1rem;font-weight:600;color:#333}.code-actions{display:flex;gap:.5rem;flex-wrap:wrap}.config-list{display:flex;flex-direction:column;gap:1rem}.config-item{border:2px solid #e0e0e0;border-radius:8px;padding:1.25rem;transition:border-color .2s}.config-item:hover{border-color:#1a73e8}.config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.config-key{font-family:Courier New,monospace;font-size:1rem;font-weight:700;color:#1a73e8}.config-actions-row{display:flex;gap:.5rem}.config-description{color:#666;font-size:.8125rem;margin-bottom:.5rem}.config-value-preview{background:#f8f9fa;border-radius:6px;padding:.75rem 1rem;font-family:Courier New,monospace;font-size:.8125rem;color:#444;white-space:pre-wrap;word-break:break-all;line-height:1.4;margin-bottom:.5rem}.config-meta{font-size:.75rem;color:#999}.modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center}.modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080}.modal-content{position:relative;background:#fff;border-radius:12px;padding:2rem;width:90%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h3{font-size:1.25rem;color:#333}.modal-close{background:none;border:none;font-size:1.75rem;color:#999;cursor:pointer;padding:0 .5rem;line-height:1}.modal-close:hover{color:#333}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.health-status{margin-top:1.5rem}.health-overall{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;margin-bottom:1.5rem;flex-wrap:wrap}.health-label{font-weight:600;color:#333;font-size:1.125rem}.status-badge{display:inline-block;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-badge.status-healthy{background:#d4edda;color:#155724;border:2px solid #28a745}.status-badge.status-degraded{background:#fff3cd;color:#856404;border:2px solid #ffc107}.status-badge.status-unhealthy{background:#f8d7da;color:#721c24;border:2px solid #dc3545}.health-timestamp{color:#666;font-size:.875rem;margin-left:auto}.health-checks{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.health-check-item{border:2px solid #e0e0e0;border-radius:8px;padding:1.5rem;transition:all .2s}.health-check-item:hover{border-color:#1a73e8;box-shadow:0 2px 8px #1a73e81a}.health-check-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0}.health-check-header h4{color:#333;font-size:1rem;margin:0}.health-check-details{display:flex;flex-direction:column;gap:.5rem}.health-message{color:#666;font-size:.875rem;line-height:1.5}.health-response-time{color:#1a73e8;font-size:.875rem;font-weight:600;font-family:Courier New,monospace}@media (max-width: 768px){.header{flex-wrap:wrap;gap:1rem}.form-row{flex-direction:column}.code-header{flex-direction:column;gap:1rem}.code-details{grid-template-columns:1fr}.health-overall{flex-direction:column;align-items:flex-start}.health-timestamp{margin-left:0}.health-checks{grid-template-columns:1fr}.config-header{flex-direction:column;gap:.75rem;align-items:flex-start}.modal-content{width:95%;padding:1.5rem}}
