/*
 * Congress Developer Portal — neutral defaults.
 *
 * All visible values map to CSS variables on :root. To re-skin with the real
 * MinakiLabs tokens later, override the variables in this :root block — no
 * template edits required.
 */
:root {
    /* color */
    --bg:           #f7f6f3;
    --surface:      #ffffff;
    --surface-2:    #fbfaf7;
    --text:         #1a1a1a;
    --text-muted:   #6e6e6e;
    --accent:       #1a4f4f;
    --accent-hover: #226e6e;
    --accent-text:  #ffffff;
    --border:       #e6e3dc;
    --code-bg:      #f0ede5;
    --error-bg:     #fdf0ed;
    --error-border: #f2c2b5;
    --error-text:   #8a2d1a;

    /* type */
    --font-sans:    -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
    --font-mono:    ui-monospace, "SF Mono", "Cascadia Mono", "JetBrains Mono", Consolas, monospace;

    /* space */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 1rem;
    --space-4: 1.5rem;
    --space-5: 2.5rem;
    --space-6: 4rem;

    /* shape */
    --radius-sm: 6px;
    --radius-md: 10px;
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--text);
    font-family: var(--font-sans);
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

code {
    font-family: var(--font-mono);
    background: var(--code-bg);
    padding: 1px 5px;
    border-radius: 4px;
    font-size: 0.94em;
}

.portal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3) var(--space-5);
    border-bottom: 1px solid var(--border);
    background: var(--surface);
}

.brand-link {
    color: var(--text);
    font-weight: 600;
    font-size: 0.95rem;
    letter-spacing: 0.01em;
    text-decoration: none;
}
.brand-divider { color: var(--text-muted); margin: 0 0.5em; font-weight: 400; }

.portal-nav { display: flex; align-items: center; gap: var(--space-3); }
.user-email { color: var(--text-muted); font-size: 0.9rem; }

.portal-main {
    max-width: 720px;
    margin: var(--space-6) auto;
    padding: 0 var(--space-4);
}

.portal-footer {
    text-align: center;
    color: var(--text-muted);
    padding: var(--space-5) var(--space-3);
    border-top: 1px solid var(--border);
}

.hero {
    text-align: left;
}
.hero h1 {
    font-size: 2.25rem;
    line-height: 1.15;
    margin: 0 0 var(--space-3);
}
.lede {
    font-size: 1.15rem;
    color: var(--text);
    margin: 0 0 var(--space-3);
}
.muted { color: var(--text-muted); }

.card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-5);
}
.card h1 { margin-top: 0; }

.placeholder {
    margin-top: var(--space-5);
    padding: var(--space-4);
    background: var(--surface-2);
    border: 1px dashed var(--border);
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    font-size: 0.94rem;
}

.error {
    background: var(--error-bg);
    border-color: var(--error-border);
    color: var(--error-text);
}

.btn {
    display: inline-block;
    padding: 0.6em 1.1em;
    border-radius: var(--radius-sm);
    font-weight: 500;
    font-size: 0.95rem;
    line-height: 1;
    border: 1px solid transparent;
    cursor: pointer;
    text-decoration: none;
}
.btn:hover { text-decoration: none; }
.btn-primary {
    background: var(--accent);
    color: var(--accent-text);
}
.btn-primary:hover { background: var(--accent-hover); }
.btn-ghost {
    background: transparent;
    color: var(--text);
    border-color: var(--border);
}
.btn-ghost:hover { background: var(--surface-2); }
.btn-small {
    font-size: 0.85rem;
    padding: 0.4em 0.8em;
}

/* CP2-B dashboard additions */
.card + .card { margin-top: var(--space-4); }
.card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-4);
}
.card-header h2 { margin: 0; }
.muted-card {
    background: transparent;
    border: 1px dashed var(--border);
}

.plan-strip {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin-top: var(--space-3);
    align-items: center;
}
.plan-badge {
    background: var(--accent);
    color: var(--accent-text);
    padding: 0.3em 0.7em;
    border-radius: var(--radius-sm);
    font-size: 0.85rem;
    font-weight: 500;
    text-transform: capitalize;
}
.plan-limit {
    color: var(--text-muted);
    font-size: 0.9rem;
    font-family: var(--font-mono);
}

.inline-form { display: inline; margin: 0; }

.keys-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: var(--space-3);
}
.keys-table th, .keys-table td {
    padding: var(--space-2) var(--space-3);
    text-align: left;
    border-bottom: 1px solid var(--border);
}
.keys-table th {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    font-weight: 500;
}
.keys-table tbody tr:last-child td { border-bottom: none; }
.key-mask {
    font-size: 0.95rem;
    font-family: var(--font-mono);
}

.warning-banner {
    background: #fff4d6;
    border: 1px solid #f0d68b;
    color: #6b4a08;
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-sm);
    margin: var(--space-3) 0 var(--space-4);
    font-size: 0.95rem;
}

.key-display {
    background: var(--code-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: var(--space-3) var(--space-4);
    margin: var(--space-4) 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    flex-wrap: wrap;
}
.key-display code {
    background: transparent;
    padding: 0;
    font-size: 1.05rem;
    word-break: break-all;
}

pre {
    background: var(--code-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: var(--space-3);
    overflow-x: auto;
    font-size: 0.9rem;
}
pre code {
    background: transparent;
    padding: 0;
}

/* ── CP2-C usage dashboard ──────────────────────────────────── */

:root {
    --ok:    #1f7a4d;
    --ok-bg: #e9f5ee;
    --warn:  #8a5a08;
    --warn-bg: #fff4d6;
    --err:   #8a2d1a;
    --err-bg: #fdf0ed;
}

.muted-sm { color: var(--text-muted); font-size: 0.85rem; }

.dashboard-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
    margin-bottom: var(--space-4);
}
.dashboard-header h1 { margin: 0 0 var(--space-2); }

/* live rate-limit */
.rate-row { margin: var(--space-3) 0; }
.rate-label {
    display: flex;
    justify-content: space-between;
    margin-bottom: var(--space-2);
    font-size: 0.93rem;
}
.rate-value { font-family: var(--font-mono); color: var(--text-muted); }
.rate-bar {
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    height: 8px;
    overflow: hidden;
}
.rate-fill {
    background: var(--accent);
    height: 100%;
    border-radius: var(--radius-sm);
    transition: width 0.3s;
}
.rate-warn { background: var(--warn); }

/* stat grid */
.stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--space-3);
    margin: var(--space-4) 0;
}
.stat-tile {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-4);
}
.stat-label {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted);
}
.stat-value {
    font-size: 2.1rem;
    font-weight: 600;
    margin: var(--space-2) 0 var(--space-1);
    line-height: 1.1;
}
.stat-sub { font-size: 0.85rem; }

/* chart */
.chart {
    display: flex;
    align-items: flex-end;
    gap: 3px;
    height: 110px;
    margin: var(--space-4) 0 var(--space-2);
    padding-bottom: 1px;
    border-bottom: 1px solid var(--border);
}
.chart-bar {
    flex: 1 0 12px;
    background: var(--accent);
    min-height: 2px;
    border-radius: 2px 2px 0 0;
    transition: opacity 0.15s, transform 0.15s;
}
.chart-bar:hover { opacity: 0.7; transform: translateY(-1px); }
.chart-bar-empty {
    background: var(--border);
    opacity: 0.55;
}
.chart-axis {
    display: flex;
    justify-content: space-between;
    margin-top: var(--space-2);
}

/* breakdown */
.breakdown-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--space-3);
}
.breakdown-tile {
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: var(--space-3) var(--space-4);
}
.breakdown-label {
    font-size: 0.8rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.breakdown-value {
    font-size: 1.5rem;
    font-weight: 600;
    margin-top: var(--space-1);
}
.breakdown-value .unit { font-size: 0.95rem; color: var(--text-muted); font-weight: 400; }
.breakdown-ok { border-left: 3px solid var(--ok); }
.breakdown-warn { border-left: 3px solid var(--warn); }
.breakdown-err { border-left: 3px solid var(--err); }
.breakdown-rate { border-left: 3px solid #8155a0; }

/* tables (replaces keys-table) */
.data-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: var(--space-3);
    font-size: 0.92rem;
}
.data-table th, .data-table td {
    padding: var(--space-2) var(--space-3);
    text-align: left;
    border-bottom: 1px solid var(--border);
}
.data-table th {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    font-weight: 500;
}
.data-table tbody tr:last-child td { border-bottom: none; }
.data-table .num { text-align: right; font-variant-numeric: tabular-nums; }
.data-table-compact td, .data-table-compact th { padding: var(--space-1) var(--space-3); }
.data-table .path-cell code { font-size: 0.88rem; }

.keys-table { /* preserved selector for older usages */
    width: 100%; border-collapse: collapse; margin-top: var(--space-3);
}

.pill {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 500;
    font-family: var(--font-mono);
    background: var(--surface-2);
    border: 1px solid var(--border);
    color: var(--text);
    letter-spacing: 0.04em;
}
.pill-method { min-width: 38px; text-align: center; }

.status {
    font-family: var(--font-mono);
    font-weight: 500;
    padding: 1px 7px;
    border-radius: 4px;
    font-size: 0.85rem;
}
.status-ok   { background: var(--ok-bg);   color: var(--ok); }
.status-warn { background: var(--warn-bg); color: var(--warn); }
.status-err  { background: var(--err-bg);  color: var(--err); }

@media (max-width: 600px) {
    .portal-main { padding: 0 var(--space-3); }
    .stat-grid { grid-template-columns: 1fr 1fr; }
    .breakdown-grid { grid-template-columns: 1fr 1fr; }
    .dashboard-header { flex-direction: column; align-items: stretch; }
    .data-table { font-size: 0.85rem; }
    .data-table th, .data-table td { padding: var(--space-1) var(--space-2); }
}
