/* ================================================================
   ADMIN THEME — Conselho do Altar
   Usa as cores do sistema: Mármore (#fbfaf7) | Ouro (#c5a059) | Azul (#162433)
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Inter:wght@300;400;500;600&display=swap');

:root {
    --bg-page: #fbfaf7;
    --bg-card: #ffffff;
    --text-main: #162433;
    --text-muted: #5a6a7a;
    --ouro: #c5a059;
    --ouro-claro: #d4b87a;
    --ouro-escuro: #a38143;
    --borda: rgba(197, 160, 89, 0.25);
    --borda-forte: rgba(197, 160, 89, 0.5);
    --sombra: rgba(22, 36, 51, 0.08);
    --sidebar-bg: #162433;
    --sidebar-text: #c5a059;
}

body {
    background: var(--bg-page);
    color: var(--text-main);
    font-family: 'Inter', sans-serif;
    min-height: 100vh;
}

h1, h2, h3, h4, h5 {
    font-family: 'Cinzel', serif;
    color: var(--text-main);
}
h1 { color: var(--ouro); }

/* ─── LAYOUT ─── */
.admin-wrapper {
    display: flex;
    min-height: 100vh;
}
.admin-sidebar {
    width: 250px;
    background: var(--sidebar-bg);
    flex-shrink: 0;
    padding: 1.5rem 0;
}
.admin-sidebar .sidebar-brand {
    font-family: 'Cinzel', serif;
    color: var(--sidebar-text);
    font-size: 1.2rem;
    padding: 0 1.25rem 1.5rem;
    letter-spacing: 1px;
    border-bottom: 1px solid rgba(197, 160, 89, 0.2);
    margin-bottom: 1rem;
}
.admin-sidebar .nav-link {
    color: rgba(255,255,255,0.7);
    padding: 0.6rem 1.25rem;
    border-left: 3px solid transparent;
    transition: all 0.2s;
    font-size: 0.9rem;
}
.admin-sidebar .nav-link:hover {
    color: #fff;
    background: rgba(197, 160, 89, 0.1);
    border-left-color: var(--ouro);
}
.admin-sidebar .nav-link.active {
    color: var(--ouro);
    background: rgba(197, 160, 89, 0.08);
    border-left-color: var(--ouro);
}
.admin-content {
    flex: 1;
    padding: 2rem;
    max-width: calc(100% - 250px);
}
.admin-topbar {
    background: #fff;
    border-bottom: 1px solid var(--borda);
    padding: 0.75rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* ─── CARDS ─── */
.card, .oracle-card, .panel, .stat-card {
    background: var(--bg-card);
    border: 1px solid var(--borda);
    border-radius: 10px;
    box-shadow: 0 2px 12px var(--sombra);
    transition: box-shadow 0.2s;
}
.card:hover, .oracle-card:hover {
    box-shadow: 0 4px 20px var(--sombra);
}
.card-header, .card-footer {
    background: transparent;
    border-color: var(--borda);
}
.stat-card { border-left: 3px solid var(--ouro); }
.stat-card.border-success { border-left-color: #28a745; }
.stat-card.border-danger { border-left-color: #dc3545; }
.stat-card.border-info { border-left-color: #5bc0de; }

/* ─── TABLES ─── */
.table {
    color: var(--text-main);
    --bs-table-bg: transparent;
}
.table thead th {
    border-bottom: 2px solid var(--ouro);
    color: var(--text-muted);
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 1px;
    font-weight: 600;
}
.table tbody tr {
    background: #fff;
    transition: background 0.15s;
}
.table tbody tr:hover {
    background: rgba(197, 160, 89, 0.05);
}
.table td {
    vertical-align: middle;
    border-color: var(--borda);
    padding: 0.75rem 0.5rem;
}
.table-hover tbody tr:hover {
    background: rgba(197, 160, 89, 0.05);
}

/* ─── BUTTONS ─── */
.btn-ouro {
    background: var(--ouro);
    border: none;
    color: #fff;
    font-weight: 600;
}
.btn-ouro:hover {
    background: var(--ouro-escuro);
    color: #fff;
}
.btn-outline-ouro {
    border: 1px solid var(--ouro);
    color: var(--ouro);
    background: transparent;
}
.btn-outline-ouro:hover {
    background: var(--ouro);
    color: #fff;
}
.btn-mystic, .btn-oracle-main, .btn-gold {
    background: var(--ouro);
    border: none;
    color: #fff;
    font-weight: 600;
    letter-spacing: 0.5px;
    transition: all 0.2s;
}
.btn-mystic:hover, .btn-oracle-main:hover, .btn-gold:hover {
    background: var(--ouro-escuro);
    color: #fff;
    transform: translateY(-1px);
}
.btn-outline-mystic, .btn-outline-gold {
    border: 1px solid var(--ouro);
    color: var(--ouro);
    background: transparent;
}
.btn-outline-mystic:hover, .btn-outline-gold:hover {
    background: var(--ouro);
    color: #fff;
}
.btn-outline-secondary {
    color: var(--text-muted);
    border-color: var(--borda-forte);
}
.btn-outline-danger { color: #dc3545; border-color: #dc3545; }
.btn-outline-danger:hover { background: #dc3545; color: #fff; }

/* ─── FORMS ─── */
.form-control, .form-select {
    background: #fff;
    border: 1px solid var(--borda-forte);
    color: var(--text-main);
    border-radius: 6px;
}
.form-control:focus, .form-select:focus {
    border-color: var(--ouro);
    box-shadow: 0 0 0 0.2rem rgba(197, 160, 89, 0.15);
}
.form-control::placeholder { color: #aaa; }
.form-text { color: var(--text-muted); font-size: 0.8rem; }
.form-label { font-weight: 500; color: var(--text-main); }
.form-check-input:checked {
    background-color: var(--ouro);
    border-color: var(--ouro);
}
.input-dark, textarea.form-control {
    background: #fff;
    border: 1px solid var(--borda-forte);
    color: var(--text-main);
}
.input-dark:focus {
    border-color: var(--ouro);
    box-shadow: 0 0 0 0.2rem rgba(197, 160, 89, 0.15);
}

/* ─── BADGES ─── */
.badge.bg-success { background-color: #28a745 !important; }
.badge.bg-danger { background-color: #dc3545 !important; }
.badge.bg-warning { background-color: #ffc107 !important; color: #212529 !important; }
.badge.bg-info { background-color: #5bc0de !important; color: #fff !important; }
.badge.bg-secondary { background-color: #6c757d !important; }
.badge-mystic {
    background: rgba(197, 160, 89, 0.15);
    color: var(--ouro-escuro);
    border: 1px solid var(--ouro);
    padding: 0.3em 0.6em;
    border-radius: 4px;
    font-size: 0.75rem;
}
.badge-gold {
    background: rgba(197, 160, 89, 0.1);
    color: var(--ouro);
    border: 1px solid var(--ouro);
}

/* ─── MODALS ─── */
.modal-content {
    background: var(--bg-card);
    border: 1px solid var(--borda);
    border-radius: 12px;
}
.modal-header {
    border-bottom: 1px solid var(--borda);
}
.modal-footer {
    border-top: 1px solid var(--borda);
}

/* ─── ALERTS ─── */
.alert {
    border-radius: 8px;
}
.alert-success {
    background: rgba(40, 167, 69, 0.08);
    border: 1px solid rgba(40, 167, 69, 0.3);
    color: #155724;
}
.alert-danger {
    background: rgba(220, 53, 69, 0.08);
    border: 1px solid rgba(220, 53, 69, 0.3);
    color: #721c24;
}
.alert-warning {
    background: rgba(255, 193, 7, 0.08);
    border: 1px solid rgba(255, 193, 7, 0.3);
    color: #856404;
}
.alert-info {
    background: rgba(91, 192, 222, 0.08);
    border: 1px solid rgba(91, 192, 222, 0.3);
    color: #0c5460;
}

/* ─── TEXT ─── */
.text-gold { color: var(--ouro) !important; }
.text-cyan { color: #5bc0de !important; }
.text-muted, small, .small, .x-small, .text-secondary, .text-body-secondary {
    color: var(--text-muted) !important;
}
code {
    background: rgba(197, 160, 89, 0.1);
    color: var(--ouro-escuro);
    padding: 0.15em 0.4em;
    border-radius: 3px;
}
a:not(.btn):not(.nav-link):not(.badge) {
    color: var(--ouro-escuro);
}
a:hover:not(.btn):not(.nav-link):not(.badge) {
    color: var(--ouro);
}

/* ─── MISC ─── */
.nav-link-mystic {
    color: var(--ouro) !important;
}
.navbar {
    background: #fff;
    border-bottom: 1px solid var(--borda);
}
.navbar.navbar-dark {
    background: var(--sidebar-bg) !important;
    border-bottom: 1px solid rgba(197, 160, 89, 0.2);
}
.navbar.navbar-dark .navbar-brand,
.navbar.navbar-dark .nav-link,
.navbar.navbar-dark .navbar-text {
    color: rgba(255,255,255,0.85) !important;
}
.navbar.navbar-dark .navbar-brand:hover,
.navbar.navbar-dark .nav-link:hover {
    color: var(--ouro) !important;
}
.text-white {
    color: var(--text-main) !important;
}
h1.text-white, h2.text-white, h3.text-white {
    color: var(--text-main) !important;
}

/* Scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg-page); }
::-webkit-scrollbar-thumb { background: var(--ouro); border-radius: 3px; }
