/* Dashboard */

.dash {
    --dash-bg: color-mix(in srgb, var(--surface) 58%, white 42%);
    --dash-bg-soft: color-mix(in srgb, var(--surface-2) 66%, white 34%);
    --dash-panel: color-mix(in srgb, var(--surface) 88%, white 12%);
    --dash-line: color-mix(in srgb, var(--border) 68%, transparent);
    --dash-line-strong: color-mix(in srgb, var(--border-2) 72%, transparent);
    --dash-ink: var(--fg);
    --dash-muted: var(--muted);
    --dash-soft-muted: var(--very-muted);
    --dash-primary: #111827;
    --dash-primary-hover: #020617;
    --dash-primary-ink: #ffffff;
    --dash-success: #16a34a;
    --dash-shadow: 0 1px 2px rgba(15, 23, 42, .06), 0 12px 30px rgba(15, 23, 42, .08);
    padding: 30px 0 64px;
}

body.theme-dark .dash {
    --dash-bg: color-mix(in srgb, var(--surface) 92%, black 8%);
    --dash-bg-soft: color-mix(in srgb, var(--surface-2) 88%, black 12%);
    --dash-panel: color-mix(in srgb, var(--surface) 96%, white 4%);
    --dash-line: color-mix(in srgb, var(--border-2) 86%, transparent);
    --dash-line-strong: color-mix(in srgb, var(--border-2) 100%, transparent);
    --dash-primary: #e5e7eb;
    --dash-primary-hover: #ffffff;
    --dash-primary-ink: #0f172a;
    --dash-shadow: 0 1px 2px rgba(0, 0, 0, .24), 0 18px 34px rgba(0, 0, 0, .24);
}

.dash .container {
    max-width: 1320px;
    display: grid;
    gap: 18px;
}

.dash :is(h1, h2, h3, p) {
    margin-top: 0;
}

.dash-command {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(520px, auto);
    gap: 30px;
    align-items: end;
    padding: 18px 0 8px;
}

.dash-title {
    min-width: 0;
}

.eyebrow-text,
.panel-kicker {
    margin: 0 0 7px;
    color: var(--dash-soft-muted);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: .11em;
    line-height: 1;
    text-transform: uppercase;
}

.dash-title h1 {
    margin: 0;
    font-size: clamp(34px, 3vw, 46px);
    line-height: .98;
    letter-spacing: -.045em;
}

.dash-title .muted {
    margin: 11px 0 0;
    color: var(--dash-muted);
    font-size: 15px;
}

.dash-metrics {
    display: grid;
    grid-template-columns: 118px 118px minmax(260px, 1fr);
    overflow: hidden;
    border: 1px solid var(--dash-line);
    border-radius: 8px;
    background: color-mix(in srgb, var(--dash-bg) 78%, transparent);
    box-shadow: 0 1px 0 rgba(255, 255, 255, .34) inset;
}

.metric-item {
    min-width: 0;
    padding: 13px 15px;
    border-left: 1px solid var(--dash-line);
}

.metric-item:first-child {
    border-left: 0;
}

.metric-item span {
    display: block;
    margin-bottom: 5px;
    color: var(--dash-soft-muted);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.metric-item strong {
    display: block;
    color: var(--dash-ink);
    font-size: 24px;
    line-height: 1;
}

.metric-item code {
    display: block;
    overflow: hidden;
    color: var(--dash-ink);
    font-size: 13px;
    line-height: 1.35;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dash-workspace {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 348px;
    gap: 18px;
    align-items: start;
}

.dash .panel,
.dash-rail .card.usage {
    border: 1px solid var(--dash-line);
    border-radius: 8px;
    background: var(--dash-bg);
    box-shadow: var(--dash-shadow);
}

.dash .panel {
    padding: 18px;
}

.panel-head,
.dash-rail .card.usage .card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}

.panel-head h2,
.rail-head h3,
.dash-rail .card.usage h3 {
    margin: 0;
    color: var(--dash-ink);
    font-size: 20px;
    letter-spacing: -.025em;
}

.status-pill,
.key-ready,
.svc-state,
.dash .tag,
.tag.subtle {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    border: 1px solid var(--dash-line);
    border-radius: 999px;
    padding: 3px 9px;
    background: color-mix(in srgb, var(--dash-bg-soft) 72%, transparent);
    color: var(--dash-muted);
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    white-space: nowrap;
}

.status-pill {
    color: var(--dash-primary);
}

.service-row .tag {
    border-color: color-mix(in srgb, var(--svc-color) 22%, transparent);
    background: color-mix(in srgb, var(--svc-color) 8%, transparent);
    color: var(--dash-ink);
}

.key-ready,
.svc-state.live {
    border-color: color-mix(in srgb, var(--dash-success) 28%, transparent);
    background: color-mix(in srgb, var(--dash-success) 10%, transparent);
    color: var(--dash-success);
}

.svc-state.idle {
    color: var(--dash-soft-muted);
}

.key-table {
    overflow: hidden;
    border: 1px solid var(--dash-line);
    border-radius: 8px;
    background: color-mix(in srgb, var(--dash-panel) 70%, transparent);
}

.key-row {
    display: grid;
    grid-template-columns: minmax(190px, 240px) minmax(220px, 1fr) auto;
    gap: 16px;
    align-items: center;
    padding: 15px;
    border-top: 1px solid var(--dash-line);
}

.key-row:first-child {
    border-top: 0;
}

.key-service,
.row-meta,
.key-actions,
.service-main,
.service-actions {
    display: flex;
    align-items: center;
}

.key-service {
    min-width: 0;
    gap: 12px;
}

.status-light {
    width: 9px;
    height: 9px;
    border-radius: 999px;
    background: var(--dash-success);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--dash-success) 12%, transparent);
    flex: 0 0 auto;
}

.key-service-copy {
    min-width: 0;
}

.row-meta {
    gap: 7px;
    flex-wrap: wrap;
    margin-bottom: 5px;
}

.key-service h3,
.service-main h3 {
    margin: 0;
    color: var(--dash-ink);
    font-size: 16px;
    line-height: 1.2;
}

.key-token {
    min-width: 0;
}

.key-token > span,
.service-use > span {
    display: block;
    margin-bottom: 5px;
    color: var(--dash-soft-muted);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: .06em;
    line-height: 1;
    text-transform: uppercase;
}

.key-token code {
    display: block;
    overflow: hidden;
    width: 100%;
    padding: 9px 10px;
    border: 1px solid var(--dash-line);
    border-radius: 8px;
    background: color-mix(in srgb, var(--dash-bg-soft) 78%, transparent);
    color: var(--dash-ink);
    font-size: 13px;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.key-actions,
.service-actions {
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

.dash .btn {
    min-height: 34px;
    border-radius: 8px;
    padding: 8px 13px;
    box-shadow: none;
    transform: none;
}

.dash .btn:hover {
    box-shadow: none;
    transform: none;
}

.dash .btn.primary {
    border-color: var(--dash-primary);
    background: var(--dash-primary);
    color: var(--dash-primary-ink);
}

.dash .btn.primary:hover {
    border-color: var(--dash-primary-hover);
    background: var(--dash-primary-hover);
    filter: none;
}

.dash .btn.primary::after {
    display: none;
}

.dash .btn.ghost {
    border-color: var(--dash-line-strong);
    background: transparent;
    color: var(--dash-ink);
}

.dash .btn.ghost:hover {
    background: color-mix(in srgb, var(--dash-bg-soft) 82%, transparent);
}

.dash .btn.sm {
    min-height: 32px;
    padding: 7px 11px;
}

.dash button:disabled {
    cursor: not-allowed;
    opacity: .58;
}

.quick {
    grid-column: 1 / -1;
    margin-top: 0;
    padding-top: 12px;
    border-top: 1px solid var(--dash-line);
}

.quick summary {
    cursor: pointer;
    color: var(--dash-ink);
    font-size: 13px;
    font-weight: 850;
}

.quick[open] summary {
    margin-bottom: 10px;
}

.fineprint {
    color: var(--dash-soft-muted);
    font-size: 12px;
    line-height: 1.55;
}

.fineprint.success,
.error-text {
    font-size: 12px;
    font-weight: 800;
}

.fineprint.success {
    color: var(--dash-success);
}

.error-text {
    color: var(--danger);
}

.pg-tip {
    margin-bottom: 10px;
}

.code {
    overflow: auto;
    margin: 0;
    padding: 12px;
    border-radius: 8px;
    background: var(--code-bg);
    color: var(--code-fg);
    font-size: 12px;
    line-height: 1.6;
}

.empty-state {
    display: grid;
    place-items: center;
    min-height: 164px;
    border: 1px dashed var(--dash-line-strong);
    border-radius: 8px;
    background: color-mix(in srgb, var(--dash-bg-soft) 62%, transparent);
    text-align: center;
}

.empty-copy {
    max-width: 360px;
}

.empty-copy h3 {
    margin: 0 0 7px;
    font-size: 18px;
}

.empty-copy p {
    margin: 0;
}

.dash-rail {
    display: grid;
    gap: 18px;
}

.dash-rail .card.usage {
    padding: 18px;
}

.dash-rail .card.usage .card-head {
    margin-bottom: 14px;
}

.dash-rail .card.usage small {
    color: var(--dash-soft-muted);
    font-size: 12px;
    line-height: 1.4;
    text-align: right;
}

.dash-rail .usage-list {
    display: grid;
    gap: 13px;
}

.dash-rail .usage-row {
    display: grid;
    gap: 6px;
}

.dash-rail .usage-top,
.dash-rail .meta {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.dash-rail .feature,
.dash-rail .nums {
    color: var(--dash-ink);
    font-size: 13px;
    font-weight: 850;
}

.dash-rail .bar {
    overflow: hidden;
    height: 7px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--dash-bg-soft) 82%, transparent);
}

.dash-rail .fill {
    height: 100%;
    border-radius: inherit;
    background: var(--dash-primary);
}

.dash-rail .meta {
    color: var(--dash-soft-muted);
    font-size: 12px;
}

.connection-card {
    display: grid;
    gap: 14px;
}

.connection-list {
    display: grid;
    gap: 12px;
    margin: 0;
}

.connection-list div {
    display: grid;
    gap: 4px;
}

.connection-list dt {
    color: var(--dash-soft-muted);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.connection-list dd {
    margin: 0;
    min-width: 0;
    overflow-wrap: anywhere;
    color: var(--dash-ink);
    font-size: 13px;
}

.connection-list code {
    display: inline-flex;
    width: fit-content;
    padding: 5px 7px;
    border: 1px solid var(--dash-line);
    border-radius: 6px;
    background: color-mix(in srgb, var(--dash-bg-soft) 82%, transparent);
}

.service-panel {
    display: grid;
    gap: 14px;
}

.service-table {
    overflow: hidden;
    border: 1px solid var(--dash-line);
    border-radius: 8px;
    background: color-mix(in srgb, var(--dash-panel) 70%, transparent);
}

.service-row {
    --svc-color: var(--dash-primary);
    position: relative;
    display: grid;
    grid-template-columns: minmax(320px, 1.25fr) minmax(220px, .8fr) minmax(150px, .55fr) auto;
    gap: 18px;
    align-items: center;
    min-height: 112px;
    padding: 16px 16px 16px 18px;
    border-top: 1px solid var(--dash-line);
}

.service-row:first-child {
    border-top: 0;
}

.service-row::before {
    content: "";
    position: absolute;
    inset: 14px auto 14px 0;
    width: 3px;
    border-radius: 999px;
    background: var(--svc-color);
    opacity: .72;
}

.service-row.on {
    background: color-mix(in srgb, var(--svc-color) 4%, transparent);
}

.service-main {
    min-width: 0;
    gap: 12px;
}

.svc-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 1px solid color-mix(in srgb, var(--svc-color) 24%, transparent);
    border-radius: 8px;
    background: color-mix(in srgb, var(--svc-color) 9%, transparent);
    color: var(--svc-color);
    font-size: 15px;
    font-weight: 900;
    flex: 0 0 auto;
}

.service-main h3 {
    margin-bottom: 5px;
}

.service-main p,
.service-use p,
.service-status span {
    margin: 0;
    color: var(--dash-muted);
    font-size: 13px;
    line-height: 1.45;
}

.service-use {
    min-width: 0;
}

.service-status {
    display: grid;
    gap: 3px;
}

.service-status strong {
    color: var(--dash-ink);
    font-size: 13px;
    line-height: 1.25;
}

.service-actions {
    min-width: max-content;
}

.service-actions .error-text {
    flex-basis: 100%;
    text-align: right;
}

.cat-search {
    --svc-color: #2563eb;
}

.cat-apps {
    --svc-color: #0891b2;
}

.cat-sports {
    --svc-color: #16a34a;
}

.cat-finance {
    --svc-color: #b45309;
}

.cat-other {
    --svc-color: var(--dash-primary);
}

.sk-line,
.sk-btn,
.skeleton .status-light {
    position: relative;
    overflow: hidden;
    border-radius: 8px;
    background: color-mix(in srgb, var(--dash-bg-soft) 80%, transparent);
}

.sk-line::after,
.sk-btn::after,
.skeleton .status-light::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .24), transparent);
    animation: dash-shimmer 1.35s linear infinite;
}

.sk-line {
    width: 128px;
    height: 13px;
}

.sk-line.short {
    width: 76px;
    margin-top: 7px;
}

.sk-line.medium {
    width: 88px;
}

.sk-line.long {
    width: min(360px, 100%);
    margin-top: 7px;
}

.sk-btn {
    width: 66px;
    height: 32px;
}

.sk-btn.wide {
    width: 126px;
}

@keyframes dash-shimmer {
    to {
        transform: translateX(100%);
    }
}

@media (max-width: 1180px) {
    .dash-command,
    .dash-workspace {
        grid-template-columns: 1fr;
    }

    .dash-metrics {
        grid-template-columns: repeat(2, 118px) minmax(240px, 1fr);
    }

    .dash-rail {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .service-row {
        grid-template-columns: minmax(300px, 1.2fr) minmax(220px, 1fr);
        grid-template-areas:
            "main use"
            "status actions";
    }

    .service-main {
        grid-area: main;
    }

    .service-use {
        grid-area: use;
    }

    .service-status {
        grid-area: status;
    }

    .service-actions {
        grid-area: actions;
    }
}

@media (max-width: 820px) {
    .dash {
        padding-top: 20px;
    }

    .dash-metrics,
    .dash-rail {
        grid-template-columns: 1fr;
    }

    .metric-item {
        border-left: 0;
        border-top: 1px solid var(--dash-line);
    }

    .metric-item:first-child {
        border-top: 0;
    }

    .key-row {
        grid-template-columns: 1fr;
    }

    .key-actions,
    .service-actions {
        justify-content: flex-start;
    }

    .service-row {
        grid-template-columns: 1fr;
        grid-template-areas:
            "main"
            "use"
            "status"
            "actions";
        gap: 12px;
    }
}

@media (max-width: 560px) {
    .dash .container {
        gap: 14px;
    }

    .dash-title h1 {
        font-size: 32px;
    }

    .dash .panel,
    .dash-rail .card.usage {
        padding: 14px;
    }

    .panel-head {
        display: grid;
    }

    .service-row {
        padding: 14px 14px 14px 16px;
    }

    .key-actions > *,
    .service-actions > * {
        flex: 1 1 auto;
    }
}
