/* ============================================
   L2JEvolution Dark Theme
   Shared across all pages
   ============================================ */

:root {
    --bg-dark: #0f1923;
    --bg-card: #1a2332;
    --bg-card-hover: #243447;
    --text-primary: #e8edf2;
    --text-secondary: #8b9bb4;
    --accent-blue: #4fc3f7;
    --accent-green: #66bb6a;
    --accent-gold: #ffd54f;
    --accent-purple: #ab47bc;
    --accent-red: #ef5350;
}

body {
    background: var(--bg-dark) !important;
    color: var(--text-primary) !important;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

h1, h2, h3, h4, h5, h6 { color: var(--text-primary); }

a { color: var(--accent-blue); }
a:hover { color: #81d4fa; }

/* ---- Navbar ---- */
.navbar {
    background: rgba(15, 25, 35, 0.95) !important;
    border-bottom: 1px solid rgba(79, 195, 247, 0.15);
    backdrop-filter: blur(10px);
}
.navbar-brand { color: var(--accent-blue) !important; font-weight: 700; }
.nav-link, .navbar-nav .nav-link { color: var(--text-secondary) !important; transition: color 0.2s; }
.nav-link:hover, .navbar-nav .nav-link:hover, .nav-link:focus { color: var(--accent-blue) !important; }
.nav-link-custom { color: var(--text-secondary) !important; transition: color 0.2s; text-decoration: none; }
.nav-link-custom:hover { color: var(--accent-blue) !important; }
.navbar-toggler { border-color: rgba(79, 195, 247, 0.3); }
.navbar-toggler-icon { filter: invert(0.7); }

/* ---- Buttons ---- */
.btn-glow {
    background: linear-gradient(135deg, var(--accent-blue), #0288d1);
    border: none; color: white; border-radius: 50px;
    padding: 14px 35px; font-weight: 700; font-size: 1.05rem;
    transition: all 0.3s; box-shadow: 0 4px 15px rgba(79, 195, 247, 0.3);
}
.btn-glow:hover {
    color: white; transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(79, 195, 247, 0.4);
}
.btn-outline-glow {
    border: 2px solid var(--accent-blue); color: var(--accent-blue);
    border-radius: 50px; padding: 12px 30px; font-weight: 600;
    background: transparent; transition: all 0.3s;
}
.btn-outline-glow:hover { background: rgba(79, 195, 247, 0.1); color: var(--accent-blue); }

.btn-primary { background: var(--accent-blue) !important; border-color: var(--accent-blue) !important; color: #000 !important; }
.btn-primary:hover { background: #81d4fa !important; border-color: #81d4fa !important; }
.btn-outline-primary { color: var(--accent-blue) !important; border-color: var(--accent-blue) !important; }
.btn-outline-primary:hover { background: rgba(79, 195, 247, 0.15) !important; color: var(--accent-blue) !important; }
.btn-outline-secondary { color: var(--text-secondary) !important; border-color: rgba(255,255,255,0.15) !important; }
.btn-outline-secondary:hover { background: rgba(255,255,255,0.05) !important; color: var(--text-primary) !important; }
.btn-outline-light { color: var(--text-secondary) !important; border-color: rgba(255,255,255,0.2) !important; }
.btn-outline-light:hover { background: rgba(255,255,255,0.05) !important; color: var(--text-primary) !important; }
.btn-link { color: var(--text-secondary) !important; text-decoration: none; }
.btn-link:hover { color: var(--accent-blue) !important; }
.btn-outline-danger { color: var(--accent-red) !important; border-color: var(--accent-red) !important; }
.btn-outline-danger:hover { background: rgba(239,83,80,0.15) !important; color: var(--accent-red) !important; }
.btn-success { background: var(--accent-green) !important; border-color: var(--accent-green) !important; color: #000 !important; }
.btn-danger { background: var(--accent-red) !important; border-color: var(--accent-red) !important; }

/* ---- Cards ---- */
.card {
    background: var(--bg-card) !important;
    border: 1px solid rgba(255,255,255,0.05) !important;
    color: var(--text-primary);
}
.card-header {
    background: rgba(79, 195, 247, 0.05) !important;
    border-bottom: 1px solid rgba(79, 195, 247, 0.1) !important;
    color: var(--text-primary) !important;
}
.card-body { color: var(--text-primary); }
.card-title { color: var(--text-primary); }
.card-text { color: var(--text-secondary); }

/* ---- Forms ---- */
.form-control, .form-select {
    background: var(--bg-dark) !important;
    color: var(--text-primary) !important;
    border: 1px solid rgba(79, 195, 247, 0.2) !important;
}
.form-control:focus, .form-select:focus {
    background: var(--bg-dark) !important;
    color: var(--text-primary) !important;
    border-color: var(--accent-blue) !important;
    box-shadow: 0 0 0 0.2rem rgba(79, 195, 247, 0.15) !important;
}
.form-control::placeholder { color: var(--text-secondary) !important; opacity: 0.6; }
.form-label { color: var(--text-secondary) !important; }
.input-group-text {
    background: rgba(79, 195, 247, 0.05) !important;
    color: var(--text-secondary) !important;
    border-color: rgba(79, 195, 247, 0.2) !important;
}
.form-check-label { color: var(--text-secondary); }
textarea.form-control { background: var(--bg-dark) !important; }

/* ---- Tables ---- */
.table { color: var(--text-primary) !important; }
.table > thead, .table-light {
    background: rgba(79, 195, 247, 0.08) !important;
    color: var(--text-primary) !important;
}
.table-light th { color: var(--text-primary) !important; background: rgba(79, 195, 247, 0.08) !important; }
.table-hover > tbody > tr:hover {
    background-color: rgba(79, 195, 247, 0.05) !important;
    color: var(--text-primary) !important;
}
.table > :not(caption) > * > * {
    border-bottom-color: rgba(255,255,255,0.05) !important;
    background-color: transparent;
}

/* ---- Modals ---- */
.modal-content {
    background: var(--bg-card) !important;
    color: var(--text-primary);
    border: 1px solid rgba(79, 195, 247, 0.2);
}
.modal-header { border-bottom-color: rgba(79, 195, 247, 0.1) !important; }
.modal-footer { border-top-color: rgba(79, 195, 247, 0.1) !important; }
.modal-title { color: var(--text-primary); }
.btn-close { filter: invert(1) grayscale(100%) brightness(200%); }

/* ---- Alerts ---- */
.alert-info {
    background: rgba(79, 195, 247, 0.1) !important;
    border: 1px solid rgba(79, 195, 247, 0.2) !important;
    color: #8bcbf0 !important;
}
.alert-success {
    background: rgba(102, 187, 106, 0.1) !important;
    border: 1px solid rgba(102, 187, 106, 0.2) !important;
    color: #8bd18e !important;
}
.alert-danger {
    background: rgba(239, 83, 80, 0.1) !important;
    border: 1px solid rgba(239, 83, 80, 0.2) !important;
    color: #f09594 !important;
}
.alert-warning {
    background: rgba(255, 213, 79, 0.1) !important;
    border: 1px solid rgba(255, 213, 79, 0.2) !important;
    color: #ffe082 !important;
}
.alert a, .alert .alert-link { color: var(--accent-blue); }

/* ---- Footer ---- */
footer {
    background: #0a1218 !important;
    border-top: 1px solid rgba(79, 195, 247, 0.1);
    color: var(--text-secondary);
}
footer a { color: var(--text-secondary); text-decoration: none; }
footer a:hover { color: var(--accent-blue); }

/* ---- Nav Tabs ---- */
.nav-tabs { border-bottom-color: rgba(79, 195, 247, 0.15) !important; }
.nav-tabs .nav-link { color: var(--text-secondary) !important; border-color: transparent !important; }
.nav-tabs .nav-link.active {
    background: var(--bg-card) !important;
    color: var(--accent-blue) !important;
    border-color: rgba(79, 195, 247, 0.2) rgba(79, 195, 247, 0.2) var(--bg-card) !important;
    border-bottom: 3px solid var(--accent-blue) !important;
}
.nav-tabs .nav-link:hover:not(.active) {
    border-color: rgba(79, 195, 247, 0.1) !important;
    color: var(--accent-blue) !important;
}

/* ---- Pagination / DataTables ---- */
.page-link {
    background: var(--bg-card) !important;
    color: var(--text-secondary) !important;
    border-color: rgba(255,255,255,0.05) !important;
}
.page-link:hover { background: rgba(79, 195, 247, 0.1) !important; color: var(--accent-blue) !important; }
.page-item.active .page-link { background: var(--accent-blue) !important; border-color: var(--accent-blue) !important; color: #fff !important; }
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_filter label { color: var(--text-secondary) !important; }
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
    background: var(--bg-dark) !important;
    color: var(--text-primary) !important;
    border-color: rgba(79, 195, 247, 0.2) !important;
}

/* ---- Utility Overrides ---- */
.text-muted { color: var(--text-secondary) !important; }
.text-dark { color: var(--text-primary) !important; }
.bg-white, .bg-light { background: var(--bg-card) !important; }
.bg-dark { background: var(--bg-dark) !important; }
code { color: var(--accent-blue); }
pre {
    background: #0a1218 !important;
    color: #f8f8f2;
    padding: 15px;
    border-radius: 8px;
    border: 1px solid rgba(79, 195, 247, 0.1);
}
small { color: var(--text-secondary); }
.list-unstyled li { color: var(--text-secondary); }

/* ---- Badges (keep default Bootstrap colors) ---- */
.badge { font-weight: 600; }

/* ---- Section styles ---- */
.section-title { font-weight: 700; margin-bottom: 15px; color: var(--text-primary); }
.section-subtitle { color: var(--text-secondary); max-width: 600px; margin: 0 auto 50px; }

/* ---- Dropdown ---- */
.dropdown-menu {
    background: var(--bg-card); border: 1px solid rgba(79, 195, 247, 0.15);
}
.dropdown-item { color: var(--text-secondary); }
.dropdown-item:hover { background: rgba(79, 195, 247, 0.1); color: var(--accent-blue); }
