/*
 * Everyone Rises ERP — CSS Variables & Reset
 * er-variables.css
 * Shared by all layouts — admin and member
 * Version 1.0 | April 2026
 */

/* ── Reset ─────────────────────────────────────────────────────────────────── */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* ── Design Tokens ─────────────────────────────────────────────────────────── */
:root {
    /* Brand colours */
    --navy:        #1A3C6E;
    --navy-deep:   #0F2448;
    --navy-mid:    #2A5298;
    --gold:        #C8922A;
    --gold-lt:     #E8A020;
    --cream:       #FAF7F2;

    /* UI colours */
    --bg:          #F4F6FA;
    --card:        #FFFFFF;
    --text:        #1A2840;
    --muted:       #6B7A99;
    --border:      #E2E8F0;
    --border-dark: #CBD5E1;

    /* Status colours */
    --error:       #DC2626;
    --success:     #16A34A;
    --warning:     #D97706;

    /* Layout */
    --nav-h:       52px;
    --sidebar-w:   240px;
    --topbar-h:    60px;

    /* Typography */
    --font-d:      'Cormorant Garamond', Georgia, serif;
    --font-b:      'Jost', Arial, sans-serif;
}

/* ── Base typography ───────────────────────────────────────────────────────── */
body {
    font-family: var(--font-b);
    color: var(--text);
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
}

/* ── Shared form elements ──────────────────────────────────────────────────── */
.form-group { margin-bottom: 16px; }
.form-row   { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 6px;
}

.required { color: var(--error); }

.form-control {
    width: 100%;
    padding: 9px 12px;
    border: 1px solid var(--border);
    border-radius: 3px;
    font-family: var(--font-b);
    font-size: 14px;
    color: var(--text);
    background: #ffffff;
    transition: border-color 0.2s;
}

.form-control:focus {
    outline: none;
    border-color: var(--navy);
    box-shadow: 0 0 0 3px rgba(26,60,110,0.06);
}

.form-control.is-invalid { border-color: var(--error); }
textarea.form-control     { resize: vertical; }
select.form-control       { cursor: pointer; }

.field-error { display: block; font-size: 12px; color: var(--error); margin-top: 4px; }
.field-hint  { display: block; font-size: 11px; color: var(--muted);  margin-top: 4px; }

/* ── Shared buttons ────────────────────────────────────────────────────────── */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 9px 18px;
    border-radius: 3px;
    font-family: var(--font-b);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.05em;
    cursor: pointer;
    border: none;
    transition: background 0.2s, opacity 0.2s;
    text-decoration: none;
    white-space: nowrap;
}

.btn-primary            { background: var(--navy);  color: #fff; }
.btn-primary:hover      { background: var(--navy-deep); }
.btn-secondary          { background: #F1F5F9; color: var(--text); border: 1px solid var(--border); }
.btn-secondary:hover    { background: var(--border); }
.btn-full               { width: 100%; }
.btn-text               { background: none; border: none; color: var(--navy); font-size: 13px; cursor: pointer; padding: 4px 0; font-family: var(--font-b); }
.btn-text:hover         { text-decoration: underline; }
.btn:disabled           { opacity: 0.5; cursor: not-allowed; }

/* ── Shared alerts ─────────────────────────────────────────────────────────── */
.alert {
    padding: 10px 14px;
    border-radius: 3px;
    font-size: 13px;
    line-height: 1.5;
    margin-bottom: 16px;
}

.alert-success { background: #F0FDF4; border: 1px solid #BBF7D0; color: #15803D; }
.alert-error   { background: #FEF2F2; border: 1px solid #FECACA; color: #B91C1C; }
.alert-warning { background: #FFFBEB; border: 1px solid #FCD34D; color: #92400E; }
.alert-info    { background: #EFF6FF; border: 1px solid #BFDBFE; color: #1E40AF; }

/* ── Shared badges ─────────────────────────────────────────────────────────── */
.badge {
    display: inline-block;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 3px 8px;
    border-radius: 2px;
}

.badge-green       { background: rgba(22,163,74,0.1);   color: #15803D; }
.badge-red         { background: rgba(220,38,38,0.1);   color: #B91C1C; }
.badge-navy        { background: rgba(26,60,110,0.1);   color: var(--navy); }
.badge-muted       { background: rgba(107,114,153,0.1); color: var(--muted); }
.badge-gold        { background: rgba(200,146,42,0.1);  color: #92400E; }
.badge-super-admin { background: rgba(139,92,246,0.1);  color: #6D28D9; }
.badge-admin       { background: rgba(26,60,110,0.1);   color: var(--navy); }
.badge-manager     { background: rgba(200,146,42,0.1);  color: #92400E; }
.badge-staff       { background: rgba(107,114,153,0.1); color: var(--muted); }

/* ── Utility ───────────────────────────────────────────────────────────────── */
.fw-600    { font-weight: 600; }
.text-muted{ color: var(--muted); }
.text-sm   { font-size: 12px; }
.text-gold { color: var(--gold); }
.text-navy { color: var(--navy); }
