.btn {
    display: inline-block;
    padding: var(--space-2) var(--space-4);
    background: var(--color-primary);
    color: var(--color-primary-text);
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-weight: 600;
}
.btn:hover { filter: brightness(0.95); }
.btn[disabled] { opacity: 0.5; cursor: not-allowed; }
.btn-secondary {
    background: var(--color-surface);
    color: var(--color-text);
    border: 1px solid var(--color-border);
}
.link-btn {
    background: transparent;
    border: none;
    color: var(--color-link);
    cursor: pointer;
    padding: 0;
}
.link-btn:hover { text-decoration: underline; }

.card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-6);
}

label {
    display: block;
    margin-bottom: var(--space-1);
    color: var(--color-muted);
    font-size: 0.9em;
}
input[type="text"], input[type="email"], input[type="password"], input[type="number"] {
    display: block;
    width: 100%;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-surface);
}
input:focus { outline: 2px solid var(--color-primary); outline-offset: -1px; }

.form-row { margin-bottom: var(--space-4); }

.error-banner {
    background: var(--color-error-bg);
    color: var(--color-error-text);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-4);
}
.success-banner {
    background: var(--color-success-bg);
    color: var(--color-success-text);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-4);
}

.muted { color: var(--color-text-muted, #666); }

.impersonation-banner[hidden] {
    /* Author `display: flex` below otherwise beats the UA [hidden] rule,
       leaving the banner visible when not impersonating. */
    display: none;
}
.impersonation-banner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
    background: #8a3b00;
    color: #fff;
    padding: var(--space-2) var(--space-3);
    font-weight: 600;
}
.impersonation-banner .link-btn {
    color: #fff;
    text-decoration: underline;
}

table th, table td {
    text-align: left;
    padding: var(--space-2) var(--space-3);
    border-bottom: 1px solid var(--color-border);
}
table th { color: var(--color-muted); font-size: 0.85em; font-weight: 500; }

/* Tab bar — used by course detail and dashboards. */
.tab-bar {
    display: flex;
    gap: var(--space-1);
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--space-4);
}
.tab-btn {
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    padding: var(--space-2) var(--space-3);
    cursor: pointer;
    color: var(--color-muted);
    font: inherit;
}
.tab-btn.active {
    color: var(--color-text);
    border-bottom-color: var(--color-primary);
    font-weight: 600;
}

/* Status pills for learner dashboard. */
.pill {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 999px;
    font-size: 0.8em;
    font-weight: 600;
}
.pill-complete { background: var(--color-success-bg); color: var(--color-success-text); }
.pill-failed   { background: var(--color-error-bg); color: var(--color-error-text); }
.pill-progress { background: #fff3cd; color: #856404; }
.pill-due      { background: #ffe0b2; color: #8a4b00; }
.pill-new      { background: var(--color-border); color: var(--color-muted); }

.stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--space-3);
}
.stat-card {
    background: var(--color-surface, #fff);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: var(--space-3);
    text-align: center;
}
.stat-card .stat-value { font-size: 1.8em; font-weight: 700; }
.stat-card .stat-label { color: var(--color-muted); font-size: 0.85em; }
