/*
 * EmberNet Industrial Theme — Master CSS
 * ========================================
 * Target: Frappe/ERPNext v16 Desk + Public Pages
 * Design: Amalgamation of fireballz.ai + dashboard.embernet.ai
 * Brand: Fireball Industries — Primary Red #c0392b
 *
 * Architecture:
 *   1. Google Fonts import (Inter + JetBrains Mono)
 *   2. CSS custom properties on :root (light mode — overridden but present)
 *   3. [data-theme="dark"] overrides — THE primary theme
 *   4. Force dark mode on ALL selectors (Frappe default is light)
 *   5. Component-level overrides (navbar, sidebar, cards, forms, tables, etc.)
 *   6. Print media query — revert to readable black-on-white
 *
 * Verified against: frappe/public/scss/espresso/_colors.scss (version-16)
 *                   frappe/public/scss/desk/dark.scss (version-16)
 *                   frappe/public/scss/common/css_variables.scss (version-16)
 */

/* =========================================================================
   0. GOOGLE FONTS
   ========================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* =========================================================================
   1. EMBERNET CUSTOM PROPERTIES
   These extend Frappe's variable system with Fireball-specific tokens.
   ========================================================================= */
:root {
    /* --- Brand --- */
    --embernet-red: #c0392b;
    --embernet-red-hover: #a93226;
    --embernet-red-light: rgba(192, 57, 43, 0.12);
    --embernet-red-glow: rgba(192, 57, 43, 0.25);
    --embernet-red-border: rgba(192, 57, 43, 0.35);
    --embernet-red-muted: rgba(192, 57, 43, 0.6);

    /* --- Surfaces (dark industrial) --- */
    --embernet-bg-base: #0d1117;
    --embernet-bg-surface: #161b22;
    --embernet-bg-card: #1a1f2b;
    --embernet-bg-elevated: #252d3a;
    --embernet-bg-input: #1e2533;

    /* --- Text --- */
    --embernet-text-primary: #e6edf3;
    --embernet-text-secondary: #8b949e;
    --embernet-text-subtle: #6e7681;

    /* --- Status --- */
    --embernet-green: #10b981;
    --embernet-green-bg: rgba(16, 185, 129, 0.12);
    --embernet-yellow: #fbbf24;
    --embernet-yellow-bg: rgba(251, 191, 36, 0.12);
    --embernet-cyan: #06b6d4;
    --embernet-cyan-bg: rgba(6, 182, 212, 0.12);

    /* --- Borders --- */
    --embernet-border: rgba(255, 255, 255, 0.08);
    --embernet-border-hover: rgba(255, 255, 255, 0.15);

    /* --- Typography --- */
    --embernet-font-ui: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --embernet-font-mono: 'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;
}

/* =========================================================================
   2. FORCE DARK THEME — Override Frappe's [data-theme="dark"] variables
   We override the default dark palette with EmberNet's industrial colors.
   ========================================================================= */
[data-theme="dark"] {
    /* --- Gray scale: deeper, blue-tinted darks --- */
    --gray-50: #e6edf3;
    --gray-100: #c9d1d9;
    --gray-200: #b1bac4;
    --gray-300: #8b949e;
    --gray-400: #6e7681;
    --gray-500: #484f58;
    --gray-600: #30363d;
    --gray-700: #21262d;
    --gray-800: #161b22;
    --gray-900: #0d1117;

    /* --- Core layout surfaces --- */
    --bg-color: var(--embernet-bg-base);
    --fg-color: var(--embernet-bg-surface);
    --subtle-accent: var(--embernet-bg-card);
    --subtle-fg: #21262d;
    --fg-hover-color: var(--embernet-bg-card);
    --card-bg: var(--embernet-bg-surface);
    --modal-bg: var(--embernet-bg-surface);
    --toast-bg: var(--embernet-bg-surface);
    --popover-bg: var(--embernet-bg-surface);
    --navbar-bg: var(--embernet-bg-surface);

    /* --- Controls / inputs --- */
    --control-bg: var(--embernet-bg-input);
    --control-bg-on-gray: var(--embernet-bg-elevated);
    --awesomebar-focus-bg: var(--embernet-bg-input);
    --awesomplete-hover-bg: var(--embernet-bg-card);
    --disabled-control-bg: #1a1f2b;
    --disabled-text-color: var(--embernet-text-subtle);
    --input-disabled-bg: #1a1f2b;

    /* --- Text colors --- */
    --text-color: var(--embernet-text-primary);
    --text-muted: var(--embernet-text-secondary);
    --text-light: var(--embernet-text-secondary);
    --text-neutral: var(--embernet-text-primary);
    --heading-color: var(--embernet-text-primary);

    /* --- Borders --- */
    --border-color: var(--embernet-border);
    --dark-border-color: rgba(255, 255, 255, 0.12);
    --table-border-color: var(--embernet-border);

    /* --- Buttons: red primary, matching brand --- */
    --btn-primary: var(--embernet-red);
    --btn-default-bg: var(--embernet-bg-card);
    --btn-default-hover-bg: var(--embernet-bg-elevated);
    --btn-ghost-hover-bg: var(--embernet-bg-card);
    --btn-group-border-color: rgba(255, 255, 255, 0.1);

    /* --- Sidebar --- */
    --sidebar-select-color: var(--embernet-bg-card);

    /* --- Scrollbar --- */
    --scrollbar-thumb-color: #30363d;
    --scrollbar-track-color: var(--embernet-bg-base);

    /* --- Misc --- */
    --shadow-inset: var(--embernet-bg-surface);
    --highlight-color: var(--embernet-bg-card);
    --yellow-highlight-color: rgba(251, 191, 36, 0.15);
    --placeholder-color: var(--embernet-bg-card);
    --skeleton-bg: var(--embernet-bg-card);

    /* --- Espresso semantic tokens (dark overrides) --- */
    --surface-white: var(--embernet-bg-base);
    --surface-gray-1: var(--embernet-bg-surface);
    --surface-gray-2: var(--embernet-bg-card);
    --surface-gray-3: var(--embernet-bg-elevated);
    --surface-menu-bar: var(--embernet-bg-base);
    --surface-modal: var(--embernet-bg-surface);
    --surface-cards: var(--embernet-bg-surface);
    --outline-gray-1: rgba(255, 255, 255, 0.06);
    --outline-gray-2: rgba(255, 255, 255, 0.08);
    --outline-gray-3: rgba(255, 255, 255, 0.12);
    --outline-gray-modals: rgba(255, 255, 255, 0.08);
}

/* =========================================================================
   3. GLOBAL TYPOGRAPHY
   ========================================================================= */
html, body,
[data-theme="dark"],
[data-theme="light"] {
    font-family: var(--embernet-font-ui) !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Monospace for all data/numeric content */
.indicator-pill .indicator-pill-count,
.bold .indicator,
.frappe-control[data-fieldtype="Currency"] .control-value,
.frappe-control[data-fieldtype="Float"] .control-value,
.frappe-control[data-fieldtype="Int"] .control-value,
.frappe-control[data-fieldtype="Percent"] .control-value,
.list-row .level-item[data-field="amount"],
.list-row .level-item[data-field="grand_total"],
.list-row .level-item[data-field="rate"],
.list-row .level-item[data-field="qty"],
.number-widget .number-widget-value,
.stat-value,
td[data-field="amount"],
td[data-field="grand_total"],
td[data-field="rate"],
td[data-field="qty"],
td[data-field="balance"],
.currency,
.count,
[data-fieldtype="Currency"],
[data-fieldtype="Float"],
[data-fieldtype="Int"],
[data-fieldtype="Percent"] {
    font-family: var(--embernet-font-mono) !important;
}

/* =========================================================================
   4. NAVBAR — Dark industrial header bar
   ========================================================================= */
.navbar {
    background-color: var(--embernet-bg-surface) !important;
    border-bottom: 1px solid var(--embernet-border) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3) !important;
}

.navbar .navbar-brand .app-logo {
    filter: brightness(0) invert(1);
}

.navbar .navbar-nav .nav-link {
    color: var(--embernet-text-secondary) !important;
    font-weight: 500;
    font-size: 13px;
    letter-spacing: 0.02em;
    transition: color 0.15s ease;
}

.navbar .navbar-nav .nav-link:hover,
.navbar .navbar-nav .nav-link:focus {
    color: var(--embernet-text-primary) !important;
}

.navbar .navbar-nav .nav-link.active,
.navbar .navbar-nav .nav-item.active .nav-link {
    color: var(--embernet-red) !important;
}

/* Awesomebar (search) */
.awesomebar-container input.awesomebar {
    background-color: var(--embernet-bg-input) !important;
    border: 1px solid var(--embernet-border) !important;
    color: var(--embernet-text-primary) !important;
    border-radius: 6px;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.awesomebar-container input.awesomebar:focus {
    border-color: var(--embernet-red-border) !important;
    box-shadow: 0 0 0 3px var(--embernet-red-light) !important;
}

/* =========================================================================
   5. SIDEBAR — Deep dark with red active indicator
   ========================================================================= */
.desk-sidebar,
.layout-side-section {
    background-color: var(--embernet-bg-base) !important;
    border-right: 1px solid var(--embernet-border) !important;
}

.desk-sidebar .sidebar-menu .sidebar-label {
    color: var(--embernet-text-subtle) !important;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.desk-sidebar .sidebar-menu a,
.desk-sidebar .sidebar-menu .sidebar-item-label {
    color: var(--embernet-text-secondary) !important;
    transition: color 0.15s ease, background-color 0.15s ease;
}

.desk-sidebar .sidebar-menu a:hover {
    color: var(--embernet-text-primary) !important;
    background-color: var(--embernet-bg-card) !important;
}

.desk-sidebar .sidebar-menu a.selected,
.desk-sidebar .sidebar-menu .selected .sidebar-item-label {
    color: var(--embernet-red) !important;
    background-color: var(--embernet-red-light) !important;
    border-left: 3px solid var(--embernet-red) !important;
}

/* =========================================================================
   6. CARDS — Dark industrial cards with subtle borders
   ========================================================================= */
.frappe-card,
.widget.widget-shadow,
.form-layout,
.page-form,
.report-wrapper .result {
    background-color: var(--embernet-bg-surface) !important;
    border: 1px solid var(--embernet-border) !important;
    border-radius: 8px !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.frappe-card:hover,
.widget.widget-shadow:hover {
    border-color: var(--embernet-border-hover) !important;
}

/* Card / widget titles — uppercase industrial labels */
.widget .widget-head .widget-title,
.section-head {
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    color: var(--embernet-text-secondary) !important;
}

/* =========================================================================
   7. BUTTONS — Red primary CTAs
   ========================================================================= */
.btn-primary,
.btn-primary-dark {
    background-color: var(--embernet-red) !important;
    border-color: var(--embernet-red) !important;
    color: #ffffff !important;
    font-weight: 500;
    border-radius: 6px;
    transition: background-color 0.15s ease, box-shadow 0.15s ease;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary-dark:hover {
    background-color: var(--embernet-red-hover) !important;
    border-color: var(--embernet-red-hover) !important;
    box-shadow: 0 0 0 3px var(--embernet-red-light) !important;
}

.btn-primary:active {
    background-color: #922b21 !important;
}

.btn-default {
    background-color: var(--embernet-bg-card) !important;
    border: 1px solid var(--embernet-border) !important;
    color: var(--embernet-text-primary) !important;
    border-radius: 6px;
}

.btn-default:hover {
    background-color: var(--embernet-bg-elevated) !important;
    border-color: var(--embernet-border-hover) !important;
}

/* =========================================================================
   8. FORMS & INPUTS
   ========================================================================= */
.frappe-control .control-input,
.frappe-control input,
.frappe-control select,
.frappe-control textarea {
    background-color: var(--embernet-bg-input) !important;
    border: 1px solid var(--embernet-border) !important;
    color: var(--embernet-text-primary) !important;
    border-radius: 6px;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.frappe-control input:focus,
.frappe-control select:focus,
.frappe-control textarea:focus {
    border-color: var(--embernet-red) !important;
    box-shadow: 0 0 0 3px var(--embernet-red-light) !important;
    outline: none;
}

/* Form labels — uppercase, letterspaced */
.frappe-control .control-label,
.frappe-control label {
    font-size: 10px !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    color: var(--embernet-text-subtle) !important;
}

/* =========================================================================
   9. LIST VIEW & TABLES
   ========================================================================= */
.list-row {
    border-bottom: 1px solid var(--embernet-border) !important;
    transition: background-color 0.1s ease;
}

.list-row:hover {
    background-color: var(--embernet-red-light) !important;
}

.list-row .level-item {
    color: var(--embernet-text-primary);
}

.list-row-head {
    background-color: var(--embernet-bg-elevated) !important;
}

.list-row-head .level-item {
    font-size: 10px !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    color: var(--embernet-text-subtle) !important;
}

/* Sortable table headers */
.dt-header .dt-cell--header .dt-cell__content {
    font-size: 10px !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    color: var(--embernet-text-subtle) !important;
}

/* =========================================================================
   10. STATUS INDICATORS — Match dashboard.embernet.ai patterns
   ========================================================================= */
.indicator-pill {
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    padding: 2px 10px;
}

.indicator-pill.green {
    background-color: var(--embernet-green-bg) !important;
    color: var(--embernet-green) !important;
}

.indicator-pill.red {
    background-color: rgba(192, 57, 43, 0.12) !important;
    color: var(--embernet-red) !important;
}

.indicator-pill.yellow,
.indicator-pill.orange {
    background-color: var(--embernet-yellow-bg) !important;
    color: var(--embernet-yellow) !important;
}

.indicator-pill.blue {
    background-color: var(--embernet-cyan-bg) !important;
    color: var(--embernet-cyan) !important;
}

/* Dot indicators */
.indicator.green::before { background-color: var(--embernet-green) !important; }
.indicator.red::before { background-color: var(--embernet-red) !important; }
.indicator.yellow::before,
.indicator.orange::before { background-color: var(--embernet-yellow) !important; }
.indicator.blue::before { background-color: var(--embernet-cyan) !important; }

/* =========================================================================
   11. MODALS & DIALOGS
   ========================================================================= */
.modal-content {
    background-color: var(--embernet-bg-surface) !important;
    border: 1px solid var(--embernet-border) !important;
    border-radius: 12px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5) !important;
}

.modal-header {
    border-bottom: 1px solid var(--embernet-border) !important;
}

.modal-footer {
    border-top: 1px solid var(--embernet-border) !important;
}

.modal-backdrop {
    background-color: rgba(0, 0, 0, 0.7) !important;
}

/* =========================================================================
   12. DROPDOWNS & POPOVERS
   ========================================================================= */
.dropdown-menu,
.awesomplete > ul {
    background-color: var(--embernet-bg-surface) !important;
    border: 1px solid var(--embernet-border) !important;
    border-radius: 8px !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4) !important;
}

.dropdown-item {
    color: var(--embernet-text-primary) !important;
    transition: background-color 0.1s ease;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: var(--embernet-red-light) !important;
    color: var(--embernet-text-primary) !important;
}

.dropdown-divider {
    border-color: var(--embernet-border) !important;
}

/* =========================================================================
   13. TABS
   ========================================================================= */
.form-tabs .nav-link {
    color: var(--embernet-text-secondary) !important;
    font-weight: 500;
    border-bottom: 2px solid transparent !important;
    transition: color 0.15s ease, border-color 0.15s ease;
}

.form-tabs .nav-link:hover {
    color: var(--embernet-text-primary) !important;
}

.form-tabs .nav-link.active {
    color: var(--embernet-red) !important;
    border-bottom-color: var(--embernet-red) !important;
}

/* =========================================================================
   14. PAGE HEADER & BREADCRUMBS
   ========================================================================= */
.page-head {
    background-color: var(--embernet-bg-base) !important;
    border-bottom: 1px solid var(--embernet-border) !important;
}

.page-title .title-text {
    color: var(--embernet-text-primary) !important;
    font-weight: 600;
}

.breadcrumb-container .breadcrumb a {
    color: var(--embernet-text-subtle) !important;
}

.breadcrumb-container .breadcrumb a:hover {
    color: var(--embernet-red) !important;
}

/* =========================================================================
   15. LIKE / COMMENT / ATTACHMENT ACTIONS
   ========================================================================= */
.like-action .like-icon.liked {
    fill: var(--embernet-red) !important;
    color: var(--embernet-red) !important;
}

/* =========================================================================
   16. WORKSPACE WIDGETS
   ========================================================================= */
.widget.number-widget .number-widget-title {
    font-size: 10px !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    color: var(--embernet-text-subtle) !important;
}

.widget.number-widget .number-widget-value {
    font-family: var(--embernet-font-mono) !important;
    color: var(--embernet-text-primary) !important;
    font-weight: 600;
    font-size: 28px;
}

.widget.shortcut-widget-box {
    background-color: var(--embernet-bg-card) !important;
    border: 1px solid var(--embernet-border) !important;
    border-radius: 8px !important;
    transition: border-color 0.15s ease, transform 0.15s ease;
}

.widget.shortcut-widget-box:hover {
    border-color: var(--embernet-red-border) !important;
    transform: translateY(-1px);
}

/* =========================================================================
   17. SCROLLBARS — Subtle dark scrollbars
   ========================================================================= */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--embernet-bg-base);
}

::-webkit-scrollbar-thumb {
    background: #30363d;
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: #484f58;
}

/* =========================================================================
   18. LOGIN PAGE — Glassmorphism card on dark background
   ========================================================================= */
.page-card {
    background: rgba(22, 27, 34, 0.85) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 16px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5) !important;
}

.page-card .page-card-head .title {
    color: var(--embernet-text-primary) !important;
    font-weight: 700;
}

body.frappe-login {
    background-color: var(--embernet-bg-base) !important;
    background-image:
        radial-gradient(circle at 20% 50%, rgba(192, 57, 43, 0.08) 0%, transparent 50%),
        radial-gradient(circle at 80% 20%, rgba(6, 182, 212, 0.05) 0%, transparent 40%) !important;
}

/* =========================================================================
   19. CHARTS — Frappe Charts dark mode refinement
   ========================================================================= */
.chart-container {
    --charts-label-color: var(--embernet-text-subtle) !important;
    --charts-axis-line-color: var(--embernet-border) !important;
    --charts-tooltip-bg: var(--embernet-bg-surface) !important;
    --charts-tooltip-value: #ffffff !important;
}

/* =========================================================================
   20. PROGRESS BARS — Green health indicators (dashboard style)
   ========================================================================= */
.progress {
    background-color: var(--embernet-bg-card) !important;
    border-radius: 4px !important;
}

.progress-bar {
    background-color: var(--embernet-green) !important;
    border-radius: 4px !important;
}

/* =========================================================================
   21. ALERTS / MESSAGES
   ========================================================================= */
.alert-warning,
.yellow-alert {
    background-color: var(--embernet-yellow-bg) !important;
    border-color: rgba(251, 191, 36, 0.3) !important;
    color: var(--embernet-yellow) !important;
}

.alert-danger {
    background-color: rgba(192, 57, 43, 0.12) !important;
    border-color: var(--embernet-red-border) !important;
    color: var(--embernet-red) !important;
}

.alert-success {
    background-color: var(--embernet-green-bg) !important;
    border-color: rgba(16, 185, 129, 0.3) !important;
    color: var(--embernet-green) !important;
}

.alert-info {
    background-color: var(--embernet-cyan-bg) !important;
    border-color: rgba(6, 182, 212, 0.3) !important;
    color: var(--embernet-cyan) !important;
}

/* =========================================================================
   22. SECTION HEADERS — Red left-border accent (dashboard pattern)
   ========================================================================= */
.section-head,
.form-section .section-head {
    border-left: 3px solid var(--embernet-red) !important;
    padding-left: 12px !important;
}

.form-section .section-head .collapse-indicator {
    color: var(--embernet-red) !important;
}

/* =========================================================================
   23. TIMELINE / ACTIVITY
   ========================================================================= */
.timeline-item .timeline-badge {
    background-color: var(--embernet-bg-card) !important;
    border: 1px solid var(--embernet-border) !important;
}

/* =========================================================================
   24. MISC GLOBAL
   ========================================================================= */

/* Links */
a {
    color: var(--embernet-text-primary);
    transition: color 0.15s ease;
}

a:hover {
    color: var(--embernet-red);
}

/* Selection highlight */
::selection {
    background: var(--embernet-red-light);
    color: var(--embernet-text-primary);
}

/* Page background */
#page-container,
.page-container,
body {
    background-color: var(--embernet-bg-base) !important;
}

/* =========================================================================
   25. PRINT MEDIA — Revert to readable black-on-white for printing
   ========================================================================= */
@media print {
    * {
        background-color: white !important;
        color: black !important;
        border-color: #ccc !important;
        box-shadow: none !important;
    }

    .navbar,
    .desk-sidebar,
    .page-head .page-actions,
    .comment-box,
    .form-footer {
        display: none !important;
    }

    .print-format {
        --text-color: #000 !important;
        --border-color: #ccc !important;
        font-family: 'Inter', sans-serif !important;
    }
}
