﻿/* =========================================================
   RecruitMatrix - GLOBAL Entity Form Theme (dashboard look)
   Applies to ALL .crmEntityFormView (Power Pages / D365 Portals)
   Paste at the VERY BOTTOM of your main CSS file.
========================================================= */

.crmEntityFormView {
    --rmx-form-card: #ffffff;
    --rmx-form-border: var(--rmx-border, #e5e7eb);
    --rmx-form-shadow: var(--rmx-shadow, 0 10px 25px rgba(2, 6, 23, 0.08));
    --rmx-form-radius: var(--rmx-radius, 18px);
    --rmx-form-brand: var(--rmx-brand, #4f46e5);
    --rmx-form-ink: var(--rmx-ink, #0f172a);
    --rmx-form-sub: var(--rmx-sub, #64748b);
    --rmx-form-danger: var(--rmx-red, #ef4444);
}

/* Container spacing when a form exists inside it */
.container:has(.crmEntityFormView) {
    max-width: 1160px;
    padding-left: 24px;
    padding-right: 24px;
}

/* Main form card */
.crmEntityFormView .entity-form {
    background: var(--rmx-form-card);
    border: 1px solid var(--rmx-form-border);
    border-radius: var(--rmx-form-radius);
    box-shadow: var(--rmx-form-shadow);
    padding: 22px;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
}

/* Tabs / columns -> 2-column layout */
.crmEntityFormView div.tab.clearfix {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 18px !important;
    align-items: flex-start !important;
    width: 100% !important;
}

    /* Kill floats/inline widths */
    .crmEntityFormView div.tab.clearfix > .tab-column {
        float: none !important;
        clear: none !important;
        width: auto !important;
        flex: 1 1 0 !important;
        min-width: 0 !important;
    }

.crmEntityFormView .tab-column:empty {
    display: none !important;
}

.crmEntityFormView div.tab.clearfix > .tab-column > div {
    width: 100% !important;
}

/* Fieldsets as sub-cards */
.crmEntityFormView fieldset {
    border: 1px solid var(--rmx-form-border);
    border-radius: 14px;
    padding: 16px;
    margin: 0 0 14px 0;
    background: #fff;
}

/* Section headings */
.crmEntityFormView legend.section-title {
    border: 0;
    margin: 0 0 12px 0;
    padding: 0;
    width: 100%;
}

    .crmEntityFormView legend.section-title h3 {
        margin: 0;
        font-size: 14px;
        font-weight: 800;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: var(--rmx-form-ink);
    }

/* Remove table-ish look for Dynamics section tables only */
.crmEntityFormView table.section {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}

.crmEntityFormView td.zero-cell {
    display: none !important;
}

/* Field rows */
.crmEntityFormView table.section > tbody > tr {
    display: block;
    margin-bottom: 12px;
}

.crmEntityFormView td.form-control-cell,
.crmEntityFormView td.picklist-cell {
    display: block;
    width: 100%;
    padding: 0 !important;
    border: 0 !important;
}

/* Labels */
.crmEntityFormView .info .field-label {
    display: block;
    font-size: 13px;
    font-weight: 700;
    color: var(--rmx-form-ink);
    margin: 0 0 6px 0;
}

/* Required asterisk */
.crmEntityFormView .info.required .field-label::after {
    content: " *";
    color: var(--rmx-form-danger);
    font-weight: 900;
}

/* Inputs */
.crmEntityFormView .form-control,
.crmEntityFormView input[type="text"],
.crmEntityFormView input[type="email"],
.crmEntityFormView input[type="tel"],
.crmEntityFormView input[type="number"],
.crmEntityFormView input[type="url"],
.crmEntityFormView input[type="search"],
.crmEntityFormView select,
.crmEntityFormView textarea {
    width: 100% !important;
    border: 1px solid var(--rmx-form-border) !important;
    border-radius: 12px !important;
    padding: 11px 12px !important;
    background: #fff !important;
    color: var(--rmx-form-ink) !important;
    box-shadow: none !important;
    outline: none !important;
    font-size: 14px;
}

.crmEntityFormView textarea {
    resize: vertical;
    min-height: 46px;
    line-height: 1.4;
}

    /* Focus ring */
    .crmEntityFormView .form-control:focus,
    .crmEntityFormView input:focus,
    .crmEntityFormView select:focus,
    .crmEntityFormView textarea:focus {
        border-color: rgba(79, 70, 229, 0.55) !important;
        box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.12) !important;
    }

/* Native picklists (avoid PCF) */
.crmEntityFormView select.form-control {
    height: 44px !important;
    line-height: 44px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Safety: do NOT affect PCF inner selects */
.crmEntityFormView [id$="_Container"] select {
    height: auto !important;
    line-height: normal !important;
}

/* Validation summary */
.crmEntityFormView .validation-summary.alert {
    border-radius: 12px;
    border: 1px solid #fecaca;
    background: #fef2f2;
    color: #991b1b;
}

/* Actions row */
.crmEntityFormView .actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 10px;
    padding-top: 14px;
    border-top: 1px solid var(--rmx-form-border);
}

/* Primary submit */
.crmEntityFormView #UpdateButton.btn-primary,
.crmEntityFormView input#UpdateButton {
    background: #0b0b0f !important;
    border: 1px solid #0b0b0f !important;
    color: #fff !important;
    border-radius: 12px !important;
    padding: 12px 18px !important;
    font-weight: 800 !important;
    letter-spacing: 0.01em;
    box-shadow: 0 10px 22px rgba(2, 6, 23, 0.14) !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease;
}

    .crmEntityFormView #UpdateButton.btn-primary:hover,
    .crmEntityFormView input#UpdateButton:hover {
        transform: translateY(-1px);
        box-shadow: 0 14px 28px rgba(2, 6, 23, 0.18) !important;
    }

/* =========================================================
   PCF Multi-select (Updated Picklist) - msos-*
   Outer wrapper is usually: [id$="_Container"].flexbox
========================================================= */

/* Remove borders from generic nested flexbox so only OUTER gets a box */
.crmEntityFormView .flexbox {
    border: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
}

/* Outer container box */
.crmEntityFormView [id$="_Container"].flexbox {
    min-height: 44px !important;
    padding: 8px 12px !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    border: 1px solid var(--rmx-form-border) !important;
    border-radius: 12px !important;
    background: #fff !important;
}

    .crmEntityFormView [id$="_Container"].flexbox:focus-within {
        border-color: rgba(79, 70, 229, 0.55) !important;
        box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.12) !important;
    }

/* Ensure msos control takes full width */
.crmEntityFormView [id$="_Container"] .msos-container {
    width: 100%;
}

/* Search input inside msos */
.crmEntityFormView [id$="_Container"] .msos-input {
    border: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    background: transparent !important;
    height: 28px !important;
    line-height: 28px !important;
    padding: 0 !important;
    margin: 0 !important;
    min-width: 160px;
}

/* Pills */
.crmEntityFormView [id$="_Container"] .msos-selected-display-item {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 6px 10px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(79, 70, 229, 0.20) !important;
    background: rgba(79, 70, 229, 0.06) !important;
    color: var(--rmx-form-ink) !important;
    font-size: 13px !important;
    line-height: 1 !important;
}

/* Delete (x) */
.crmEntityFormView [id$="_Container"] .msos-quick-delete {
    opacity: 0.7 !important;
}

    .crmEntityFormView [id$="_Container"] .msos-quick-delete:hover {
        opacity: 1 !important;
    }

/* Dropdown options */
.crmEntityFormView .msos-selection .msos-option,
.crmEntityFormView .msos-selection li {
    border-radius: 10px !important;
}

    .crmEntityFormView .msos-selection .msos-option:hover,
    .crmEntityFormView .msos-selection li:hover {
        background: rgba(79, 70, 229, 0.08) !important;
    }

/* =========================================================
   Datepicker safety (don’t break table layout)
========================================================= */
.crmEntityFormView .datepicker table tr {
    display: table-row !important;
    margin: 0 !important;
}

.crmEntityFormView .datepicker table td,
.crmEntityFormView .datepicker table th {
    display: table-cell !important;
    text-align: center !important;
    vertical-align: middle !important;
}

/* Optional: nicer datepicker shell */
.crmEntityFormView .datepicker.dropdown-menu {
    border-radius: 14px !important;
    border: 1px solid var(--rmx-form-border) !important;
    box-shadow: var(--rmx-form-shadow) !important;
    padding: 10px !important;
}



/* =========================================================
   Responsive
========================================================= */
@media (max-width: 980px) {
    .crmEntityFormView div.tab.clearfix {
        flex-wrap: wrap !important;
    }

        .crmEntityFormView div.tab.clearfix > .tab-column {
            flex: 1 1 100% !important;
        }

    .crmEntityFormView .entity-form {
        padding: 18px;
    }
}


/* =========================================================
   GLOBAL FIX – Rounded Datepicker (Input + Button)
========================================================= */

/* Wrap the date input group */
.crmEntityFormView .input-group {
    display: flex !important;
    align-items: stretch !important;
}

    /* Date input */
    .crmEntityFormView .input-group input.form-control {
        border-radius: 12px 0 0 12px !important;
        height: 44px !important;
    }

/* Calendar button container */
.crmEntityFormView .input-group-addon,
.crmEntityFormView .input-group-btn .btn {
    border-radius: 0 12px 12px 0 !important;
    height: 44px !important;
    /*border-left: 0 !important;*/
    background: #f9fafb !important;
}

/* Calendar icon button */
.crmEntityFormView .input-group-btn .btn {
    padding: 0 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Ensure borders merge cleanly */
.crmEntityFormView .input-group input.form-control:focus {
    z-index: 2;
}

.crmEntityFormView .input-group-btn .btn {
    z-index: 1;
}

/* Focus glow across the whole control */
.crmEntityFormView .input-group:focus-within input.form-control,
.crmEntityFormView .input-group:focus-within .input-group-addon,
.crmEntityFormView .input-group:focus-within .input-group-btn .btn {
    border-color: rgba(79, 70, 229, 0.55) !important;
    box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.12) !important;
}

/* Calendar dropdown itself */
.crmEntityFormView .datepicker.dropdown-menu {
    border-radius: 14px !important;
}


/* =========================================================
   FIX – Datepicker button shape & alignment
========================================================= */

/* Target ONLY datepicker input groups */
.crmEntityFormView .input-group.date,
.crmEntityFormView .input-group:has(.datepicker) {
    display: flex !important;
    align-items: stretch !important;
}

    /* Date input */
    .crmEntityFormView .input-group.date input.form-control {
        border-radius: 12px 0 0 12px !important;
        height: 44px !important;
    }

    /* Calendar button */
    .crmEntityFormView .input-group.date .input-group-addon,
    .crmEntityFormView .input-group.date .input-group-btn .btn {
        width: 44px !important;
        min-width: 44px !important;
        padding: 0 !important;
        border-radius: 0 12px 12px 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    /* Prevent tall pill stretching */
    .crmEntityFormView .input-group.date .input-group-addon {
        height: 44px !important;
    }

    /* Clean border join */
    .crmEntityFormView .input-group.date .input-group-addon {
        border-left: 0 !important;
    }


/* =========================================================
   FIX – Currency ($) input groups
========================================================= */

/* Currency symbol addon */
.crmEntityFormView .input-group .input-group-addon:not(.btn) {
    border-radius: 12px 0 0 12px !important;
    height: 44px !important;
    padding: 0 14px !important;
    background: #f9fafb !important;
    border-right: 0 !important;
    display: flex !important;
    align-items: center !important;
    font-weight: 600;
}

/* Currency input */
.crmEntityFormView .input-group input.form-control {
    border-radius: 0 12px 12px 0 !important;
    height: 44px !important;
}

/* Merge borders cleanly */
.crmEntityFormView .input-group input.form-control {
    /*border-left: 0 !important;*/
}


/* =========================================================
   FINAL FIX – Datepicker input-group (Portals)
   Targets the calendar button reliably (.datepickerbutton)
========================================================= */

/* Date input group should behave as one rounded control */
.crmEntityFormView .input-group:has(.datepickerbutton),
.crmEntityFormView .input-group:has(.glyphicon-calendar),
.crmEntityFormView .input-group:has(.fa-calendar) {
    display: flex !important;
    align-items: stretch !important;
    width: 100%;
}

    /* Date input */
    .crmEntityFormView .input-group:has(.datepickerbutton) > input.form-control,
    .crmEntityFormView .input-group:has(.glyphicon-calendar) > input.form-control,
    .crmEntityFormView .input-group:has(.fa-calendar) > input.form-control {
        height: 44px !important;
        border-radius: 12px 0 0 12px !important;
    }

    /* Calendar button container (usually input-group-addon) */
    .crmEntityFormView .input-group:has(.datepickerbutton) > .input-group-addon,
    .crmEntityFormView .input-group:has(.glyphicon-calendar) > .input-group-addon,
    .crmEntityFormView .input-group:has(.fa-calendar) > .input-group-addon,
    .crmEntityFormView .input-group:has(.datepickerbutton) > .input-group-btn,
    .crmEntityFormView .input-group:has(.glyphicon-calendar) > .input-group-btn,
    .crmEntityFormView .input-group:has(.fa-calendar) > .input-group-btn {
        width: 44px !important;
        min-width: 44px !important;
        height: 44px !important;
        padding: 0 !important;
        border-radius: 0 12px 12px 0 !important;
        border-left: 0 !important;
        background: #f9fafb !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    /* The actual clickable button/icon */
    .crmEntityFormView .input-group:has(.datepickerbutton) .datepickerbutton,
    .crmEntityFormView .input-group:has(.glyphicon-calendar) .datepickerbutton,
    .crmEntityFormView .input-group:has(.fa-calendar) .datepickerbutton {
        width: 44px !important;
        height: 44px !important;
        padding: 0 !important;
        border: 0 !important;
        background: transparent !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    /* Make borders merge nicely */
    .crmEntityFormView .input-group:has(.datepickerbutton) > input.form-control,
    .crmEntityFormView .input-group:has(.glyphicon-calendar) > input.form-control,
    .crmEntityFormView .input-group:has(.fa-calendar) > input.form-control {
        border-right: 0 !important;
    }

    /* Focus glow across BOTH input + button */
    .crmEntityFormView .input-group:has(.datepickerbutton):focus-within > input.form-control,
    .crmEntityFormView .input-group:has(.datepickerbutton):focus-within > .input-group-addon,
    .crmEntityFormView .input-group:has(.datepickerbutton):focus-within > .input-group-btn,
    .crmEntityFormView .input-group:has(.glyphicon-calendar):focus-within > input.form-control,
    .crmEntityFormView .input-group:has(.glyphicon-calendar):focus-within > .input-group-addon,
    .crmEntityFormView .input-group:has(.glyphicon-calendar):focus-within > .input-group-btn,
    .crmEntityFormView .input-group:has(.fa-calendar):focus-within > input.form-control,
    .crmEntityFormView .input-group:has(.fa-calendar):focus-within > .input-group-addon,
    .crmEntityFormView .input-group:has(.fa-calendar):focus-within > .input-group-btn {
        border-color: rgba(79, 70, 229, 0.55) !important;
        box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.12) !important;
    }

    /* Prevent the input-group-addon from rounding on the LEFT (date only) */
    .crmEntityFormView .input-group:has(.datepickerbutton) > .input-group-addon,
    .crmEntityFormView .input-group:has(.glyphicon-calendar) > .input-group-addon,
    .crmEntityFormView .input-group:has(.fa-calendar) > .input-group-addon {
        border-radius: 0 12px 12px 0 !important;
    }


/* =========================================================
   FINAL FIX – Remove inner black border from MSOS multiselect
========================================================= */

/* Kill ALL inner MSOS borders & backgrounds */
.crmEntityFormView [id$="_Container"] .msos-container,
.crmEntityFormView [id$="_Container"] .msos-selection,
.crmEntityFormView [id$="_Container"] .msos-selected-display,
.crmEntityFormView [id$="_Container"] .msos-selected-display-list,
.crmEntityFormView [id$="_Container"] .msos-input-container {
    border: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
    outline: none !important;
}

/* Ensure nothing inside reintroduces a border */
.crmEntityFormView [id$="_Container"] * {
    box-shadow: none !important;
}

/* Keep outer container as the ONLY visible box */
.crmEntityFormView [id$="_Container"].flexbox {
    border: 1px solid var(--rmx-form-border) !important;
    border-radius: 12px !important;
    background: #fff !important;
}

    /* Focus state only on outer container */
    .crmEntityFormView [id$="_Container"].flexbox:focus-within {
        border-color: rgba(79, 70, 229, 0.55) !important;
        box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.12) !important;
    }


/* ---------------------------------------------------------
   Left sidebar card (profile + menu) to match theme
--------------------------------------------------------- */
.panel.panel-default {
    border: 1px solid #e6eaf2 !important;
    border-radius: 16px !important;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06) !important;
    overflow: hidden;
}

    .panel.panel-default .panel-heading {
        background: #fff !important;
        border-bottom: 1px solid #eef2f7 !important;
    }

    .panel.panel-default .weblinks.list-group {
        border-top: 0 !important;
        margin-bottom: 0 !important;
    }

    .panel.panel-default .weblink.list-group-item {
        border: 0 !important;
        border-top: 1px solid #eef2f7 !important;
        padding: 12px 14px !important;
        color: #0f172a !important;
        font-weight: 600;
    }

        .panel.panel-default .weblink.list-group-item.active {
            background: black !important;
            color: #fff !important;
        }
