/* API Keys Page Styles */

.api-keys-page {
    padding: 6rem 0 2rem 0;
}

/* Full width container */
.container-wide {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 2rem;
}

/* Page Header */
.api-keys-page .page-header {
    margin-bottom: 2rem;
}

.api-keys-page .back-link {
    display: inline-block;
    color: rgb(var(--color-text-secondary));
    text-decoration: none;
    margin-bottom: 0.5rem;
    font-size: 0.9rem;
    transition: color 0.2s;
}

.api-keys-page .back-link:hover {
    color: var(--color-primary);
}

.api-keys-page h1 {
    margin: 0;
    font-size: 1.75rem;
    color: rgb(var(--color-text));
}

/* Two Column Side-by-Side Layout */
.api-keys-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    align-items: start;
}

@media (max-width: 1100px) {
    .api-keys-columns {
        grid-template-columns: 1fr;
    }
}

.api-keys-column {
    min-width: 0;
}

/* Service Keys Section */
.service-keys-section {
    margin-top: 2rem;
}

/* Environment Tabs */
.env-tabs {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid rgba(var(--color-border), var(--border-opacity));
    padding-bottom: 0.5rem;
}

.env-tab {
    padding: 0.5rem 1rem;
    background: transparent;
    border: 1px solid rgba(var(--color-border), var(--border-opacity));
    border-radius: var(--radius-default);
    color: rgb(var(--color-text-secondary));
    cursor: pointer;
    font-size: 0.875rem;
    font-weight: 500;
    transition: all 0.2s ease;
}

.env-tab:hover {
    background: rgba(var(--color-primary), 0.1);
    color: rgb(var(--color-text));
}

.env-tab.active {
    background: rgba(var(--color-primary), 0.15);
    border-color: rgb(var(--color-primary));
    color: rgb(var(--color-primary));
}

/* Service Keys List */
.service-keys-list {
    display: grid;
    gap: 1rem;
}

.service-key-card {
    background: rgba(var(--color-surface), 0.4);
    border: 1px solid rgba(var(--color-border), var(--border-opacity));
    border-radius: var(--radius-lg);
    padding: 1rem;
}

.service-key-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.75rem;
}

.service-key-name {
    font-weight: 600;
    font-size: 1rem;
    color: rgb(var(--color-text));
}

.service-key-id {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.75rem;
    color: rgb(var(--color-text-secondary));
}

.service-key-connections {
    margin-top: 0.5rem;
}

.service-key-connections .table {
    font-size: 0.85rem;
    margin-bottom: 0;
}

.service-key-connections .table th {
    font-size: 0.7rem;
    padding: 0.5rem;
    background: rgba(var(--color-surface), 0.5);
}

.service-key-connections .table td {
    padding: 0.5rem;
}

.bootstrap-badge {
    display: inline-block;
    padding: 0.15rem 0.4rem;
    background: rgba(var(--color-success), 0.15);
    color: rgb(var(--color-success));
    border-radius: var(--radius-default);
    font-size: 0.65rem;
    font-weight: 600;
    text-transform: uppercase;
    margin-left: 0.5rem;
}

/* Empty state for service keys */
.service-keys-empty {
    text-align: center;
    padding: 2rem;
    color: rgb(var(--color-text-secondary));
    font-style: italic;
}

/* Responsive container */
@media (max-width: 768px) {
    .container-wide {
        padding: 0 1rem;
    }

    .api-keys-page {
        padding: 5rem 0 1.5rem 0;
    }

    .api-keys-page h1 {
        font-size: 1.5rem;
    }

    .env-tabs {
        flex-wrap: wrap;
    }
}
