:root {
    --navy-900: #0b1d3a;
    --navy-800: #10254d;
    --navy-700: #163266;
    --navy-600: #1c4080;
    --accent: #f4b400;   /* ذهبي دافئ للتباين مع الكحلي */
    --accent-2: #12b886;
    --bg-soft: #f4f7fb;
    --text-soft: #5c6b82;
    --radius: 14px;
}

* { font-family: 'Tajawal', 'Segoe UI', sans-serif; }

body {
    background: var(--bg-soft);
    color: #1c2733;
}

/* ---------- Navbar ---------- */
.app-navbar {
    background: linear-gradient(90deg, var(--navy-900), var(--navy-700));
    box-shadow: 0 2px 12px rgba(11, 29, 58, .25);
}
.app-navbar .navbar-brand { font-weight: 900; letter-spacing: .3px; }

/* ---------- Footer ---------- */
.app-footer {
    background: var(--navy-900);
    color: rgba(255,255,255,.65);
    margin-top: 60px;
}

/* ---------- Cards ---------- */
.card {
    border: none;
    border-radius: var(--radius);
    box-shadow: 0 6px 24px rgba(16, 37, 77, .08);
}
.card-header.brand {
    background: var(--navy-800);
    color: #fff;
    border-radius: var(--radius) var(--radius) 0 0 !important;
    font-weight: 700;
}

/* ---------- Buttons ---------- */
.btn-primary {
    background: var(--navy-700);
    border-color: var(--navy-700);
}
.btn-primary:hover, .btn-primary:focus {
    background: var(--navy-900);
    border-color: var(--navy-900);
}
.btn-accent {
    background: var(--accent);
    color: var(--navy-900);
    font-weight: 700;
    border: none;
}
.btn-accent:hover { filter: brightness(0.95); color: var(--navy-900); }

/* ---------- Auth pages ---------- */
.auth-wrapper {
    min-height: 78vh;
    display: flex;
    align-items: center;
    justify-content: center;
}
.auth-card {
    max-width: 460px;
    width: 100%;
}
.auth-side {
    background: radial-gradient(circle at 30% 20%, var(--navy-600), var(--navy-900) 75%);
    color: #fff;
    border-radius: var(--radius);
    padding: 40px;
}

/* ---------- Badges / status ---------- */
.badge-pending { background: #fff3cd; color: #7a5b00; }
.badge-approved { background: #d1f5e8; color: #056e46; }

/* ---------- Tables ---------- */
.table thead {
    background: var(--navy-800);
    color: #fff;
}
.table > :not(caption) > * > * { vertical-align: middle; }

/* ---------- Stat cards (dashboards) ---------- */
.stat-card {
    border-radius: var(--radius);
    padding: 22px;
    color: #fff;
}
.stat-card.navy   { background: linear-gradient(135deg, var(--navy-700), var(--navy-900)); }
.stat-card.gold   { background: linear-gradient(135deg, #f6c453, #d99b1e); color: var(--navy-900); }
.stat-card.green  { background: linear-gradient(135deg, #2fd6a1, #0e9e73); }
.stat-card h3 { font-weight: 900; margin: 0; }
.stat-card span { opacity: .85; font-size: .9rem; }

/* ---------- Section title ---------- */
.section-title {
    border-right: 5px solid var(--accent);
    padding-right: 12px;
    font-weight: 800;
    color: var(--navy-900);
}
