/* ========================================================================
   SLM.css — Layout + Theming
   ======================================================================== */

/* ------------------------------------------------------------------------
   1. THEME VARIABLES
   ------------------------------------------------------------------------ */

:root {
    --slm-color-bg: #ffffff;
    --slm-color-surface: #f5f5f5;
    --slm-color-border: #cccccc;
    --slm-color-text-primary: #111111;
    --slm-color-text-muted: #666666;
    --slm-color-accent: #0067c5;
    --slm-color-error: #b00020;
    --slm-color-separator: #888888;

    /* --------------------------------------------------------------------
       Field + Button tokens (centralized)
       -------------------------------------------------------------------- */

    /* Field wrapper */
    --slm-field-wrapper-bg: #fbfbfb;
    --slm-field-wrapper-border: rgba(0,0,0,0.06);
    --slm-field-wrapper-border-focus: rgba(0,0,0,0.08);
    --slm-field-input-bg: rgba(0,0,0,0.05);

    /* Button: default */
    --slm-button-container-bg: #f5f5f5;
    --slm-button-container-border: #cccccc;
    --slm-button-text: var(--slm-color-text-primary);
    --slm-button-hover-bg: #e9e9e9;
    --slm-button-active-bg: #e1e1e1;

    /* Primary */
    --slm-button-primary-container-bg: #0b5ed7;
    --slm-button-primary-container-border: #0b5ed7;
    --slm-button-primary-text: #ffffff;
    --slm-button-primary-hover-bg: #0a58ca;
    --slm-button-primary-active-bg: #084298;
    --slm-button-primary-disabled-bg: #6ea8fe;
    --slm-button-primary-disabled-text: #ffffff;

    /* Secondary */
    --slm-button-secondary-container-bg: #eef1f4;
    --slm-button-secondary-container-border: #cccccc;
    --slm-button-secondary-text: var(--slm-color-text-primary);
    --slm-button-secondary-hover-bg: #e4e8ec;
    --slm-button-secondary-active-bg: #d9dee3;
    --slm-button-secondary-disabled-bg: #f2f4f6;
    --slm-button-secondary-disabled-text: var(--slm-color-text-muted);

    /* Light */
    --slm-button-light-container-bg: #f7f7f7;
    --slm-button-light-container-border: #cccccc;
    --slm-button-light-text: var(--slm-color-text-primary);
    --slm-button-light-hover-bg: #f0f0f0;
    --slm-button-light-active-bg: #e8e8e8;
    --slm-button-light-disabled-bg: #fafafa;
    --slm-button-light-disabled-text: var(--slm-color-text-muted);

    /* Danger */
    --slm-button-danger-container-bg: var(--slm-color-error);
    --slm-button-danger-container-border: var(--slm-color-error);
    --slm-button-danger-text: #ffffff;
    --slm-button-danger-hover-bg: #c21f34;
    --slm-button-danger-active-bg: #8f1526;
    --slm-button-danger-disabled-bg: #e07a86;
    --slm-button-danger-disabled-text: #ffffff;

    /* Link */
    --slm-button-link-text: var(--slm-color-accent);
    --slm-button-link-hover-text-decoration: underline;
    --slm-button-link-disabled-text: var(--slm-color-text-muted);
    --slm-button-link-disabled-bg: transparent;

    /* DFormLoader sizing tokens */
    --slm-dform-dialog-min-width: var(--slm-dialog-min-width, 360px);
    --slm-dform-dialog-gap-width: 8px;

    /* Dialog sizing tokens (shared) */
    --slm-dialog-min-width: 360px;
    --slm-dialog-min-height: 400px;

    /* Global typography */
    --slm-font-family: "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* Full-page loading overlay (shown during navigation) */
.slm-loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 2500;
    background: rgba(0, 0, 0, 0.25);
    display: flex;
    align-items: center;
    justify-content: center;
}

.slm-loading-overlay__content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 24px 32px;
    background: var(--slm-color-surface, #fff);
    border-radius: 8px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.3);
    font-size: 0.9rem;
    color: var(--slm-color-text-primary, #1a1a1a);
}

.slm-loading-overlay__spinner {
    width: 28px;
    height: 28px;
    border: 3px solid var(--slm-color-accent, #0078d4);
    border-top-color: transparent;
    border-radius: 50%;
    animation: slm-navlock-spin 0.8s linear infinite;
}

    /* Field/DForm label defaults */
    --slm-label-font-size: 0.8rem;
    --slm-label-color: #8B0000;

    /* Button focus border color (high contrast) */
    --slm-button-focus-border: #ffbf00;

    /* SlmDialog ribbon colors */
    --slm-dialog-ribbon-info:     #1e3a5f;
    --slm-dialog-ribbon-confirm:  #b45309;
    --slm-dialog-ribbon-warn:     #7a1b1b;
    --slm-dialog-ribbon-success:  #166534;
    --slm-dialog-ribbon-input:    var(--slm-color-accent);

    /* SlmDialog surface */
    --slm-dialog-surface:         #fafbfc;
    --slm-dialog-border:          #d1d5db;
    --slm-dialog-radius:          12px;

    /* SlmDialog backdrop */
    --slm-dialog-backdrop:        rgba(0, 0, 0, 0.32);
    --slm-dialog-backdrop-blur:   2px;

    /* SlmDialog shadow (multi-layer) */
    --slm-dialog-shadow:
        0 2px 8px rgba(0,0,0,0.08),
        0 8px 24px rgba(0,0,0,0.12),
        0 24px 48px rgba(0,0,0,0.06);

    /* SlmDialog text */
    --slm-dialog-title-size:      1.1rem;
    --slm-dialog-body-size:       0.95rem;
    --slm-dialog-body-line-height: 1.6;
}

/* Light theme */
body.slm-theme-light {
    --slm-color-bg: #ffffff;
    --slm-color-surface: #f5f5f5;
    --slm-color-border: #cccccc;
    --slm-color-text-primary: #111111;
    --slm-color-text-muted: #666666;
    --slm-color-accent: #0067c5;
    --slm-color-error: #b00020;
    --slm-label-color: #8B0000;

    --slm-field-wrapper-bg: #fbfbfb;
    --slm-field-wrapper-border: rgba(0,0,0,0.06);
    --slm-field-wrapper-border-focus: rgba(0,0,0,0.08);
    --slm-field-input-bg: rgba(0,0,0,0.05);

    /* Focus ring in light theme should be light-blue (not white) so borders match Dark theme behavior. */
    --slm-button-focus-border: #ffbf00;
}

/* Dark theme */
body.slm-theme-dark {
    --slm-color-bg: #111111;
    --slm-color-surface: #1e1e1e;
    --slm-color-border: #3a3a3a;
    --slm-color-text-primary: #f5f5f5;
    --slm-color-text-muted: #aaaaaa;
    --slm-color-accent: #4fa3ff;
    --slm-color-error: #ff6b81;
    --slm-color-separator: #777777;
    --slm-label-color: #ff9999;

    --slm-field-wrapper-bg: #1b1b1b;
    --slm-field-wrapper-border: rgba(255,255,255,0.14);
    --slm-field-wrapper-border-focus: rgba(255,255,255,0.22);
    --slm-field-input-bg: rgba(255,255,255,0.06);

    /* Dark-specific button overrides */
    --slm-button-container-bg: #242424;
    --slm-button-container-border: #3a3a3a;
    --slm-button-text: #f5f5f5;
    --slm-button-hover-bg: #2c2c2c;
    --slm-button-active-bg: #333333;
    --slm-button-focus-border: #ffbf00;

    --slm-button-primary-container-bg: #1b6de0;
    --slm-button-primary-container-border: #1b6de0;
    --slm-button-primary-hover-bg: #236fe3;
    --slm-button-primary-active-bg: #1a56b9;
    --slm-button-primary-disabled-bg: #274b7a;

    --slm-button-secondary-container-bg: #2a2a2a;
    --slm-button-secondary-container-border: #3a3a3a;
    --slm-button-secondary-text: #f5f5f5;
    --slm-button-secondary-hover-bg: #323232;
    --slm-button-secondary-active-bg: #3a3a3a;
    --slm-button-secondary-disabled-bg: #262626;
    --slm-button-secondary-disabled-text: #aaaaaa;

    --slm-button-light-container-bg: #2a2a2a;
    --slm-button-light-container-border: #3a3a3a;
    --slm-button-light-text: #f5f5f5;
    --slm-button-light-hover-bg: #323232;
    --slm-button-light-active-bg: #3a3a3a;
    --slm-button-light-disabled-bg: #262626;
    --slm-button-light-disabled-text: #aaaaaa;

    --slm-button-danger-container-bg: #b93a4a;
    --slm-button-danger-container-border: #b93a4a;
    --slm-button-danger-hover-bg: #c04656;
    --slm-button-danger-active-bg: #8a2b38;
    --slm-button-danger-disabled-bg: #5b2a32;
    --slm-button-danger-disabled-text: #ffffff;

    --slm-button-link-text: var(--slm-color-accent);
    --slm-button-link-disabled-text: #aaaaaa;

    --slm-button-focus-border: #ffbf00;

    /* SlmDialog dark overrides */
    --slm-dialog-ribbon-info:     #60a5fa;
    --slm-dialog-ribbon-confirm:  #fbbf24;
    --slm-dialog-ribbon-warn:     #fca5a5;
    --slm-dialog-ribbon-success:  #86efac;
    --slm-dialog-ribbon-input:    var(--slm-color-accent);

    --slm-dialog-surface:         #1a1f2e;
    --slm-dialog-border:          #334155;

    --slm-dialog-backdrop:        rgba(0, 0, 0, 0.55);

    --slm-dialog-shadow:
        0 2px 8px rgba(0,0,0,0.20),
        0 8px 24px rgba(0,0,0,0.30),
        0 24px 48px rgba(0,0,0,0.15);
}

/* ------------------------------------------------------------------------
   2. GLOBAL PAGE STYLING
   ------------------------------------------------------------------------ */

html,
body {
    height: 100%;
    margin: 0;
    padding: 0;
    background-color: var(--slm-color-bg);
    color: var(--slm-color-text-primary);
    box-sizing: border-box;
    font-family: var(--slm-font-family);
}

*,
*::before,
*::after {
    box-sizing: inherit;
}

a {
    color: var(--slm-color-accent);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

/* ------------------------------------------------------------------------
   3. MAIN LAYOUT SHELL
   ------------------------------------------------------------------------ */

.SLM-mainlayout-toplevel {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    height: 100vh;
    box-sizing: border-box;
    background-color: var(--slm-color-bg);
    color: var(--slm-color-text-primary);
}

.SLM-mainlayout-stack {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-width: 0;
    height: 100vh;
    box-sizing: border-box;
}

.SLM-mainlayout-content {
    flex: 1 1 auto;
    border: 2px solid var(--slm-color-border);
    overflow: visible;
    box-sizing: border-box;
    background-color: var(--slm-color-surface);
    padding-left: 5px;
}

/* Inner scroller for page content.
   Main content must not be a scroll container or fixed-position modals (DFormLoader) can be clipped.
*/
.SLM-mainlayout-content-scroll {
    height: 100%;
    overflow: auto;
    position: relative;
}

.SLM-leftmenu,
.SLM-rightmenu {
    position: relative;
    flex: 0 0 auto;
    width: 220px;
    min-width: 160px;
    max-width: 480px;
    height: 100vh;
    border: 2px solid var(--slm-color-border);
    box-sizing: border-box;
    overflow: hidden;
    background-color: var(--slm-color-surface);
}

.SLM-leftmenu-logo {
    padding: 4px 4px 4px 16px;
    border-bottom: 2px solid #2563eb;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    cursor: pointer;
    text-decoration: none;
}

.SLM-leftmenu-logo img {
    height: 24px;
    width: auto;
    display: block;
}

.SLM-leftmenu-header {
    padding: 10px;
    border-bottom: 1px solid rgba(0,0,0,0.08);
}

.SLM-leftmenu-header-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: stretch;
}

.SLM-leftmenu-header-meta {
    font-size: 12px;
    color: var(--v2-label-color);
    font-weight: 600;
    line-height: 1.2;
    min-width: 0;
}

.SLM-leftmenu-header-tenant {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 220px;
}

.SLM-leftmenu-header-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}

.SLM-resizer-handle {
    position: absolute;
    top: 0;
    width: 14px;
    height: 100%;
    cursor: col-resize;
    z-index: 50;
    background-color: rgba(0, 0, 0, 0.05);
}

.SLM-resizer-handle:hover {
    background-color: rgba(0, 0, 255, 0.25);
}

.SLM-resizer-left { right: -7px; }
.SLM-resizer-right { left: -1px; }

/* Right splitter: narrower to create the desired internal gutter without shrinking the left splitter. */
.SLM-resizer-handle.SLM-resizer-right {
	width: 8px;
}

.SLM-topmenu,
.SLM-statusbar {
    flex: 0 0 1.5rem;
    width: 100%;
    border: 2px solid var(--slm-color-border);
    box-sizing: border-box;
    background-color: var(--slm-color-surface);
}

.SLM-footer {
    flex: 0 0 auto;
    width: 100%;
    box-sizing: border-box;
}

/* ------------------------------------------------------------------------
   4. MISC GLOBAL HELPERS
   ------------------------------------------------------------------------ */

.slm-searchmode-toggle .slm-iconbtn {
    transition: background-color 120ms ease, border-color 120ms ease;
}

.slm-searchmode-toggle .slm-iconbtn.is-active {
    background-color: var(--slm-field-wrapper-border-focus, #e6f0ff);
    border-color: var(--slm-field-wrapper-border-focus, #4a90e2);
    border-width: 2px;
}

.slm-searchmode-toggle .slm-iconbtn.is-active i {
    color: var(--slm-color-text-primary, #1a1a1a);
}

.slm-breadcrumb-bar {
    background-color: color-mix(in srgb, var(--slm-color-surface) 70%, var(--slm-color-border) 30%);
    border: 1px solid color-mix(in srgb, var(--slm-color-border) 80%, var(--slm-color-text-primary) 20%);
    border-radius: 6px;
    padding: 0.35rem 0.5rem;
    box-shadow: 0 1px 0 rgba(0,0,0,0.14);
}
