/* ─────────────────────────────────────────────────────────────────────
 * ui-components.css — Reusable UI primitives.
 * Depends on: design-tokens.css (must be loaded first).
 *
 * EdTech SaaS palette: teal · emerald · cyan · amber · gray.
 * No red, no purple, no blue brand colors.
 * ───────────────────────────────────────────────────────────────────── */

/* ════════════════════════════════════════════════════════════════════
 * PAGE HEADER
 * ════════════════════════════════════════════════════════════════════ */
.page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: var(--space-4);
    flex-wrap: wrap;
    padding-bottom: var(--space-5);
    margin-bottom: var(--space-6);
    border-bottom: 1px solid var(--color-border);
}
.page-title {
    font-size: var(--fs-h1-desktop);
    font-weight: var(--fw-bold);
    color: var(--color-ink);
    margin: 0;
    letter-spacing: var(--tracking-tight);
    line-height: var(--lh-tight);
}
.page-subtitle {
    font-size: var(--fs-body);
    color: var(--color-muted);
    margin: var(--space-2) 0 0;
    line-height: var(--lh-normal);
}
.section-title {
    font-size: var(--fs-h2-desktop);
    font-weight: var(--fw-bold);
    color: var(--color-ink);
    margin: 0 0 var(--space-2);
    letter-spacing: var(--tracking-tight);
}
.section-subtitle {
    font-size: var(--fs-body);
    color: var(--color-muted);
    margin: 0 0 var(--space-5);
}
.eyebrow {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: var(--fs-small);
    font-weight: var(--fw-bold);
    color: var(--color-primary);
    letter-spacing: var(--tracking-mono);
    text-transform: uppercase;
    margin-bottom: var(--space-3);
}

@media (max-width: 768px) {
    .page-title    { font-size: var(--fs-h1-mobile); }
    .section-title { font-size: var(--fs-h2-mobile); }
}

/* ════════════════════════════════════════════════════════════════════
 * BUTTONS
 * ════════════════════════════════════════════════════════════════════ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    height: var(--btn-h-md);
    padding: 0 var(--btn-px-md);
    border-radius: var(--radius-md);
    border: 1.5px solid transparent;
    font-family: var(--font-sans);
    font-size: var(--fs-small);
    font-weight: var(--fw-bold);
    line-height: 1;
    letter-spacing: var(--tracking-normal);
    cursor: pointer;
    text-decoration: none;
    transition: all var(--dur-base) var(--ease);
    user-select: none;
    white-space: nowrap;
}
.btn:focus-visible { outline: none; box-shadow: var(--shadow-focus); }
.btn:disabled, .btn[aria-disabled="true"] {
    opacity: .55; cursor: not-allowed; pointer-events: none;
}
.btn i, .btn .fa, .btn .fas, .btn .far { font-size: 0.95em; }

/* Sizes */
.btn-sm { height: var(--btn-h-sm); padding: 0 var(--btn-px-sm); font-size: var(--fs-micro); }
.btn-md { height: var(--btn-h-md); padding: 0 var(--btn-px-md); }
.btn-lg { height: var(--btn-h-lg); padding: 0 var(--btn-px-lg); font-size: var(--fs-body); }

/* Variants — TEAL primary */
.btn-primary {
    background: var(--color-primary);
    color: var(--color-on-dark);
    border-color: var(--color-primary);
    box-shadow: 0 4px 12px rgba(20, 184, 166, .22);
}
.btn-primary:hover:not(:disabled) {
    background: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
    color: var(--color-on-dark);
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(20, 184, 166, .30);
}

/* Secondary — emerald (success/learning state) */
.btn-secondary {
    background: var(--color-secondary);
    color: var(--color-on-dark);
    border-color: var(--color-secondary);
    box-shadow: 0 4px 12px rgba(16, 185, 129, .22);
}
.btn-secondary:hover:not(:disabled) {
    background: var(--color-secondary-hover);
    border-color: var(--color-secondary-hover);
    color: var(--color-on-dark);
    transform: translateY(-1px);
}

/* Outline (neutral) */
.btn-outline {
    background: var(--color-surface);
    color: var(--color-text);
    border-color: var(--color-border);
}
.btn-outline:hover:not(:disabled) {
    border-color: var(--color-primary);
    color: var(--color-primary);
    transform: translateY(-1px);
}

/* Ghost */
.btn-ghost {
    background: transparent;
    color: var(--color-text);
    border-color: transparent;
}
.btn-ghost:hover:not(:disabled) {
    background: var(--color-soft);
    color: var(--color-text);
}

/* Danger — restyled as AMBER warning (no red allowed in brand) */
.btn-danger {
    background: var(--color-warning);
    color: var(--color-on-dark);
    border-color: var(--color-warning);
    box-shadow: 0 4px 12px rgba(245, 158, 11, .22);
}
.btn-danger:hover:not(:disabled) {
    background: #D97706;
    border-color: #D97706;
    color: var(--color-on-dark);
    transform: translateY(-1px);
}

/* Success — alias to secondary (emerald) */
.btn-success {
    background: var(--color-secondary);
    color: var(--color-on-dark);
    border-color: var(--color-secondary);
}
.btn-success:hover:not(:disabled) {
    background: var(--color-secondary-hover);
    border-color: var(--color-secondary-hover);
    color: var(--color-on-dark);
    transform: translateY(-1px);
}

/* Accent — cyan (AI / premium / special) */
.btn-accent {
    background: var(--color-accent);
    color: var(--color-on-dark);
    border-color: var(--color-accent);
    box-shadow: 0 4px 12px rgba(6, 182, 212, .22);
}
.btn-accent:hover:not(:disabled) {
    background: var(--color-accent-hover);
    border-color: var(--color-accent-hover);
    color: var(--color-on-dark);
    transform: translateY(-1px);
}

/* Locked — gray, non-actionable visual */
.btn-locked {
    background: var(--color-locked-soft);
    color: var(--color-locked-deep);
    border-color: var(--color-border);
    cursor: not-allowed;
}
.btn-locked:hover { transform: none; }

.btn-pill { border-radius: var(--radius-pill); }
.btn-block { width: 100%; }

.btn-group { display: inline-flex; gap: var(--space-2); flex-wrap: wrap; }

/* ════════════════════════════════════════════════════════════════════
 * CARDS
 * ════════════════════════════════════════════════════════════════════ */
.ui-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    transition: border-color var(--dur-base) var(--ease),
                box-shadow var(--dur-base) var(--ease),
                transform var(--dur-base) var(--ease);
}
.ui-card-hover:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}
.ui-card-flat { box-shadow: none; }
.ui-card-elevated { box-shadow: var(--shadow-md); border-color: transparent; }

/* Premium card (cyan accent) */
.ui-card-premium {
    background: linear-gradient(135deg, var(--color-accent-soft), var(--color-surface));
    border-color: var(--color-accent);
}

/* Locked card */
.ui-card-locked {
    background: var(--color-locked-soft);
    border-color: var(--color-border);
    color: var(--color-locked-deep);
}
.ui-card-locked .ui-card-title { color: var(--color-locked-deep); }

.ui-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding-bottom: var(--space-4);
    margin-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-line);
}
.ui-card-title {
    font-size: var(--fs-h4);
    font-weight: var(--fw-semibold);
    color: var(--color-ink);
    margin: 0;
    letter-spacing: var(--tracking-tight);
}
.ui-card-subtitle {
    font-size: var(--fs-small);
    color: var(--color-muted);
    margin: var(--space-1) 0 0;
}
.ui-card-body {}
.ui-card-footer {
    display: flex;
    justify-content: flex-end;
    gap: var(--space-2);
    padding-top: var(--space-4);
    margin-top: var(--space-4);
    border-top: 1px solid var(--color-line);
}

/* ════════════════════════════════════════════════════════════════════
 * FORMS
 * ════════════════════════════════════════════════════════════════════ */
.form-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    margin-bottom: var(--space-4);
}
.form-label {
    font-size: var(--fs-small);
    font-weight: var(--fw-semibold);
    color: var(--color-text);
    line-height: 1.3;
}
.form-label .form-required { color: var(--color-warning); margin-left: 2px; }
.form-help {
    font-size: var(--fs-micro);
    color: var(--color-muted);
    margin-top: var(--space-1);
}

.form-control {
    display: block;
    width: 100%;
    height: var(--input-h);
    padding: 0 var(--input-px);
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    line-height: 1.4;
    color: var(--color-text);
    background: var(--color-surface);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: border-color var(--dur-base) var(--ease),
                box-shadow var(--dur-base) var(--ease);
}
textarea.form-control {
    height: auto;
    min-height: 96px;
    padding: var(--space-3) var(--input-px);
    line-height: var(--lh-normal);
    resize: vertical;
}
select.form-control {
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%2364748B' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

.form-control:hover { border-color: var(--color-mute2); }
.form-control:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: var(--shadow-focus);
}
.form-control:disabled { background: var(--color-soft); cursor: not-allowed; }

.form-control.is-invalid { border-color: var(--color-warning); }
.form-control.is-invalid:focus { box-shadow: 0 0 0 3px rgba(245, 158, 11, .22); }
.form-error {
    font-size: var(--fs-micro);
    color: var(--color-warning-deep);
    margin-top: var(--space-1);
    display: flex;
    align-items: center;
    gap: 6px;
}

.form-check {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
    font-size: var(--fs-small);
}
.form-check input[type="checkbox"],
.form-check input[type="radio"] {
    width: 18px; height: 18px; accent-color: var(--color-primary);
}

/* ════════════════════════════════════════════════════════════════════
 * TABLES
 * ════════════════════════════════════════════════════════════════════ */
.ui-table-wrap {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.ui-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--fs-small);
}
.ui-table thead th {
    background: var(--color-soft);
    color: var(--color-muted);
    font-weight: var(--fw-bold);
    font-size: var(--fs-micro);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
    padding: var(--space-3) var(--space-4);
    text-align: left;
    border-bottom: 1px solid var(--color-border);
}
.ui-table tbody td {
    padding: var(--space-4);
    border-bottom: 1px solid var(--color-line);
    color: var(--color-text);
    vertical-align: middle;
}
.ui-table tbody tr:last-child td { border-bottom: none; }
.ui-table tbody tr:hover td { background: var(--color-bg); }
.ui-table .ui-table-actions { display: flex; gap: var(--space-2); justify-content: flex-end; }

.ui-table-empty {
    text-align: center;
    padding: var(--space-12) var(--space-6);
    color: var(--color-muted);
    font-size: var(--fs-small);
}

/* ════════════════════════════════════════════════════════════════════
 * BADGES — only primary/secondary/accent/warning/muted
 * ════════════════════════════════════════════════════════════════════ */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 10px;
    border-radius: var(--radius-pill);
    font-family: var(--font-mono);
    font-size: var(--fs-micro);
    font-weight: var(--fw-bold);
    line-height: 1.4;
    letter-spacing: var(--tracking-wide);
    background: var(--color-soft);
    color: var(--color-muted);
}
.badge-primary   { background: var(--color-primary-soft);   color: var(--color-primary-hover); }
.badge-secondary { background: var(--color-secondary-soft); color: var(--color-secondary-hover); }
.badge-accent    { background: var(--color-accent-soft);    color: var(--color-accent-hover); }
.badge-warning   { background: var(--color-warning-soft);   color: var(--color-warning-deep); }
.badge-locked    { background: var(--color-locked-soft);    color: var(--color-locked-deep); }
.badge-muted     { background: var(--color-soft);           color: var(--color-muted); }
.badge-dark      { background: var(--color-ink);            color: var(--color-on-dark); }
/* Legacy aliases — point at brand-appropriate colors */
.badge-success   { background: var(--color-secondary-soft); color: var(--color-secondary-hover); }
.badge-danger    { background: var(--color-warning-soft);   color: var(--color-warning-deep); }
.badge-info      { background: var(--color-accent-soft);    color: var(--color-accent-hover); }

/* "Premium" badge utility — cyan */
.badge-premium {
    background: var(--color-accent);
    color: var(--color-on-dark);
}

/* ════════════════════════════════════════════════════════════════════
 * ALERTS
 * ════════════════════════════════════════════════════════════════════ */
.ui-alert {
    display: flex;
    gap: var(--space-3);
    padding: var(--space-4) var(--space-5);
    border-radius: var(--radius-md);
    border-left: 4px solid var(--color-accent);
    background: var(--color-accent-soft);
    color: var(--color-accent-deep);
    font-size: var(--fs-small);
    line-height: var(--lh-normal);
    margin-bottom: var(--space-4);
}
.ui-alert i { margin-top: 2px; flex-shrink: 0; }
.ui-alert-success { border-color: var(--color-secondary); background: var(--color-secondary-soft); color: var(--color-secondary-deep); }
.ui-alert-warning { border-color: var(--color-warning);   background: var(--color-warning-soft);   color: var(--color-warning-deep); }
.ui-alert-locked  { border-color: var(--color-locked);    background: var(--color-locked-soft);    color: var(--color-locked-deep); }
/* Legacy: "danger" → warning (no red) */
.ui-alert-danger  { border-color: var(--color-warning);   background: var(--color-warning-soft);   color: var(--color-warning-deep); }
.ui-alert-info    { border-color: var(--color-accent);    background: var(--color-accent-soft);    color: var(--color-accent-deep); }

/* ════════════════════════════════════════════════════════════════════
 * UTILITIES
 * ════════════════════════════════════════════════════════════════════ */
.ui-link {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: var(--fw-semibold);
    border-bottom: 1px solid transparent;
    transition: border-color var(--dur-fast) var(--ease);
}
.ui-link:hover { border-color: var(--color-primary); color: var(--color-primary-hover); }

.ui-divider {
    height: 1px;
    background: var(--color-border);
    margin: var(--space-6) 0;
    border: none;
}

.ui-stack-2 > * + * { margin-top: var(--space-2); }
.ui-stack-3 > * + * { margin-top: var(--space-3); }
.ui-stack-4 > * + * { margin-top: var(--space-4); }
.ui-stack-6 > * + * { margin-top: var(--space-6); }

.ui-text-muted   { color: var(--color-muted); }
.ui-text-mono    { font-family: var(--font-mono); }
.ui-text-center  { text-align: center; }

/* Premium / Locked state helpers */
.is-premium { color: var(--color-accent); }
.is-locked  { color: var(--color-locked); }
.is-success { color: var(--color-secondary); }
