/* ── Shared component library ─────────────────────────────────────────────
   All values reference tokens from brand.css. Per-page overrides go in
   that page's own <style> block, below the components.css link.
   ──────────────────────────────────────────────────────────────────────── */

/* ── Reset / base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
    font-family: var(--font-body);
    font-size: var(--text-md);
    color: var(--color-text);
    background: var(--color-bg);
    line-height: 1.5;
}

/* ── Layout ── */
.wrapper {
    width: 92%;
    max-width: 1200px;
    margin-inline: auto;
}

/* ── Buttons ── */
.btn-primary {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--brand);
    color: #fff;
    border: none;
    border-radius: var(--radius-md);
    padding: 10px var(--space-5);
    font-size: var(--text-base);
    font-weight: 700;
    cursor: pointer;
    text-decoration: none;
    transition: background var(--transition-base), box-shadow var(--transition-base), transform var(--transition-fast);
}
.btn-primary:hover {
    background: var(--brand-dark);
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
}

.btn-outline {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--color-surface);
    color: var(--brand);
    border: 2px solid var(--brand);
    border-radius: var(--radius-md);
    padding: 10px var(--space-5);
    font-size: var(--text-base);
    font-weight: 700;
    cursor: pointer;
    text-decoration: none;
    transition: background var(--transition-base), color var(--transition-base);
}
.btn-outline:hover {
    background: var(--brand-lighter);
}

.btn-pill {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--brand);
    color: #fff;
    border: none;
    border-radius: var(--radius-pill);
    padding: 10px var(--space-6);
    font-size: var(--text-base);
    font-weight: 700;
    cursor: pointer;
    text-decoration: none;
    transition: background var(--transition-base), box-shadow var(--transition-base);
}
.btn-pill:hover {
    background: var(--brand-dark);
    box-shadow: var(--shadow-md);
}

.btn-ghost {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: transparent;
    color: var(--color-muted);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 8px var(--space-4);
    font-size: var(--text-sm);
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    transition: border-color var(--transition-base), color var(--transition-base);
}
.btn-ghost:hover {
    border-color: var(--brand);
    color: var(--brand);
}

/* ── Cards ── */
.card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
}
.card-hover {
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.card-hover:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

/* ── Badges ── */
.badge {
    display: inline-block;
    padding: 2px 10px;
    border-radius: var(--radius-pill);
    font-size: var(--text-xs);
    font-weight: 600;
    line-height: 1.6;
}
.badge-brand   { background: var(--brand-light);        color: var(--brand-dark); }
.badge-green   { background: var(--color-success-bg);   color: var(--color-success-text); }
.badge-red     { background: var(--color-error-bg);     color: var(--color-error-text); }
.badge-amber   { background: var(--color-warning-bg);   color: var(--color-warning-text); }
.badge-blue    { background: var(--color-info-bg);      color: var(--color-info-text); }
.badge-grey    { background: #f3f4f6;                   color: var(--color-muted); }
.badge-purple  { background: #ede9fe;                   color: #6d28d9; }

/* ── Form elements ── */
.form-label {
    display: block;
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-text-2);
    margin-bottom: var(--space-1);
}

.form-input,
.form-select,
.form-textarea {
    width: 100%;
    padding: 9px 11px;
    border: 1px solid var(--color-border-mid);
    border-radius: var(--radius-sm);
    font-size: var(--text-base);
    font-family: var(--font-body);
    color: var(--color-text);
    background: var(--color-surface);
    outline: none;
    transition: border-color var(--transition-base), box-shadow var(--transition-base);
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    border-color: var(--brand);
    box-shadow: var(--shadow-focus);
}
.form-textarea { resize: vertical; min-height: 80px; }

/* ── Flash / alert banners ── */
.flash-success {
    background: var(--color-success-bg);
    color: var(--color-success-text);
    border-radius: var(--radius-sm);
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-sm);
    font-weight: 600;
    margin-bottom: var(--space-5);
}
.flash-error {
    background: var(--color-error-bg);
    color: var(--color-error-text);
    border-radius: var(--radius-sm);
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-sm);
    font-weight: 600;
    margin-bottom: var(--space-5);
}
.flash-warning {
    background: var(--color-warning-bg);
    color: var(--color-warning-text);
    border-radius: var(--radius-sm);
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-sm);
    font-weight: 600;
    margin-bottom: var(--space-5);
}
.flash-info {
    background: var(--color-info-bg);
    color: var(--color-info-text);
    border-radius: var(--radius-sm);
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-sm);
    font-weight: 600;
    margin-bottom: var(--space-5);
}

/* ── Tables ── */
.table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
}
.table th {
    text-align: left;
    font-size: var(--text-xs);
    font-weight: 700;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: var(--space-3) var(--space-4);
    border-bottom: 2px solid var(--color-border);
}
.table td {
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--color-border);
    color: var(--color-text);
    vertical-align: middle;
}
.table tr:last-child td { border-bottom: none; }
.table tr:hover td { background: var(--color-surface-2); }

/* ── Divider ── */
.divider {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: var(--space-5) 0;
}

/* ── Helper utilities ── */
.text-muted  { color: var(--color-muted); }
.text-brand  { color: var(--brand); }
.text-sm     { font-size: var(--text-sm); }
.text-xs     { font-size: var(--text-xs); }
.fw-600      { font-weight: 600; }
.fw-700      { font-weight: 700; }
.fw-800      { font-weight: 800; }
