﻿/* =====================================================================
   Admin Modal Variant: simple-exemption (DUPLICATE-ID SAFE)
   ---------------------------------------------------------------------
   Problem:
     - First render: one #adminModalChildContent
     - Later: a second nested #adminModalChildContent appears, doubling rules

   Fix (CSS-only):
     - NEVER scope to the duplicated ID
     - Scope to the OUTER modal-content only:
         #adminModalContainer > .modal-content.admin-modal--simple-exemption
     - Make the INNER nested .modal-content visually inert
   ===================================================================== */


/* =====================================================================
   0) ROOT SCOPE (OUTER ONLY) + TOKENS
   ===================================================================== */

#adminModalContainer > .modal-content.admin-modal--simple-exemption,
#adminModalContainer > .modal-content.admin-modal--simple-exemption * {
    box-sizing: border-box;
}

#adminModalContainer > .modal-content.admin-modal--simple-exemption {
    /* Theme tokens */
    --m-bg: #0b1424;
    --m-surface: #0f1a2e;
    --m-text: #ffffff;
    --m-muted: rgba(255,255,255,.88);
    --m-border: rgba(255,255,255,.14);
    --m-primary: #0d7bff;
    --m-primary-hover: #0b6de0;
    /* Sizing */
    --m-title: 54px;
    --m-label: 32px;
    --m-font: 32px;
    --m-help: 26px;
    --m-control-h: 76px;
    color: var(--m-text) !important;
    background: var(--m-surface) !important;
}


    /* =====================================================================
   0.1) NEUTRALISE THE NESTED/INNER DUPLICATE .modal-content
   - If a second .modal-content shows up inside, it stops adding borders,
     backgrounds, shadows, height/overflow rules, etc.
   ===================================================================== */

    #adminModalContainer > .modal-content.admin-modal--simple-exemption > .modal-content {
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
        border-radius: 0 !important;
        height: auto !important;
        overflow: visible !important;
    }


/* =====================================================================
   1) KIOSK / FULL-VIEWPORT (VISUAL ONLY)
   ===================================================================== */

#adminModal {
    padding-right: 0 !important; /* Bootstrap adds padding for scrollbar; remove */
}

    /* modal-dialog wrapper */
    #adminModal #adminModalContainer.modal-dialog {
        max-width: 100vw !important;
        width: 100vw !important;
        height: 100vh !important;
        margin: 0 !important;
    }

    /* OUTER modal-content fills viewport */
    #adminModal #adminModalContainer > .modal-content.admin-modal--simple-exemption {
        height: 100vh !important;
        max-height: 100vh !important;
        border-radius: 0 !important;
    }


/* =====================================================================
   2) MODAL SHELL (BACKGROUND + BORDER)
   ===================================================================== */

#adminModalContainer.modal-dialog,
#adminModalContainer > .modal-content.admin-modal--simple-exemption {
    background: var(--m-surface) !important;
    color: var(--m-text) !important;
}

#adminModalContainer > .modal-content.admin-modal--simple-exemption {
    border: 1px solid var(--m-border) !important;
    box-shadow: 0 14px 40px rgba(0,0,0,.45) !important;
    overflow: hidden !important;
}


    /* =====================================================================
   3) HEADER
   - Sticky header
   - Title centred without blocking the X
   - Username via CSS var --modal-username (set inline)
   ===================================================================== */

    #adminModalContainer > .modal-content.admin-modal--simple-exemption #AdminEditModalHeader {
        position: sticky !important;
        top: 0 !important;
        z-index: 50 !important;
        background: linear-gradient(180deg, var(--m-surface) 0%, var(--m-bg) 100%) !important;
        border-bottom: 1px solid var(--m-border) !important;
        min-height: 160px !important;
        padding: 52px 28px 28px 28px !important;
        /* anchor pseudo + absolute title */
        position: relative !important;
    }

        /* Username (from TS): --modal-username: "user@x.com" */
        #adminModalContainer > .modal-content.admin-modal--simple-exemption #AdminEditModalHeader::before {
            content: var(--modal-username, "");
            position: absolute;
            left: 28px;
            top: 16px;
            font-size: 18px;
            font-weight: 700;
            color: rgba(255,255,255,.9);
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            max-width: 40%;
            pointer-events: none;
        }

        /* Title centred, does not block close */
        #adminModalContainer > .modal-content.admin-modal--simple-exemption #AdminEditModalHeader .modal-title {
            position: absolute !important;
            left: 50% !important;
            top: 50% !important;
            transform: translate(-50%, -50%) !important;
            margin: 0 !important;
            text-align: center !important;
            font-size: var(--m-title) !important;
            font-weight: 900 !important;
            line-height: 1.05 !important;
            letter-spacing: .4px !important;
            color: var(--m-text) !important;
            pointer-events: none !important;
        }

        /* Close (X): keep Bootstrap positioning, improve contrast */
        #adminModalContainer > .modal-content.admin-modal--simple-exemption #AdminEditModalHeader .close {
            opacity: 1 !important;
            color: #ffffff !important;
            text-shadow: none !important;
        }

            #adminModalContainer > .modal-content.admin-modal--simple-exemption #AdminEditModalHeader .close span {
                color: #ffffff !important;
            }


    /* =====================================================================
   4) BODY / SCROLL REGION
   ===================================================================== */

    #adminModalContainer > .modal-content.admin-modal--simple-exemption .AdminEditModalFormWrapper.modal-body {
        background: var(--m-surface) !important;
        padding: 34px 30px !important;
        max-height: calc(100vh - 170px) !important;
        overflow-y: auto !important;
    }


    /* =====================================================================
   5) ROW BASELINE STYLING
   ===================================================================== */

    #adminModalContainer > .modal-content.admin-modal--simple-exemption .row.mb-1 {
        padding: 22px 0 !important;
        border-bottom: 1px solid rgba(255,255,255,.06) !important;
        align-items: flex-start !important;
    }


/* =====================================================================
   6) FIELD ROW LAYOUT (TS ADDS .field-row-2col)
   ===================================================================== */

@media (min-width: 768px) {
    #adminModalContainer > .modal-content.admin-modal--simple-exemption .row.mb-1.field-row-2col {
        display: grid !important;
        grid-template-columns: 280px 1fr !important;
        column-gap: 24px !important;
        align-items: start !important;
    }

        #adminModalContainer > .modal-content.admin-modal--simple-exemption .row.mb-1.field-row-2col > .col-md-2,
        #adminModalContainer > .modal-content.admin-modal--simple-exemption .row.mb-1.field-row-2col > .col-md-10 {
            max-width: none !important;
            width: auto !important;
            padding-left: 0 !important;
            padding-right: 0 !important;
            min-width: 0 !important;
        }
}

/* Label alignment overrides */
#adminModalContainer > .modal-content.admin-modal--simple-exemption .row.mb-1 > .col-md-2 label {
    height: auto !important;
    align-items: flex-start !important;
    padding-top: 12px !important;
}

    #adminModalContainer > .modal-content.admin-modal--simple-exemption .row.mb-1 > .col-md-2 label.d-flex {
        align-items: flex-start !important;
    }

/* Labels: big + bold, wrap */
#adminModalContainer > .modal-content.admin-modal--simple-exemption label,
#adminModalContainer > .modal-content.admin-modal--simple-exemption label strong {
    font-size: var(--m-label) !important;
    font-weight: 900 !important;
    color: var(--m-muted) !important;
    display: block !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
    line-height: 1.1 !important;
}


/* =====================================================================
   7) CONTROLS (INPUTS / SELECTS)
   ===================================================================== */

#adminModalContainer > .modal-content.admin-modal--simple-exemption .form-control,
#adminModalContainer > .modal-content.admin-modal--simple-exemption .form-select,
#adminModalContainer > .modal-content.admin-modal--simple-exemption input[type="text"],
#adminModalContainer > .modal-content.admin-modal--simple-exemption select {
    min-height: var(--m-control-h) !important;
    font-size: var(--m-font) !important;
    padding: 16px 22px !important;
    border-radius: 18px !important;
    background: rgba(255,255,255,.06) !important;
    color: var(--m-text) !important;
    border: 1px solid var(--m-border) !important;
}

    #adminModalContainer > .modal-content.admin-modal--simple-exemption .form-control:focus,
    #adminModalContainer > .modal-content.admin-modal--simple-exemption .form-select:focus {
        outline: none !important;
        border-color: var(--m-primary) !important;
        box-shadow: 0 0 0 6px rgba(13,123,255,.25) !important;
    }

/* Validation */
#adminModalContainer > .modal-content.admin-modal--simple-exemption .text-danger,
#adminModalContainer > .modal-content.admin-modal--simple-exemption .field-validation-error {
    font-size: var(--m-help) !important;
    margin-top: 10px !important;
    color: #ff6b6b !important;
}


/* =====================================================================
   8) SELECT + OPTION (CSS-ONLY LIMITS)
   ===================================================================== */

#adminModalContainer > .modal-content.admin-modal--simple-exemption select {
    appearance: none !important;
    padding-right: 76px !important;
    background-color: rgba(255,255,255,.06) !important;
    color: #ffffff !important;
    font-size: var(--m-font) !important;
    font-weight: 700 !important;
    background-image: linear-gradient(45deg, transparent 50%, rgba(255,255,255,.9) 50%), linear-gradient(135deg, rgba(255,255,255,.9) 50%, transparent 50%);
    background-position: calc(100% - 38px) 50%, calc(100% - 28px) 50%;
    background-size: 12px 12px, 12px 12px;
    background-repeat: no-repeat;
    scrollbar-width: thin;
    scrollbar-color: #0d7bff #0f1a2e;
}

    #adminModalContainer > .modal-content.admin-modal--simple-exemption select option {
        background-color: #0f1a2e !important;
        color: #ffffff !important;
        font-size: 28px !important;
        padding: 12px 16px !important;
    }

        #adminModalContainer > .modal-content.admin-modal--simple-exemption select option:checked,
        #adminModalContainer > .modal-content.admin-modal--simple-exemption select option:hover {
            background-color: #0d7bff !important;
            color: #ffffff !important;
        }

    /* WebKit scrollbar */
    #adminModalContainer > .modal-content.admin-modal--simple-exemption select::-webkit-scrollbar {
        width: 10px;
    }

    #adminModalContainer > .modal-content.admin-modal--simple-exemption select::-webkit-scrollbar-track {
        background: #0f1a2e;
    }

    #adminModalContainer > .modal-content.admin-modal--simple-exemption select::-webkit-scrollbar-thumb {
        background-color: #0d7bff;
        border-radius: 10px;
        border: 2px solid #0f1a2e;
    }


/* =====================================================================
   9) ACTION ROW (ADD BUTTON)
   - Hide bottom Close button (not the header X)
   - Make Add/Submit fill row
   ===================================================================== */

/* Hide Close buttons inside the form footer area */
#adminModalContainer > .modal-content.admin-modal--simple-exemption #AdminEditFormModal button.btn-default,
#adminModalContainer > .modal-content.admin-modal--simple-exemption #AdminEditFormModal button[data-dismiss="modal"],
#adminModalContainer > .modal-content.admin-modal--simple-exemption #AdminEditFormModal button[data-bs-dismiss="modal"] {
    display: none !important;
}

/* Hide its column (offset-sm-3) */
#adminModalContainer > .modal-content.admin-modal--simple-exemption
#AdminEditFormModal > .row.mb-1 > .col-sm-3.offset-sm-3 {
    display: none !important;
}

/* Action row columns to full width */
#adminModalContainer > .modal-content.admin-modal--simple-exemption
#AdminEditFormModal > .row.mb-1 > .col-sm-3 {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin: 0 !important;
}

/* Clean up row gutters */
#adminModalContainer > .modal-content.admin-modal--simple-exemption
#AdminEditFormModal > .row.mb-1 {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Submit button full width */
#adminModalContainer > .modal-content.admin-modal--simple-exemption #btnSubmit {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    min-height: 96px !important;
    font-size: var(--m-font) !important;
    font-weight: 900 !important;
    border-radius: 18px !important;
    background: var(--m-primary) !important;
    border: 1px solid var(--m-primary) !important;
    color: #fff !important;
}

    #adminModalContainer > .modal-content.admin-modal--simple-exemption #btnSubmit:hover {
        background: var(--m-primary-hover) !important;
        border-color: var(--m-primary-hover) !important;
    }


/* =====================================================================
   10) MOBILE TWEAKS
   ===================================================================== */

@media (max-width: 768px) {
    #adminModalContainer > .modal-content.admin-modal--simple-exemption #AdminEditModalHeader {
        min-height: 170px !important;
        padding-top: 54px !important;
    }

        #adminModalContainer > .modal-content.admin-modal--simple-exemption #AdminEditModalHeader::before {
            max-width: 60%;
        }
}
