/* ============================================================
   NOVA FLUX - Futuristic RoundCube Skin
   A modern, futuristic email skin with blue & purple colors
   Extends: Elastic (RoundCube default)
   ============================================================ */

/* ============================================================
   CSS CUSTOM PROPERTIES (Design Tokens)
   Dark mode = default. Light mode toggled via elastic JS.
   ============================================================ */
:root {
    /* -- Sizing (shared) -- */
    --nf-radius-sm:      6px;
    --nf-radius-md:      10px;
    --nf-radius-lg:      16px;
    --nf-radius-xl:      24px;
    --nf-transition:     all 0.25s cubic-bezier(0.4, 0, 0.2, 1);

    /* -- Accent Colors (shared) -- */
    --nf-blue:           #29b6f6;
    --nf-blue-light:     #4fc3f7;
    --nf-blue-glow:      #0288d1;
    --nf-cyan:           #80deea;
    --nf-cyan-dim:       #4dd0e1;

    /* -- Gradients (shared) -- */
    --nf-gradient-primary:   linear-gradient(180deg, #0288d1 0%, #29b6f6 50%, #4fc3f7 100%);
    --nf-gradient-accent:    linear-gradient(135deg, #0277bd 0%, #0288d1 40%, #4fc3f7 100%);

    /* -- DARK MODE palette (default) -- */
    --nf-bg-deep:        #0b1a2e;
    --nf-bg-dark:        #0f2133;
    --nf-bg-card:        #122a3f;
    --nf-bg-surface:     #16334b;
    --nf-bg-elevated:    #1b3d58;
    --nf-bg-hover:       #1f4768;
    --nf-gradient-glow:      linear-gradient(180deg, rgba(2,136,209,0.15) 0%, rgba(79,195,247,0.1) 100%);
    --nf-gradient-sidebar:   linear-gradient(180deg, #0b1a2e 0%, #0f2a42 50%, #16374f 100%);
    --nf-gradient-toolbar:   linear-gradient(90deg, #0b1a2e 0%, #0f2133 50%, #0b1a2e 100%);
    --nf-text-primary:   #e0f0ff;
    --nf-text-secondary: #90c4e8;
    --nf-text-muted:     #5a92b5;
    --nf-text-accent:    #4fc3f7;
    --nf-text-bright:    #f5fbff;
    --nf-border:         rgba(41, 182, 246, 0.15);
    --nf-border-hover:   rgba(41, 182, 246, 0.3);
    --nf-border-active:  rgba(79, 195, 247, 0.5);
    --nf-divider:        rgba(90, 146, 181, 0.12);
    --nf-shadow-sm:      0 1px 3px rgba(0, 0, 0, 0.35);
    --nf-shadow-md:      0 4px 12px rgba(0, 0, 0, 0.4);
    --nf-shadow-lg:      0 8px 32px rgba(0, 0, 0, 0.5);
    --nf-shadow-glow:    0 0 20px rgba(41, 182, 246, 0.12), 0 0 40px rgba(2, 136, 209, 0.06);
    --nf-shadow-btn:     0 0 15px rgba(41, 182, 246, 0.3), 0 4px 12px rgba(0, 0, 0, 0.25);
    --nf-overlay-bg:     rgba(5, 15, 30, 0.8);

    /* Compat aliases */
    --nf-purple:         #29b6f6;
    --nf-purple-light:   #4fc3f7;
    --nf-purple-glow:    #0288d1;
    --nf-magenta:        #29b6f6;
}

/* ============================================================
   LIGHT MODE VARIABLES
   Applied when user toggles to "Mode clair" / light mode
   ============================================================ */
html:not(.dark-mode) {
    --nf-bg-deep:        #eef3f8;
    --nf-bg-dark:        #f5f7fa;
    --nf-bg-card:        #ffffff;
    --nf-bg-surface:     #f0f4f8;
    --nf-bg-elevated:    #e8eef4;
    --nf-bg-hover:       #dce6f0;
    --nf-gradient-glow:      linear-gradient(180deg, rgba(2,136,209,0.08) 0%, rgba(79,195,247,0.05) 100%);
    --nf-gradient-sidebar:   linear-gradient(180deg, #e8eef4 0%, #f0f4f8 50%, #f5f7fa 100%);
    --nf-gradient-toolbar:   linear-gradient(90deg, #f0f4f8 0%, #f5f7fa 50%, #f0f4f8 100%);
    --nf-text-primary:   #1a2b3c;
    --nf-text-secondary: #3d5a73;
    --nf-text-muted:     #7a95aa;
    --nf-text-accent:    #0277bd;
    --nf-text-bright:    #0b1a2e;
    --nf-border:         rgba(11, 26, 46, 0.1);
    --nf-border-hover:   rgba(11, 26, 46, 0.2);
    --nf-border-active:  rgba(2, 136, 209, 0.4);
    --nf-divider:        rgba(11, 26, 46, 0.06);
    --nf-shadow-sm:      0 1px 3px rgba(0, 0, 0, 0.08);
    --nf-shadow-md:      0 4px 12px rgba(0, 0, 0, 0.1);
    --nf-shadow-lg:      0 8px 32px rgba(0, 0, 0, 0.12);
    --nf-shadow-glow:    0 0 20px rgba(41, 182, 246, 0.06), 0 0 40px rgba(2, 136, 209, 0.03);
    --nf-shadow-btn:     0 0 15px rgba(41, 182, 246, 0.15), 0 4px 12px rgba(0, 0, 0, 0.1);
    --nf-overlay-bg:     rgba(0, 0, 0, 0.4);
    --nf-purple:         #0277bd;
    --nf-purple-light:   #0288d1;
    --nf-purple-glow:    #01579b;
    --nf-magenta:        #0277bd;
}

/* ============================================================
   GLOBAL RESETS & BASE
   ============================================================ */
html {
    background: var(--nf-bg-deep) !important;
    color: var(--nf-text-primary) !important;
    font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif !important;
}

html.dark-mode {
    scrollbar-color: var(--nf-bg-elevated) var(--nf-bg-dark);
}

body {
    background: var(--nf-bg-deep) !important;
    color: var(--nf-text-primary) !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Custom scrollbar */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
::-webkit-scrollbar-track {
    background: var(--nf-bg-dark);
}
::-webkit-scrollbar-thumb {
    background: var(--nf-bg-elevated);
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
    background: var(--nf-blue);
}

/* Selection */
::selection {
    background: rgba(41, 182, 246, 0.35);
    color: #fff;
}

/* ============================================================
   LAYOUT SYSTEM
   ============================================================ */
#layout {
    background: var(--nf-bg-deep) !important;
}

#layout > div {
    background: transparent !important;
}

/* ============================================================
   SIDEBAR / FOLDER LIST
   ============================================================ */
#layout-sidebar,
#layout-sidebar .scroller {
    background: var(--nf-gradient-sidebar) !important;
    border-right: 1px solid var(--nf-border) !important;
}

/* Sidebar header */
#layout-sidebar .header {
    background: var(--nf-bg-elevated) !important;
    border-bottom: 1px solid var(--nf-border) !important;
    backdrop-filter: blur(12px);
}

/* Folder tree */
#mailboxlist li a,
#mailboxlist li span.listname,
.folderlist li a {
    color: var(--nf-text-secondary) !important;
    transition: var(--nf-transition);
    border-radius: var(--nf-radius-sm);
    padding: 6px 12px !important;
}

#mailboxlist li a:hover,
.folderlist li a:hover {
    background: var(--nf-bg-hover) !important;
    color: var(--nf-text-bright) !important;
}

#mailboxlist li.selected > a,
#mailboxlist li a.focused,
.folderlist li.selected > a {
    background: var(--nf-gradient-glow) !important;
    color: var(--nf-blue-light) !important;
    border-left: 3px solid var(--nf-blue) !important;
    box-shadow: inset 0 0 20px rgba(41, 182, 246, 0.08);
}

/* Unread badge */
#mailboxlist .unreadcount,
.folderlist .unreadcount {
    background: var(--nf-gradient-primary) !important;
    color: #fff !important;
    font-weight: 600 !important;
    border-radius: 12px !important;
    padding: 1px 8px !important;
    font-size: 11px !important;
    box-shadow: 0 0 8px rgba(41, 182, 246, 0.3);
}

/* ============================================================
   TOOLBAR / NAVIGATION BAR
   (Excludes #layout-menu which is styled separately above)
   ============================================================ */
#layout-sidebar .toolbar,
#layout-list .toolbar,
#layout-content .toolbar,
.toolbar:not(#taskmenu),
#layout .toolbar,
.header:not(.popover-header) {
    background: var(--nf-gradient-toolbar) !important;
    border-bottom: 1px solid var(--nf-border) !important;
    backdrop-filter: blur(12px);
}

/* Toolbar buttons (content toolbars only, not left menu) */
#layout-sidebar .toolbar a,
#layout-list .toolbar a,
#layout-content .toolbar a,
.toolbar a,
.toolbar a.button {
    color: var(--nf-text-secondary) !important;
    transition: var(--nf-transition);
    border-radius: var(--nf-radius-sm) !important;
    position: relative;
}

#layout-sidebar .toolbar a:hover,
#layout-list .toolbar a:hover,
#layout-content .toolbar a:hover,
.toolbar a:hover,
.toolbar a.button:hover {
    color: var(--nf-text-bright) !important;
    background: var(--nf-bg-hover) !important;
}

.toolbar a.active,
.toolbar a.button.active {
    color: var(--nf-blue-light) !important;
    background: rgba(41, 182, 246, 0.12) !important;
}

/* Taskmenu icons glow on active */
#layout-menu #taskmenu a.selected::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 24px;
    height: 3px;
    background: var(--nf-gradient-primary);
    border-radius: 3px;
    box-shadow: 0 0 8px rgba(41, 182, 246, 0.5);
}

/* ============================================================
   MESSAGE LIST
   ============================================================ */
#layout-list,
#layout-list .scroller {
    background: var(--nf-bg-dark) !important;
}

/* Message list header */
#layout-list .header {
    background: var(--nf-bg-elevated) !important;
    border-bottom: 1px solid var(--nf-border) !important;
}

/* Message rows */
.messagelist tr,
#message-list tr {
    border-bottom: 1px solid var(--nf-divider) !important;
    transition: var(--nf-transition);
}

.messagelist tr td,
#message-list tr td {
    color: var(--nf-text-secondary) !important;
    border-color: var(--nf-divider) !important;
}

/* Unread messages */
.messagelist tr.unread td,
#message-list tr.unread td {
    color: var(--nf-text-bright) !important;
    font-weight: 600 !important;
}

.messagelist tr.unread td.subject span {
    color: var(--nf-text-bright) !important;
}

/* Hover state */
.messagelist tr:hover,
#message-list tr:hover {
    background: var(--nf-bg-surface) !important;
}

/* Selected / focused message */
.messagelist tr.selected td,
#message-list tr.selected td,
.messagelist tr.focused td {
    background: rgba(41, 182, 246, 0.1) !important;
    color: var(--nf-text-bright) !important;
}

.messagelist tr.selected td,
#message-list tr.selected td {
    border-left: 3px solid var(--nf-blue) !important;
}

/* Flagged messages */
.messagelist tr.flagged td.subject span {
    color: var(--nf-cyan) !important;
}

/* Thread indicators */
.messagelist td.threads div {
    color: var(--nf-text-muted) !important;
}

/* ============================================================
   MESSAGE CONTENT AREA
   ============================================================ */
#layout-content,
#layout-content .scroller {
    background: var(--nf-bg-dark) !important;
}

/* Message headers */
.message-header,
#message-header,
.header-title {
    background: var(--nf-bg-card) !important;
    border-bottom: 1px solid var(--nf-border) !important;
    color: var(--nf-text-primary) !important;
}

.message-header .header-title .subject {
    color: var(--nf-text-bright) !important;
    font-weight: 600;
}

/* Message body */
#message-content,
.message-part,
#messagebody {
    background: var(--nf-bg-card) !important;
    color: var(--nf-text-primary) !important;
    border-radius: var(--nf-radius-md);
    padding: 16px !important;
}

/* Quoted text styling */
blockquote {
    border-left: 3px solid var(--nf-purple) !important;
    padding-left: 12px !important;
    color: var(--nf-text-muted) !important;
}

/* Attachments */
.attachmentslist li,
#attachment-list li {
    background: var(--nf-bg-surface) !important;
    border: 1px solid var(--nf-border) !important;
    border-radius: var(--nf-radius-sm) !important;
    color: var(--nf-text-secondary) !important;
    transition: var(--nf-transition);
}

.attachmentslist li:hover,
#attachment-list li:hover {
    background: var(--nf-bg-hover) !important;
    border-color: var(--nf-border-hover) !important;
    color: var(--nf-text-bright) !important;
}

/* ============================================================
   COMPOSE FORM
   ============================================================ */
#compose-content,
#composebody,
.compose-header {
    background: var(--nf-bg-card) !important;
}

#composebody,
#composebodycontainer,
textarea._from,
textarea.form-control {
    background: var(--nf-bg-surface) !important;
    color: var(--nf-text-primary) !important;
    border: 1px solid var(--nf-border) !important;
    border-radius: var(--nf-radius-md) !important;
}

/* ============================================================
   FORM CONTROLS
   ============================================================ */
input[type="text"],
input[type="password"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="number"],
select,
textarea,
.form-control {
    background: var(--nf-bg-surface) !important;
    color: var(--nf-text-primary) !important;
    border: 1px solid var(--nf-border) !important;
    border-radius: var(--nf-radius-sm) !important;
    transition: var(--nf-transition);
    padding: 8px 12px !important;
}

input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus,
.form-control:focus {
    border-color: var(--nf-blue) !important;
    box-shadow: 0 0 0 3px rgba(41, 182, 246, 0.15), 0 0 12px rgba(41, 182, 246, 0.1) !important;
    outline: none !important;
    background: var(--nf-bg-elevated) !important;
}

/* Placeholders */
::placeholder {
    color: var(--nf-text-muted) !important;
    opacity: 0.7;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn,
button,
input[type="submit"],
input[type="button"],
.button {
    transition: var(--nf-transition);
    border-radius: var(--nf-radius-sm) !important;
    font-weight: 500 !important;
    letter-spacing: 0.01em;
}

/* Primary buttons */
.btn-primary,
.btn.submit,
input[type="submit"],
.mainaction {
    background: var(--nf-gradient-primary) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: var(--nf-shadow-btn) !important;
    text-transform: none;
    padding: 8px 20px !important;
}

.btn-primary:hover,
.btn.submit:hover,
input[type="submit"]:hover,
.mainaction:hover {
    box-shadow: 0 0 24px rgba(41, 182, 246, 0.4), 0 6px 16px rgba(0, 0, 0, 0.3) !important;
    transform: translateY(-1px);
    filter: brightness(1.1);
}

.btn-primary:active,
.btn.submit:active,
input[type="submit"]:active,
.mainaction:active {
    transform: translateY(0);
    filter: brightness(0.95);
}

/* Secondary buttons */
.btn-secondary,
.btn.cancel {
    background: var(--nf-bg-surface) !important;
    color: var(--nf-text-secondary) !important;
    border: 1px solid var(--nf-border) !important;
}

.btn-secondary:hover,
.btn.cancel:hover {
    background: var(--nf-bg-hover) !important;
    color: var(--nf-text-bright) !important;
    border-color: var(--nf-border-hover) !important;
}

/* Danger buttons */
.btn-danger {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
    color: #fff !important;
    border: none !important;
}

/* ============================================================
   DROPDOWN MENUS & POPUPS
   ============================================================ */
.popupmenu,
.dropdown-menu,
.popup,
.ui-dialog,
.ui-autocomplete,
.menu {
    background: var(--nf-bg-card) !important;
    border: 1px solid var(--nf-border) !important;
    border-radius: var(--nf-radius-md) !important;
    box-shadow: var(--nf-shadow-lg), var(--nf-shadow-glow) !important;
    backdrop-filter: blur(20px);
    overflow: hidden;
}

.popupmenu li a,
.dropdown-menu li a,
.menu li a {
    color: var(--nf-text-secondary) !important;
    transition: var(--nf-transition);
    padding: 8px 16px !important;
}

.popupmenu li a:hover,
.dropdown-menu li a:hover,
.menu li a:hover {
    background: var(--nf-bg-hover) !important;
    color: var(--nf-text-bright) !important;
}

.popupmenu li a.active,
.dropdown-menu li a.active,
.menu li a.active {
    background: rgba(41, 182, 246, 0.12) !important;
    color: var(--nf-blue-light) !important;
}

/* ============================================================
   DIALOGS & MODALS
   ============================================================ */
.ui-dialog {
    background: var(--nf-bg-card) !important;
    border: 1px solid var(--nf-border-hover) !important;
    border-radius: var(--nf-radius-lg) !important;
    box-shadow: var(--nf-shadow-lg), 0 0 60px rgba(41, 182, 246, 0.08) !important;
}

.ui-dialog .ui-dialog-titlebar {
    background: var(--nf-bg-surface) !important;
    border-bottom: 1px solid var(--nf-border) !important;
    color: var(--nf-text-bright) !important;
    border-radius: var(--nf-radius-lg) var(--nf-radius-lg) 0 0 !important;
}

.ui-dialog .ui-dialog-content {
    color: var(--nf-text-primary) !important;
}

.ui-dialog .ui-dialog-buttonpane {
    background: var(--nf-bg-surface) !important;
    border-top: 1px solid var(--nf-border) !important;
}

/* Overlay */
.ui-widget-overlay {
    background: var(--nf-overlay-bg) !important;
    backdrop-filter: blur(4px);
}

/* ============================================================
   SEARCH BAR
   ============================================================ */
.searchbar,
#searchbar,
.searchbox {
    background: var(--nf-bg-surface) !important;
    border: 1px solid var(--nf-border) !important;
    border-radius: var(--nf-radius-xl) !important;
    overflow: hidden;
}

.searchbar input,
#searchbar input,
.searchbox input {
    background: transparent !important;
    color: var(--nf-text-primary) !important;
    border: none !important;
}

.searchbar:focus-within,
#searchbar:focus-within,
.searchbox:focus-within {
    border-color: var(--nf-blue) !important;
    box-shadow: 0 0 0 3px rgba(41, 182, 246, 0.12), 0 0 20px rgba(41, 182, 246, 0.08) !important;
}

/* ============================================================
   SETTINGS PAGE
   ============================================================ */
#sections-table,
#sections-table tr,
#settings-sections,
.propform,
.propform fieldset {
    background: transparent !important;
    border-color: var(--nf-border) !important;
}

.propform fieldset legend,
.propform .row .title,
.propform label {
    color: var(--nf-text-secondary) !important;
}

.listing tbody tr td {
    color: var(--nf-text-secondary) !important;
    border-color: var(--nf-divider) !important;
}

.listing tbody tr:hover td {
    background: var(--nf-bg-surface) !important;
    color: var(--nf-text-bright) !important;
}

.listing tbody tr.selected td {
    background: rgba(41, 182, 246, 0.12) !important;
    color: var(--nf-blue-light) !important;
}

/* ============================================================
   ADDRESS BOOK / CONTACTS
   ============================================================ */
#contacts-table tr,
#directorylist li,
.contactlist tr {
    border-color: var(--nf-divider) !important;
    transition: var(--nf-transition);
}

#contacts-table tr:hover,
#directorylist li:hover,
.contactlist tr:hover {
    background: var(--nf-bg-surface) !important;
}

#contacts-table tr.selected,
#directorylist li.selected,
.contactlist tr.selected {
    background: rgba(41, 182, 246, 0.12) !important;
}

/* Contact photo placeholder */
.contactphoto,
.contact-photo {
    background: var(--nf-bg-elevated) !important;
    border: 2px solid var(--nf-border) !important;
    border-radius: 50% !important;
}

/* ============================================================
   LOGIN PAGE
   ============================================================ */
body.task-login {
    background: var(--nf-bg-deep) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    position: relative;
    overflow: hidden;
}

/* Animated background on login */
body.task-login::before {
    content: '';
    position: fixed;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background:
        radial-gradient(ellipse at 20% 50%, rgba(41, 182, 246, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(2, 136, 209, 0.1) 0%, transparent 50%),
        radial-gradient(ellipse at 50% 80%, rgba(79, 195, 247, 0.06) 0%, transparent 50%);
    animation: nf-aurora 20s ease-in-out infinite alternate;
    z-index: 0;
    pointer-events: none;
}

@keyframes nf-aurora {
    0% { transform: translate(0, 0) rotate(0deg); }
    33% { transform: translate(2%, -1%) rotate(1deg); }
    66% { transform: translate(-1%, 2%) rotate(-1deg); }
    100% { transform: translate(1%, -2%) rotate(0.5deg); }
}

/* Grid pattern overlay on login */
body.task-login::after {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image:
        linear-gradient(rgba(41, 182, 246, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(41, 182, 246, 0.03) 1px, transparent 1px);
    background-size: 40px 40px;
    z-index: 0;
    pointer-events: none;
}

/* Login container */
body.task-login #layout-content {
    background: var(--nf-bg-card) !important;
    border: 1px solid var(--nf-border-hover) !important;
    border-radius: var(--nf-radius-xl) !important;
    box-shadow:
        var(--nf-shadow-lg),
        0 0 60px rgba(41, 182, 246, 0.08),
        0 0 120px rgba(2, 136, 209, 0.06) !important;
    position: relative;
    z-index: 1;
    max-width: 420px !important;
    padding: 48px 40px !important;
    backdrop-filter: blur(20px);
}

/* Login logo (wibyo wordmark - white on dark) */
body.task-login #logo {
    display: block !important;
    max-width: 220px !important;
    width: 220px !important;
    height: auto !important;
    margin: 0 auto 36px auto !important;
    filter: drop-shadow(0 0 18px rgba(41, 182, 246, 0.25)) drop-shadow(0 0 40px rgba(41, 182, 246, 0.12));
}

/* Ensure the logo image itself displays correctly */
#logo img,
#logo svg {
    width: 100% !important;
    height: auto !important;
}

/* Sidebar logo (W favicon icon) — smaller square icon in the menu header */
#layout-menu .popover-header #logo {
    display: block !important;
    width: 32px !important;
    max-width: 32px !important;
    height: auto !important;
    object-fit: contain;
    margin: 6px auto;
    padding: 2px 0;
    filter: none;
}

/* When sidebar is in collapsed/icon mode (narrow strip) */
#layout-menu #logo {
    display: block !important;
    width: 28px !important;
    max-width: 28px !important;
    height: auto !important;
    object-fit: contain;
    margin: 8px auto 4px auto;
    padding: 0;
}

/* Login form inputs */
body.task-login .form-control,
body.task-login input[type="text"],
body.task-login input[type="password"] {
    background: var(--nf-bg-surface) !important;
    border: 1px solid var(--nf-border) !important;
    border-radius: var(--nf-radius-md) !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    color: var(--nf-text-primary) !important;
}

body.task-login .form-control:focus,
body.task-login input[type="text"]:focus,
body.task-login input[type="password"]:focus {
    border-color: var(--nf-blue) !important;
    box-shadow: 0 0 0 3px rgba(41, 182, 246, 0.15), 0 0 20px rgba(41, 182, 246, 0.1) !important;
}

/* Login submit button */
body.task-login input[type="submit"],
body.task-login .btn-primary,
body.task-login .button.mainaction {
    background: var(--nf-gradient-primary) !important;
    border: none !important;
    border-radius: var(--nf-radius-md) !important;
    padding: 12px 24px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    letter-spacing: 0.03em;
    width: 100%;
    box-shadow: var(--nf-shadow-btn) !important;
    text-transform: none !important;
    cursor: pointer;
}

body.task-login input[type="submit"]:hover,
body.task-login .btn-primary:hover,
body.task-login .button.mainaction:hover {
    box-shadow: 0 0 30px rgba(41, 182, 246, 0.4), 0 8px 24px rgba(0, 0, 0, 0.3) !important;
    transform: translateY(-2px);
}

/* Login footer */
#login-footer {
    color: var(--nf-text-muted) !important;
    margin-top: 24px !important;
    font-size: 12px !important;
}

#login-footer a {
    color: var(--nf-blue-light) !important;
}

/* ============================================================
   CHECKBOXES & RADIO BUTTONS (Custom)
   ============================================================ */
.custom-control-input:checked ~ .custom-control-label::before,
input[type="checkbox"]:checked + label::before {
    background-color: var(--nf-blue) !important;
    border-color: var(--nf-blue) !important;
    box-shadow: 0 0 6px rgba(41, 182, 246, 0.3) !important;
}

.custom-switch .custom-control-input:checked ~ .custom-control-label::before {
    background: var(--nf-gradient-primary) !important;
    border-color: var(--nf-blue) !important;
}

/* ============================================================
   TABS & NAV
   ============================================================ */
.nav-tabs,
.tabsbar {
    border-bottom: 1px solid var(--nf-border) !important;
    background: transparent !important;
}

.nav-tabs .nav-link,
.tabsbar a {
    color: var(--nf-text-muted) !important;
    border: none !important;
    transition: var(--nf-transition);
    position: relative;
}

.nav-tabs .nav-link:hover,
.tabsbar a:hover {
    color: var(--nf-text-primary) !important;
    background: transparent !important;
}

.nav-tabs .nav-link.active,
.tabsbar a.selected {
    color: var(--nf-blue-light) !important;
    background: transparent !important;
    border: none !important;
}

.nav-tabs .nav-link.active::after,
.tabsbar a.selected::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--nf-gradient-primary);
    border-radius: 3px 3px 0 0;
}

/* ============================================================
   PAGINATION
   ============================================================ */
.pagenav,
.countdisplay {
    color: var(--nf-text-muted) !important;
}

.pagenav a {
    color: var(--nf-text-secondary) !important;
}

.pagenav a:hover {
    color: var(--nf-blue-light) !important;
}

/* ============================================================
   LOADING / SPINNER
   ============================================================ */
.loading,
.spinner {
    color: var(--nf-blue-light) !important;
}

/* ============================================================
   NOTIFICATION / ALERT MESSAGES
   ============================================================ */
#messagestack,
#message {
    z-index: 9999;
}

#messagestack div,
.ui.alert {
    border-radius: var(--nf-radius-md) !important;
    border: 1px solid var(--nf-border) !important;
    backdrop-filter: blur(16px);
    box-shadow: var(--nf-shadow-md) !important;
}

#messagestack div.notice,
.ui.alert.notice {
    background: rgba(41, 182, 246, 0.15) !important;
    color: var(--nf-blue-light) !important;
    border-color: rgba(41, 182, 246, 0.3) !important;
}

#messagestack div.confirmation,
.ui.alert.confirmation {
    background: rgba(34, 197, 94, 0.15) !important;
    color: #4ade80 !important;
    border-color: rgba(34, 197, 94, 0.3) !important;
}

#messagestack div.error,
#messagestack div.warning,
.ui.alert.error,
.ui.alert.warning {
    background: rgba(239, 68, 68, 0.15) !important;
    color: #f87171 !important;
    border-color: rgba(239, 68, 68, 0.3) !important;
}

/* ============================================================
   TOOLTIPS
   ============================================================ */
.tooltip .tooltip-inner {
    background: var(--nf-bg-elevated) !important;
    color: var(--nf-text-primary) !important;
    border: 1px solid var(--nf-border) !important;
    border-radius: var(--nf-radius-sm) !important;
    box-shadow: var(--nf-shadow-md) !important;
    font-size: 12px;
}

/* ============================================================
   TABLE GENERAL
   ============================================================ */
table {
    border-color: var(--nf-divider) !important;
}

th {
    color: var(--nf-text-muted) !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    font-size: 11px !important;
    letter-spacing: 0.05em;
    border-color: var(--nf-border) !important;
}

td {
    border-color: var(--nf-divider) !important;
    color: var(--nf-text-secondary) !important;
}

/* ============================================================
   LINKS
   ============================================================ */
a {
    color: var(--nf-blue-light) !important;
    transition: var(--nf-transition);
}

a:hover {
    color: var(--nf-cyan) !important;
    text-decoration: none !important;
}

/* ============================================================
   ICON OVERRIDES (Bootstrap Icons / Font Awesome)
   ============================================================ */
.toolbar a::before,
#layout-menu #taskmenu a::before,
.listbox .header a::before,
.menu a::before {
    transition: var(--nf-transition);
}

.toolbar a:hover::before,
#layout-menu #taskmenu a:hover::before {
    filter: drop-shadow(0 0 4px rgba(41, 182, 246, 0.4));
}

/* ============================================================
   RESPONSIVE STYLES
   ============================================================ */
@media screen and (max-width: 768px) {
    body.task-login #layout-content {
        margin: 16px !important;
        padding: 32px 24px !important;
        border-radius: var(--nf-radius-lg) !important;
    }

    .toolbar,
    #layout .toolbar {
        padding: 4px 8px !important;
    }
}

@media screen and (max-width: 480px) {
    body.task-login #layout-content {
        padding: 24px 20px !important;
        border-radius: var(--nf-radius-md) !important;
    }
}

/* ============================================================
   WATERMARK / EMPTY STATE
   The watermark is rendered via watermark.html in an iframe.
   These styles ensure the iframe container blends seamlessly.
   ============================================================ */
.watermark {
    opacity: 0.06 !important;
}

/* Ensure content frame (which loads watermark.html) matches our theme */
#messagecontframe,
iframe[name="messagecontframe"] {
    background: var(--nf-bg-dark) !important;
    border: none !important;
}

/* ============================================================
   LISTBOX ITEMS (generic)
   ============================================================ */
.listbox .listing li,
.listbox .listing tr {
    transition: var(--nf-transition);
}

.listbox .listing li:hover,
.listbox .listing tr:hover {
    background: var(--nf-bg-surface) !important;
}

.listbox .listing li.selected,
.listbox .listing tr.selected,
.listbox .listing li.focused,
.listbox .listing tr.focused {
    background: rgba(41, 182, 246, 0.1) !important;
}

/* ============================================================
   FROSTED GLASS PANELS
   ============================================================ */
.content.frame-content {
    background: var(--nf-bg-card) !important;
}

/* iframes */
.iframe-wrapper iframe,
iframe.content-frame {
    background: var(--nf-bg-card) !important;
}

/* ============================================================
   PRINT STYLES
   ============================================================ */
@media print {
    body {
        background: #fff !important;
        color: #000 !important;
    }
}

/* ============================================================
   NOSCRIPT WARNING
   ============================================================ */
.noscriptwarning {
    background: rgba(239, 68, 68, 0.15) !important;
    color: #f87171 !important;
    border: 1px solid rgba(239, 68, 68, 0.3) !important;
    border-radius: var(--nf-radius-md) !important;
    padding: 16px 24px !important;
}

/* ============================================================
   SUBTLE FUTURISTIC ACCENTS
   ============================================================ */

/* Glowing line separator on top of content */
#layout-content::before {
    content: '';
    display: block;
    height: 1px;
    background: var(--nf-gradient-accent);
    opacity: 0.4;
}

/* Sidebar subtle glow line */
#layout-sidebar::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 1px;
    height: 100%;
    background: linear-gradient(180deg, transparent 0%, rgba(41, 182, 246, 0.2) 50%, transparent 100%);
    pointer-events: none;
}

/* Corner accent on login card */
body.task-login #layout-content::before {
    content: '';
    position: absolute;
    top: -1px;
    left: 20%;
    right: 20%;
    height: 2px;
    background: var(--nf-gradient-primary);
    border-radius: 0 0 4px 4px;
    opacity: 0.8;
}

body.task-login #layout-content::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 30%;
    right: 30%;
    height: 1px;
    background: var(--nf-gradient-primary);
    border-radius: 4px 4px 0 0;
    opacity: 0.4;
}

/* ============================================================
   LEFT MENU STRIP — explicit for both modes
   The narrow left icon strip (#layout-menu) must be styled
   independently from toolbars/headers to avoid conflicts.
   ============================================================ */
#layout-menu {
    background: var(--nf-gradient-sidebar) !important;
    border-right: 1px solid var(--nf-border) !important;
}

#layout-menu .popover-header {
    background: transparent !important;
    border-bottom: 1px solid var(--nf-border) !important;
}

#layout-menu #taskmenu {
    background: transparent !important;
}

#layout-menu #taskmenu a {
    color: var(--nf-text-secondary) !important;
}

#layout-menu #taskmenu a:hover {
    color: var(--nf-text-bright) !important;
    background: var(--nf-bg-hover) !important;
}

#layout-menu #taskmenu a.selected {
    color: var(--nf-blue-light) !important;
    background: rgba(41, 182, 246, 0.12) !important;
}

/* Fix text overflow in the narrow left menu strip — labels get clipped */
#layout-menu #taskmenu .special-buttons a .inner,
#layout-menu #taskmenu .action-buttons a .inner,
#layout-menu #taskmenu a .inner {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    display: block;
}

/* ============================================================
   DARK MODE EXPLICIT
   ============================================================ */
html.dark-mode body,
html.dark-mode #layout {
    background: var(--nf-bg-deep) !important;
    color: var(--nf-text-primary) !important;
}

/* ============================================================
   BOOTSTRAP OVERRIDES
   ============================================================ */
.card {
    background: var(--nf-bg-card) !important;
    border: 1px solid var(--nf-border) !important;
    border-radius: var(--nf-radius-md) !important;
}

.card-header {
    background: var(--nf-bg-surface) !important;
    border-bottom: 1px solid var(--nf-border) !important;
    color: var(--nf-text-bright) !important;
}

.card-body {
    color: var(--nf-text-primary) !important;
}

.list-group-item {
    background: var(--nf-bg-card) !important;
    border-color: var(--nf-divider) !important;
    color: var(--nf-text-secondary) !important;
}

.list-group-item:hover {
    background: var(--nf-bg-surface) !important;
    color: var(--nf-text-bright) !important;
}

.list-group-item.active {
    background: rgba(41, 182, 246, 0.12) !important;
    border-color: var(--nf-border-active) !important;
    color: var(--nf-blue-light) !important;
}

.badge {
    border-radius: 12px !important;
}

.badge-primary,
.badge.bg-primary {
    background: var(--nf-gradient-primary) !important;
    color: #fff !important;
}

/* ============================================================
   PROGRESS BAR (file upload etc.)
   ============================================================ */
.progress {
    background: var(--nf-bg-surface) !important;
    border-radius: var(--nf-radius-sm) !important;
    overflow: hidden;
}

.progress-bar {
    background: var(--nf-gradient-primary) !important;
    box-shadow: 0 0 8px rgba(41, 182, 246, 0.3);
}

/* ============================================================
   QUOTA BAR
   ============================================================ */
.quotadisplay .bar {
    background: var(--nf-bg-surface) !important;
    border-radius: var(--nf-radius-sm) !important;
}

.quotadisplay .bar .value {
    background: var(--nf-gradient-primary) !important;
    border-radius: var(--nf-radius-sm) !important;
}

/* ============================================================
   RESPONSIVE LAYOUT SIDEBAR TOGGLE
   ============================================================ */
.menu-button,
.back-button {
    color: var(--nf-text-secondary) !important;
}

.menu-button:hover,
.back-button:hover {
    color: var(--nf-blue-light) !important;
}

/* ============================================================
   ANIMATED FOCUS RING (Futuristic glow)
   ============================================================ */
*:focus-visible {
    outline: 2px solid var(--nf-blue) !important;
    outline-offset: 2px;
    box-shadow: 0 0 0 4px rgba(41, 182, 246, 0.1) !important;
}

/* ============================================================
   LIGHT MODE — COMPREHENSIVE OVERRIDES
   Elastic toggles .dark-mode class on <html>.
   When absent → light mode. We override EVERY structural
   element so nothing inherits the dark defaults.
   ============================================================ */

/* -- Base backgrounds -- */
html:not(.dark-mode),
html:not(.dark-mode) body {
    background: linear-gradient(135deg, #e8f0fe 0%, #f0f4f8 40%, #eef3f8 100%) !important;
    color: #1a2b3c !important;
}

html:not(.dark-mode) #layout {
    background: transparent !important;
}

html:not(.dark-mode) #layout > div {
    background: transparent !important;
}

/* -- LEFT MENU STRIP (#layout-menu) -- */
html:not(.dark-mode) #layout-menu {
    background: linear-gradient(180deg, #ffffff 0%, #f8fafd 100%) !important;
    border-right: 1px solid rgba(2, 136, 209, 0.1) !important;
    box-shadow: 2px 0 12px rgba(2, 136, 209, 0.04) !important;
}

html:not(.dark-mode) #layout-menu .popover-header {
    background: transparent !important;
    border-bottom: 1px solid rgba(2, 136, 209, 0.08) !important;
}

html:not(.dark-mode) #layout-menu #taskmenu {
    background: transparent !important;
}

html:not(.dark-mode) #layout-menu #taskmenu a,
html:not(.dark-mode) #layout-menu #taskmenu a .inner {
    color: #5a7a94 !important;
}

html:not(.dark-mode) #layout-menu #taskmenu a:hover,
html:not(.dark-mode) #layout-menu #taskmenu a:hover .inner {
    color: #0277bd !important;
    background: rgba(2, 136, 209, 0.06) !important;
}

html:not(.dark-mode) #layout-menu #taskmenu a.selected,
html:not(.dark-mode) #layout-menu #taskmenu a.selected .inner {
    color: #0277bd !important;
    background: rgba(2, 136, 209, 0.1) !important;
}

html:not(.dark-mode) #layout-menu #taskmenu a.selected::after {
    background: linear-gradient(90deg, #0288d1, #29b6f6) !important;
    box-shadow: 0 0 10px rgba(2, 136, 209, 0.4);
}

/* Compose FAB button in light mode */
html:not(.dark-mode) #layout-menu #taskmenu a.compose {
    color: #fff !important;
}

/* Left menu special-buttons: ensure text doesn't overflow the narrow strip */
html:not(.dark-mode) #layout-menu #taskmenu .special-buttons a .inner {
    color: inherit !important;
    font-size: 11px !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* -- SIDEBAR / FOLDER LIST -- */
html:not(.dark-mode) #layout-sidebar,
html:not(.dark-mode) #layout-sidebar .scroller {
    background: linear-gradient(180deg, #f8fafd 0%, #f2f6fa 100%) !important;
    border-right: 1px solid rgba(2, 136, 209, 0.08) !important;
}

html:not(.dark-mode) #layout-sidebar .header {
    background: rgba(255, 255, 255, 0.8) !important;
    border-bottom: 1px solid rgba(2, 136, 209, 0.08) !important;
    backdrop-filter: blur(12px);
}

/* Folder email address header */
html:not(.dark-mode) #layout-sidebar .header a,
html:not(.dark-mode) #layout-sidebar .header .header-title,
html:not(.dark-mode) #layout-sidebar .header span {
    color: #1a2b3c !important;
}

html:not(.dark-mode) #mailboxlist li a,
html:not(.dark-mode) #mailboxlist li span.listname,
html:not(.dark-mode) .folderlist li a {
    color: #3d5a73 !important;
}

html:not(.dark-mode) #mailboxlist li a:hover,
html:not(.dark-mode) .folderlist li a:hover {
    background: rgba(2, 136, 209, 0.06) !important;
    color: #0b1a2e !important;
}

html:not(.dark-mode) #mailboxlist li.selected > a,
html:not(.dark-mode) #mailboxlist li a.focused,
html:not(.dark-mode) .folderlist li.selected > a {
    background: linear-gradient(90deg, rgba(2, 136, 209, 0.1) 0%, rgba(2, 136, 209, 0.04) 100%) !important;
    color: #0277bd !important;
    border-left: 3px solid #0288d1 !important;
    box-shadow: inset 0 0 20px rgba(2, 136, 209, 0.04);
}

html:not(.dark-mode) #mailboxlist .unreadcount,
html:not(.dark-mode) .folderlist .unreadcount {
    box-shadow: 0 0 8px rgba(2, 136, 209, 0.2);
}

/* Sidebar glow line — subtle in light mode */
html:not(.dark-mode) #layout-sidebar::after {
    background: linear-gradient(180deg, transparent 0%, rgba(2, 136, 209, 0.08) 50%, transparent 100%);
}

/* -- TOOLBARS -- */
html:not(.dark-mode) .toolbar,
html:not(.dark-mode) #layout .toolbar {
    background: rgba(255, 255, 255, 0.85) !important;
    border-bottom: 1px solid rgba(2, 136, 209, 0.08) !important;
    backdrop-filter: blur(12px);
}

html:not(.dark-mode) .header {
    background: rgba(255, 255, 255, 0.85) !important;
    border-bottom: 1px solid rgba(2, 136, 209, 0.08) !important;
    backdrop-filter: blur(12px);
}

html:not(.dark-mode) .toolbar a,
html:not(.dark-mode) .toolbar a.button {
    color: #5a7a94 !important;
}

html:not(.dark-mode) .toolbar a:hover,
html:not(.dark-mode) .toolbar a.button:hover {
    color: #0277bd !important;
    background: rgba(2, 136, 209, 0.06) !important;
}

html:not(.dark-mode) .toolbar a.active,
html:not(.dark-mode) .toolbar a.button.active {
    color: #0277bd !important;
    background: rgba(2, 136, 209, 0.1) !important;
}

/* Active toolbar text labels (like "Sélecti..." "Options" etc.) */
html:not(.dark-mode) .toolbar a.selected,
html:not(.dark-mode) .toolbar a.button.selected {
    color: #0277bd !important;
    background: rgba(2, 136, 209, 0.1) !important;
}

/* Toolbar icon labels */
html:not(.dark-mode) .toolbar a .inner,
html:not(.dark-mode) .toolbar a.button .inner {
    color: inherit !important;
}

/* -- MESSAGE LIST -- */
html:not(.dark-mode) #layout-list,
html:not(.dark-mode) #layout-list .scroller {
    background: #ffffff !important;
}

html:not(.dark-mode) #layout-list .header {
    background: rgba(255, 255, 255, 0.9) !important;
    border-bottom: 1px solid rgba(2, 136, 209, 0.06) !important;
    backdrop-filter: blur(12px);
}

html:not(.dark-mode) .messagelist tr td,
html:not(.dark-mode) #message-list tr td {
    color: #3d5a73 !important;
    border-color: rgba(11, 26, 46, 0.05) !important;
}

html:not(.dark-mode) .messagelist tr.unread td,
html:not(.dark-mode) #message-list tr.unread td {
    color: #0b1a2e !important;
}

html:not(.dark-mode) .messagelist tr.unread td.subject span {
    color: #0b1a2e !important;
}

html:not(.dark-mode) .messagelist tr:hover,
html:not(.dark-mode) #message-list tr:hover {
    background: rgba(2, 136, 209, 0.03) !important;
}

html:not(.dark-mode) .messagelist tr.selected td,
html:not(.dark-mode) #message-list tr.selected td,
html:not(.dark-mode) .messagelist tr.focused td {
    background: rgba(2, 136, 209, 0.07) !important;
    color: #0b1a2e !important;
}

html:not(.dark-mode) .messagelist tr.flagged td.subject span {
    color: #0277bd !important;
}

/* -- CONTENT AREA (right panel) -- */
html:not(.dark-mode) #layout-content,
html:not(.dark-mode) #layout-content .scroller {
    background: linear-gradient(180deg, #f2f6fa 0%, #eef3f8 100%) !important;
}

html:not(.dark-mode) .message-header,
html:not(.dark-mode) #message-header,
html:not(.dark-mode) .header-title {
    background: rgba(255, 255, 255, 0.9) !important;
    border-bottom: 1px solid rgba(2, 136, 209, 0.08) !important;
    color: #1a2b3c !important;
    backdrop-filter: blur(12px);
}

html:not(.dark-mode) .message-header .header-title .subject {
    color: #0b1a2e !important;
}

html:not(.dark-mode) #message-content,
html:not(.dark-mode) .message-part,
html:not(.dark-mode) #messagebody {
    background: #ffffff !important;
    color: #1a2b3c !important;
    border-radius: var(--nf-radius-md);
    box-shadow: 0 1px 4px rgba(2, 136, 209, 0.04);
}

/* Content top accent — softer in light mode */
html:not(.dark-mode) #layout-content::before {
    background: linear-gradient(90deg, transparent, rgba(2, 136, 209, 0.15), rgba(41, 182, 246, 0.2), rgba(2, 136, 209, 0.15), transparent) !important;
    opacity: 1;
    height: 2px;
}

/* -- SEARCH BAR -- */
html:not(.dark-mode) .searchbar,
html:not(.dark-mode) #searchbar,
html:not(.dark-mode) .searchbox {
    background: rgba(255, 255, 255, 0.9) !important;
    border-color: rgba(2, 136, 209, 0.1) !important;
    box-shadow: 0 1px 4px rgba(2, 136, 209, 0.04) !important;
}

html:not(.dark-mode) .searchbar input,
html:not(.dark-mode) #searchbar input,
html:not(.dark-mode) .searchbox input {
    color: #1a2b3c !important;
}

html:not(.dark-mode) .searchbar:focus-within,
html:not(.dark-mode) #searchbar:focus-within,
html:not(.dark-mode) .searchbox:focus-within {
    border-color: #0288d1 !important;
    box-shadow: 0 0 0 3px rgba(2, 136, 209, 0.1), 0 0 20px rgba(2, 136, 209, 0.05) !important;
}

/* -- FORM CONTROLS -- */
html:not(.dark-mode) input[type="text"],
html:not(.dark-mode) input[type="password"],
html:not(.dark-mode) input[type="email"],
html:not(.dark-mode) input[type="url"],
html:not(.dark-mode) input[type="search"],
html:not(.dark-mode) input[type="number"],
html:not(.dark-mode) select,
html:not(.dark-mode) textarea,
html:not(.dark-mode) .form-control {
    background: #ffffff !important;
    color: #1a2b3c !important;
    border-color: rgba(11, 26, 46, 0.12) !important;
}

html:not(.dark-mode) input[type="text"]:focus,
html:not(.dark-mode) input[type="password"]:focus,
html:not(.dark-mode) input[type="email"]:focus,
html:not(.dark-mode) input[type="url"]:focus,
html:not(.dark-mode) input[type="search"]:focus,
html:not(.dark-mode) input[type="number"]:focus,
html:not(.dark-mode) select:focus,
html:not(.dark-mode) textarea:focus,
html:not(.dark-mode) .form-control:focus {
    background: #ffffff !important;
    border-color: #0288d1 !important;
    box-shadow: 0 0 0 3px rgba(2, 136, 209, 0.12), 0 0 12px rgba(2, 136, 209, 0.06) !important;
}

/* -- COMPOSE -- */
html:not(.dark-mode) #compose-content,
html:not(.dark-mode) #composebody,
html:not(.dark-mode) .compose-header {
    background: #ffffff !important;
}

/* -- POPUPS & DROPDOWNS -- */
html:not(.dark-mode) .popupmenu,
html:not(.dark-mode) .dropdown-menu,
html:not(.dark-mode) .popup,
html:not(.dark-mode) .ui-autocomplete {
    background: rgba(255, 255, 255, 0.95) !important;
    border-color: rgba(2, 136, 209, 0.1) !important;
    backdrop-filter: blur(20px);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(2, 136, 209, 0.05) !important;
}

html:not(.dark-mode) .popupmenu li a,
html:not(.dark-mode) .dropdown-menu li a {
    color: #3d5a73 !important;
}

html:not(.dark-mode) .popupmenu li a:hover,
html:not(.dark-mode) .dropdown-menu li a:hover {
    background: rgba(2, 136, 209, 0.06) !important;
    color: #0b1a2e !important;
}

html:not(.dark-mode) .popupmenu li a.active,
html:not(.dark-mode) .dropdown-menu li a.active,
html:not(.dark-mode) .menu li a.active {
    background: rgba(2, 136, 209, 0.08) !important;
    color: #0277bd !important;
}

/* -- DIALOGS -- */
html:not(.dark-mode) .ui-dialog {
    background: rgba(255, 255, 255, 0.98) !important;
    border-color: rgba(2, 136, 209, 0.1) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12), 0 0 60px rgba(2, 136, 209, 0.04) !important;
    backdrop-filter: blur(20px);
}

html:not(.dark-mode) .ui-dialog .ui-dialog-titlebar {
    background: linear-gradient(180deg, #f8fafd, #f2f6fa) !important;
    color: #0b1a2e !important;
}

html:not(.dark-mode) .ui-dialog .ui-dialog-content {
    color: #1a2b3c !important;
}

html:not(.dark-mode) .ui-dialog .ui-dialog-buttonpane {
    background: #f8fafd !important;
}

html:not(.dark-mode) .ui-widget-overlay {
    background: rgba(11, 26, 46, 0.25) !important;
    backdrop-filter: blur(4px);
}

/* -- SETTINGS & LISTINGS -- */
html:not(.dark-mode) .listing tbody tr td {
    color: #3d5a73 !important;
    border-color: rgba(11, 26, 46, 0.06) !important;
}

html:not(.dark-mode) .listing tbody tr:hover td {
    background: rgba(2, 136, 209, 0.03) !important;
    color: #0b1a2e !important;
}

html:not(.dark-mode) .listing tbody tr.selected td {
    background: rgba(2, 136, 209, 0.08) !important;
    color: #0277bd !important;
}

/* -- CONTACTS -- */
html:not(.dark-mode) #contacts-table tr.selected,
html:not(.dark-mode) #directorylist li.selected,
html:not(.dark-mode) .contactlist tr.selected {
    background: rgba(2, 136, 209, 0.08) !important;
}

html:not(.dark-mode) .contactphoto,
html:not(.dark-mode) .contact-photo {
    background: linear-gradient(135deg, #e8f0fe, #dce6f0) !important;
    border-color: rgba(2, 136, 209, 0.12) !important;
}

/* -- LISTBOX generic -- */
html:not(.dark-mode) .listbox .listing li:hover,
html:not(.dark-mode) .listbox .listing tr:hover {
    background: rgba(2, 136, 209, 0.03) !important;
}

html:not(.dark-mode) .listbox .listing li.selected,
html:not(.dark-mode) .listbox .listing tr.selected,
html:not(.dark-mode) .listbox .listing li.focused,
html:not(.dark-mode) .listbox .listing tr.focused {
    background: rgba(2, 136, 209, 0.06) !important;
}

html:not(.dark-mode) .list-group-item {
    background: #ffffff !important;
    color: #3d5a73 !important;
}

html:not(.dark-mode) .list-group-item:hover {
    background: rgba(2, 136, 209, 0.03) !important;
}

html:not(.dark-mode) .list-group-item.active {
    background: rgba(2, 136, 209, 0.08) !important;
    color: #0277bd !important;
}

/* -- CARDS -- */
html:not(.dark-mode) .card {
    background: rgba(255, 255, 255, 0.9) !important;
    border-color: rgba(2, 136, 209, 0.08) !important;
    box-shadow: 0 1px 4px rgba(2, 136, 209, 0.04) !important;
    backdrop-filter: blur(8px);
}

html:not(.dark-mode) .card-header {
    background: linear-gradient(180deg, #f8fafd, #f2f6fa) !important;
    color: #0b1a2e !important;
}

/* -- FRAME CONTENT -- */
html:not(.dark-mode) .content.frame-content {
    background: #ffffff !important;
}

html:not(.dark-mode) .iframe-wrapper iframe,
html:not(.dark-mode) iframe.content-frame {
    background: #ffffff !important;
}

html:not(.dark-mode) #messagecontframe,
html:not(.dark-mode) iframe[name="messagecontframe"] {
    background: linear-gradient(180deg, #f2f6fa 0%, #eef3f8 100%) !important;
}

/* -- SCROLLBAR -- */
html:not(.dark-mode) ::-webkit-scrollbar-track {
    background: #f2f6fa;
}
html:not(.dark-mode) ::-webkit-scrollbar-thumb {
    background: #c0d8e8;
    border-radius: 4px;
}
html:not(.dark-mode) ::-webkit-scrollbar-thumb:hover {
    background: #0288d1;
}

/* -- SELECTION -- */
html:not(.dark-mode) ::selection {
    background: rgba(2, 136, 209, 0.25);
    color: #0b1a2e;
}

/* -- NOTIFICATIONS -- */
html:not(.dark-mode) #messagestack div.notice,
html:not(.dark-mode) .ui.alert.notice {
    background: rgba(2, 136, 209, 0.1) !important;
    color: #0277bd !important;
    border-color: rgba(2, 136, 209, 0.25) !important;
}

html:not(.dark-mode) #messagestack div.confirmation,
html:not(.dark-mode) .ui.alert.confirmation {
    background: rgba(22, 163, 74, 0.1) !important;
    color: #15803d !important;
    border-color: rgba(22, 163, 74, 0.25) !important;
}

html:not(.dark-mode) #messagestack div.error,
html:not(.dark-mode) #messagestack div.warning,
html:not(.dark-mode) .ui.alert.error,
html:not(.dark-mode) .ui.alert.warning {
    background: rgba(220, 38, 38, 0.08) !important;
    color: #dc2626 !important;
    border-color: rgba(220, 38, 38, 0.2) !important;
}

html:not(.dark-mode) .noscriptwarning {
    background: rgba(220, 38, 38, 0.08) !important;
    color: #dc2626 !important;
    border-color: rgba(220, 38, 38, 0.2) !important;
}

/* -- TOOLTIPS -- */
html:not(.dark-mode) .tooltip .tooltip-inner {
    background: rgba(255, 255, 255, 0.95) !important;
    color: #1a2b3c !important;
    border-color: rgba(2, 136, 209, 0.1) !important;
    backdrop-filter: blur(12px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08) !important;
}

/* -- LINKS -- */
html:not(.dark-mode) a {
    color: #0277bd !important;
}
html:not(.dark-mode) a:hover {
    color: #01579b !important;
}

/* -- CHECKBOXES -- */
html:not(.dark-mode) .custom-control-input:checked ~ .custom-control-label::before,
html:not(.dark-mode) input[type="checkbox"]:checked + label::before {
    box-shadow: 0 0 6px rgba(2, 136, 209, 0.2) !important;
}

/* -- BUTTONS -- */
html:not(.dark-mode) .btn-secondary,
html:not(.dark-mode) .btn.cancel {
    background: rgba(255, 255, 255, 0.9) !important;
    color: #3d5a73 !important;
    border-color: rgba(2, 136, 209, 0.12) !important;
    backdrop-filter: blur(8px);
}

html:not(.dark-mode) .btn-secondary:hover,
html:not(.dark-mode) .btn.cancel:hover {
    background: rgba(2, 136, 209, 0.06) !important;
    color: #0b1a2e !important;
    border-color: rgba(2, 136, 209, 0.2) !important;
}

html:not(.dark-mode) .btn-primary:hover,
html:not(.dark-mode) .btn.submit:hover,
html:not(.dark-mode) input[type="submit"]:hover,
html:not(.dark-mode) .mainaction:hover {
    box-shadow: 0 0 24px rgba(2, 136, 209, 0.25), 0 6px 16px rgba(0, 0, 0, 0.08) !important;
}

/* -- ICON HOVER GLOW -- */
html:not(.dark-mode) .toolbar a:hover::before,
html:not(.dark-mode) #taskmenu a:hover::before {
    filter: drop-shadow(0 0 4px rgba(2, 136, 209, 0.3));
}

/* -- FOCUS RING -- */
html:not(.dark-mode) *:focus-visible {
    outline-color: #0288d1 !important;
    box-shadow: 0 0 0 4px rgba(2, 136, 209, 0.08) !important;
}

/* -- PROGRESS BAR -- */
html:not(.dark-mode) .progress {
    background: #e8eef4 !important;
}

html:not(.dark-mode) .progress-bar {
    box-shadow: 0 0 8px rgba(2, 136, 209, 0.2);
}

/* -- QUOTA BAR -- */
html:not(.dark-mode) .quotadisplay .bar {
    background: #e8eef4 !important;
}

/* -- PAGINATION / STATUS BAR -- */
html:not(.dark-mode) .pagenav,
html:not(.dark-mode) .countdisplay {
    color: #7a95aa !important;
}

html:not(.dark-mode) .pagenav a {
    color: #3d5a73 !important;
}

html:not(.dark-mode) .pagenav a:hover {
    color: #0277bd !important;
}

/* -- FOOTER / STATUS AREA -- */
html:not(.dark-mode) #layout-sidebar .footer,
html:not(.dark-mode) #layout-list .footer,
html:not(.dark-mode) .listbox .footer {
    background: rgba(255, 255, 255, 0.7) !important;
    border-top: 1px solid rgba(2, 136, 209, 0.06) !important;
    color: #7a95aa !important;
    backdrop-filter: blur(8px);
}

/* -- TABLES -- */
html:not(.dark-mode) table {
    border-color: rgba(11, 26, 46, 0.06) !important;
}

html:not(.dark-mode) th {
    color: #7a95aa !important;
    border-color: rgba(11, 26, 46, 0.08) !important;
}

html:not(.dark-mode) td {
    color: #3d5a73 !important;
    border-color: rgba(11, 26, 46, 0.06) !important;
}

/* -- PLACEHOLDERS -- */
html:not(.dark-mode) ::placeholder {
    color: #7a95aa !important;
}

/* ============================================================
   LIGHT MODE LOGIN PAGE
   ============================================================ */
html:not(.dark-mode) body.task-login {
    background: linear-gradient(135deg, #e8f0fe 0%, #f0f4f8 40%, #eef3f8 100%) !important;
}

html:not(.dark-mode) body.task-login::before {
    background:
        radial-gradient(ellipse at 20% 50%, rgba(2, 136, 209, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(41, 182, 246, 0.1) 0%, transparent 50%),
        radial-gradient(ellipse at 50% 80%, rgba(79, 195, 247, 0.06) 0%, transparent 50%);
}

html:not(.dark-mode) body.task-login::after {
    background-image:
        linear-gradient(rgba(2, 136, 209, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(2, 136, 209, 0.03) 1px, transparent 1px);
}

html:not(.dark-mode) body.task-login #layout-content {
    background: rgba(255, 255, 255, 0.95) !important;
    border: 1px solid rgba(2, 136, 209, 0.12) !important;
    box-shadow:
        0 8px 32px rgba(0, 0, 0, 0.06),
        0 0 60px rgba(2, 136, 209, 0.06),
        0 0 120px rgba(41, 182, 246, 0.04) !important;
    backdrop-filter: blur(20px);
}

html:not(.dark-mode) body.task-login #logo {
    filter: drop-shadow(0 0 18px rgba(2, 136, 209, 0.15)) drop-shadow(0 0 40px rgba(2, 136, 209, 0.08));
}

html:not(.dark-mode) body.task-login .form-control,
html:not(.dark-mode) body.task-login input[type="text"],
html:not(.dark-mode) body.task-login input[type="password"] {
    background: #f5f7fa !important;
    color: #1a2b3c !important;
    border-color: rgba(11, 26, 46, 0.12) !important;
}

html:not(.dark-mode) body.task-login .form-control:focus,
html:not(.dark-mode) body.task-login input[type="text"]:focus,
html:not(.dark-mode) body.task-login input[type="password"]:focus {
    border-color: #0288d1 !important;
    box-shadow: 0 0 0 3px rgba(2, 136, 209, 0.12), 0 0 20px rgba(2, 136, 209, 0.06) !important;
}

html:not(.dark-mode) body.task-login input[type="submit"]:hover,
html:not(.dark-mode) body.task-login .btn-primary:hover,
html:not(.dark-mode) body.task-login .button.mainaction:hover {
    box-shadow: 0 0 30px rgba(2, 136, 209, 0.25), 0 8px 24px rgba(0, 0, 0, 0.1) !important;
}

html:not(.dark-mode) #login-footer {
    color: #7a95aa !important;
}

html:not(.dark-mode) #login-footer a {
    color: #0277bd !important;
}

html:not(.dark-mode) body.task-login #layout-content::before {
    opacity: 0.6;
}

html:not(.dark-mode) body.task-login #layout-content::after {
    opacity: 0.3;
}

/* ============================================================
   LIGHT MODE — FUTURISTIC ACCENTS
   Subtle gradient separators & glow touches for personality
   ============================================================ */

/* Thin gradient accent line at very top of page */
html:not(.dark-mode) #layout::before {
    content: '';
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, #0288d1, #29b6f6, #4fc3f7, #29b6f6, #0288d1, transparent);
    z-index: 9999;
    pointer-events: none;
    opacity: 0.6;
}

/* Subtle mesh gradient on content area for depth */
html:not(.dark-mode) #layout-content::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background:
        radial-gradient(ellipse at 80% 20%, rgba(2, 136, 209, 0.03) 0%, transparent 50%),
        radial-gradient(ellipse at 20% 80%, rgba(41, 182, 246, 0.02) 0%, transparent 50%);
    pointer-events: none;
    z-index: 0;
}

/* ============================================================
   END OF NOVA FLUX SKIN STYLES
   ============================================================ */
