/* =========================================
   Admin Variables & Base (Dark Mode Core)
   ========================================= */
:root {
    --nb-bg-dark: #000000;
    /* Absolute black for premium feel */
    --nb-bg-panel: #0a0a0a;
    --nb-bg-card: rgba(255, 255, 255, 0.03);

    --nb-border: rgba(255, 255, 255, 0.1);
    --nb-border-hover: rgba(147, 112, 219, 0.5);
    /* Purple hint */

    --nb-accent: #9370DB;
    /* The Purple */
    --nb-accent-glow: rgba(147, 112, 219, 0.4);

    --nb-text: #e5e5e5;
    --nb-text-muted: #a3a3a3;

    --nb-font-display: 'Oswald', sans-serif;
    --nb-font-body: 'Inter', sans-serif;

    --nb-glass-bg: rgba(20, 20, 20, 0.7);
    --nb-glass-border: 1px solid rgba(255, 255, 255, 0.08);
    --nb-glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.5);
    --nb-backdrop-blur: blur(16px);
}

/* =========================================
   Login Page Styling
   ========================================= */
body.login {
    background-color: var(--nb-bg-dark);
    background-image: radial-gradient(circle at 50% 30%, #1a0b2e 0%, #000000 70%);
    color: var(--nb-text);
    font-family: var(--nb-font-body);
}

/* Form Container - Glassmorphism */
body.login #login {
    padding-top: 8vh;
    width: 360px;
}

body.login .message,
body.login .success,
body.login #login_error {
    background: rgba(147, 112, 219, 0.1);
    border: 1px solid var(--nb-accent);
    border-left: 4px solid var(--nb-accent);
    color: #fff;
    box-shadow: var(--nb-glass-shadow);
    backdrop-filter: var(--nb-backdrop-blur);
    border-radius: 4px;
}

body.login #loginform {
    background: var(--nb-glass-bg);
    backdrop-filter: var(--nb-backdrop-blur);
    -webkit-backdrop-filter: var(--nb-backdrop-blur);
    border: var(--nb-glass-border);
    border-radius: 16px;
    box-shadow: var(--nb-glass-shadow);
    padding: 40px;
}

/* Form Fields */
body.login label {
    color: var(--nb-text-muted);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-family: var(--nb-font-display);
    margin-bottom: 4px;
}

body.login input[type="text"],
body.login input[type="password"] {
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--nb-border);
    color: #fff;
    border-radius: 8px;
    padding: 12px 15px;
    font-size: 16px;
    margin-top: 6px;
    transition: all 0.3s ease;
    font-weight: 500;
}

body.login input[type="text"]:focus,
body.login input[type="password"]:focus {
    border-color: var(--nb-accent);
    box-shadow: 0 0 0 1px var(--nb-accent), 0 0 15px var(--nb-accent-glow);
    background: rgba(0, 0, 0, 0.5);
}

/* Submit Button */
body.login .button-primary {
    background: var(--nb-accent) !important;
    border: 1px solid var(--nb-accent) !important;
    color: #fff !important;
    /* White text on purple */
    font-family: var(--nb-font-display);
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 0.1em;
    padding: 12px 24px !important;
    border-radius: 4px !important;
    height: auto !important;
    font-size: 15px !important;
    transition: all 0.3s ease;
    text-shadow: none !important;
    box-shadow: 0 4px 15px rgba(147, 112, 219, 0.3) !important;
    float: none !important;
    width: 100%;
    margin-top: 25px;
    opacity: 1 !important;
    /* Ensure button is always visible */
}

body.login .button-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(147, 112, 219, 0.5) !important;
    background: #7B68EE !important;
    /* Slightly lighter purple */
}

/* Logo - Custom Image Handling via CSS */
/* Logo - Custom Image Handling via CSS */
body.login h1 a {
    background-image: none !important;
    width: auto !important;
    height: auto !important;
    margin-bottom: 20px !important;
    /* Ensure text is visible as fallback or primary brand */
    text-indent: 0 !important;
    overflow: visible !important;
    display: block !important;
    margin: 0 auto 30px auto;

    /* Typography matching brand */
    color: #fff !important;
    font-family: 'Oswald', sans-serif !important;
    font-size: 40px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 2px;
    text-decoration: none !important;
    text-shadow: 0 0 20px rgba(147, 112, 219, 0.6);
}

body.login h1 a:before {
    content: '';
    /* Remove pseudo-content if we rely on standard WP site title output */
}

/* Footer Links */
body.login #nav,
body.login #backtoblog {
    text-align: center;
    padding: 0;
    margin-top: 20px;
}

body.login #nav a,
body.login #backtoblog a {
    color: var(--nb-text-muted) !important;
    transition: color 0.3s ease;
    font-size: 13px;
}

body.login #nav a:hover,
body.login #backtoblog a:hover {
    color: var(--nb-accent) !important;
}

/* =========================================
   Admin Backend Style Overrides
   ========================================= */

/* 1. Admin Bar */
#wpadminbar {
    background: rgba(0, 0, 0, 0.8) !important;
    /* Glassy */
    backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.5);
}

#wpadminbar .ab-icon:before {
    color: var(--nb-text-muted) !important;
}

#wpadminbar .ab-item,
#wpadminbar a.ab-item {
    color: var(--nb-text) !important;
}

#wpadminbar .ab-top-secondary {
    background: transparent !important;
}

/* Hover states in admin bar */
#wpadminbar:not(.mobile) .ab-top-menu>li:hover>.ab-item,
#wpadminbar:not(.mobile) .ab-top-menu>li>.ab-item:focus,
#wpadminbar.nojq .quicklinks .ab-top-menu>li>.ab-item:focus,
#wpadminbar .ab-top-menu>li.hover>.ab-item {
    background: rgba(147, 112, 219, 0.2) !important;
    /* Purple tint */
    color: #fff !important;
}

/* 2. Admin Menu (Sidebar) */
#adminmenu,
#adminmenu .wp-submenu,
#adminmenuback,
#adminmenuwrap {
    background: #050505 !important;
    border-right: 1px solid rgba(255, 255, 255, 0.05);
}

/* Active Item */
#adminmenu .wp-has-current-submenu .wp-submenu .wp-submenu-head,
#adminmenu .wp-menu-arrow,
#adminmenu .wp-menu-arrow div,
#adminmenu li.current a.menu-top,
#adminmenu li.wp-has-current-submenu a.wp-has-current-submenu {
    background: var(--nb-accent) !important;
    color: #fff !important;
    font-weight: 600;
    box-shadow: 0 0 15px rgba(147, 112, 219, 0.4);
    transition: none !important;
    /* Fix Delay */
}

/* Hover Item */
#adminmenu li.menu-top:hover,
#adminmenu li.opensub>a.menu-top,
#adminmenu li>a.menu-top:focus {
    color: var(--nb-accent) !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
    transition: none !important;
    /* Fix Delay */
}

/* Icons - Purple Always or on Hover? "make just the logos/icons purple as well" implies generally. */
#adminmenu div.wp-menu-image:before,
#adminmenu .dashicons,
#adminmenu .wp-menu-image img {
    color: var(--nb-accent) !important;
    opacity: 1 !important;
}

/* Keep active/hover icons white for contrast? Or purple? 
   "make just the logos/icons purple as well" - let's make them purple primarily, 
   but white on active/hover background so they stand out? 
   Or purple on active? 
   Let's toggle: Purple by default (instead of grey), White on active/hover (on purple/dark bg).
*/
#adminmenu li.current div.wp-menu-image:before,
#adminmenu li.wp-has-current-submenu div.wp-menu-image:before,
#adminmenu li:hover div.wp-menu-image:before {
    color: #fff !important;
}

/* 3. Main Content Area */
body.wp-admin {
    background-color: var(--nb-bg-dark);
    font-family: var(--nb-font-body);
}

#wpbody-content {
    color: var(--nb-text);
}

/* Headings */
.wrap h1,
.wrap h2,
.wrap h3 {
    color: #fff;
    font-family: var(--nb-font-display);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
}

/* Cards (Postboxes) - Glass Effect */
.postbox,
.welcome-panel,
.card {
    background: rgba(20, 20, 20, 0.6) !important;
    backdrop-filter: blur(10px);
    border: 1px solid var(--nb-border) !important;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2) !important;
    color: var(--nb-text) !important;
    border-radius: 8px !important;
}

.postbox-header {
    border-bottom: 1px solid var(--nb-border) !important;
    background: rgba(255, 255, 255, 0.02) !important;
}

.hndle {
    color: var(--nb-accent) !important;
    font-family: var(--nb-font-display) !important;
    font-weight: 500 !important;
}

/* Inputs & Forms */
.wp-core-ui input[type="text"],
.wp-core-ui input[type="password"],
.wp-core-ui input[type="email"],
.wp-core-ui input[type="number"],
.wp-core-ui select,
.wp-core-ui textarea {
    background: #000 !important;
    border: 1px solid #333 !important;
    color: #fff !important;
    border-radius: 4px;
    padding: 6px 10px;
}

.wp-core-ui input:focus,
.wp-core-ui select:focus,
.wp-core-ui textarea:focus {
    border-color: var(--nb-accent) !important;
    box-shadow: 0 0 0 1px var(--nb-accent) !important;
    outline: none !important;
}

/* Links */
a {
    color: var(--nb-accent);
    transition: color 0.2s;
    text-decoration: none;
}

a:hover {
    color: #B088F9;
}

/* Buttons */
.wp-core-ui .button-primary {
    background: var(--nb-accent) !important;
    border-color: var(--nb-accent) !important;
    color: #fff !important;
    text-shadow: none !important;
    font-family: var(--nb-font-display);
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 4px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3) !important;
    transition: all 0.2s;
}

.wp-core-ui .button-primary:hover {
    background: #7B68EE !important;
    border-color: #7B68EE !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 10px rgba(147, 112, 219, 0.4) !important;
}

.wp-core-ui .button-secondary {
    background: transparent !important;
    border-color: var(--nb-border) !important;
    color: var(--nb-text) !important;
}

.wp-core-ui .button-secondary:hover {
    border-color: var(--nb-accent) !important;
    color: #fff !important;
}

/* Wrapper background (fix for list tables) */
.wp-list-table tr:nth-child(odd) {
    background: transparent !important;
}

.wp-list-table tr:nth-child(even),
.striped>tbody> :nth-child(odd) {
    background: rgba(255, 255, 255, 0.02) !important;
}

.wp-list-table tr:hover {
    background: rgba(147, 112, 219, 0.1) !important;
}

.wp-list-table th,
.wp-list-table td {
    color: var(--nb-text) !important;
}


/* =========================================
   Notification Center / Cleanup
   ========================================= */
.updated,
.error,
.notice {
    background: rgba(30, 30, 30, 0.95) !important;
    border: 1px solid #333 !important;
    border-left-width: 4px !important;
    backdrop-filter: blur(5px);
    color: #eee !important;
}

.notice-success {
    border-left-color: #46b450 !important;
}

.notice-error {
    border-left-color: #dc3232 !important;
}

.notice-info {
    border-left-color: var(--nb-accent) !important;
}

/* Custom Notification Sidebar */
#nb-notification-sidebar {
    position: fixed;
    top: 32px;
    right: -350px;
    width: 320px;
    height: calc(100% - 32px);
    background: rgba(10, 10, 10, 0.95);
    backdrop-filter: blur(20px);
    border-left: 1px solid var(--nb-border);
    z-index: 99999;
    padding: 20px;
    overflow-y: auto;
    transition: right 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    box-shadow: -10px 0 30px rgba(0, 0, 0, 0.5);
}

#nb-notification-sidebar.active {
    right: 0;
}

#nb-notification-sidebar h3 {
    font-family: var(--nb-font-display);
    color: var(--nb-accent);
    margin-top: 0;
    border-bottom: 1px solid var(--nb-border);
    padding-bottom: 10px;
    margin-bottom: 20px;
}

#nb-notification-toggle {
    position: fixed;
    top: 45px;
    right: 25px;
    z-index: 10000;
    background: var(--nb-accent);
    color: #fff;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 4px 15px rgba(147, 112, 219, 0.4);
    font-weight: bold;
    font-family: var(--nb-font-display);
    transition: transform 0.2s;
}

#nb-notification-toggle:hover {
    transform: scale(1.1);
}

#nb-notification-toggle .count {
    position: absolute;
    top: -5px;
    right: -5px;
    background: #dc3232;
    color: white;
    font-size: 10px;
    padding: 2px 6px;
    border-radius: 10px;
    border: 2px solid #000;
}