﻿@property --primary-accent-color-h {
    syntax: "<integer>";
    inherits: true;
    initial-value: 136;
}

@property --primary-accent-color-s {
    syntax: "<percentage>";
    inherits: true;
    initial-value: 52%;
}

@property --primary-accent-color-l {
    syntax: "<percentage>";
    inherits: true;
    initial-value: 45%;
}

@property --secondary-accent-color-h {
    syntax: "<integer>";
    inherits: true;
    initial-value: 0;
}

@property --secondary-accent-color-s {
    syntax: "<percentage>";
    inherits: true;
    initial-value: 0%;
}

@property --secondary-accent-color-l {
    syntax: "<percentage>";
    inherits: true;
    initial-value: 29%;
}

@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 100 900; /* Defines the full weight range from Thin to Black */
    font-display: swap;
    src: url('fonts/Inter-VariableFont_opsz,wght.ttf') format('truetype-variations');
}


@layer reset {

    *, *::before, *::after {
        box-sizing: border-box;
        margin: 0;
        padding: 0;
        font-family: Inter;
        interpolate-size: allow-keywords;
    }
    /*     * {
        outline: 1px solid red !important;
        opacity: 1 !important;
        visibility:visible !important;
    }
*/

    input, button, textarea, select {
        font: inherit;
    }

    html {
        font-family: 'Inter', Arial, sans-serif;
        outline: solid 1px lime;
        /*        scrollbar-gutter: stable;*/
        background-color: ActiveBorder;
        /*        font-size: 16px;*/
    }

    body {
        font-family: 'Inter', Arial, sans-serif;
        /*        font-size: 16px;*/
    }


    h1 {
        font-size: clamp(1.4rem,1rem+4vw,2.25rem);
        font-weight: 200;
        line-height: 1.5em;
        margin-block: 0.15rem 1.1rem;
        color: hsl(0,0,29);
    }

    h2 {
        font-size: clamp(1.2rem,0.7rem+4vw,2.05rem);
        font-weight: 300;
        line-height: 1.75rem;
        margin-block: 0.15rem 1rem;
    }

    button {
        /*        max-height: 48px;*/
        border-radius: 5px;
        height: fit-content;
        margin-inline: 0.25rem;
        margin-block: 1rem;
        width: fit-content;
    }

        button.w-100 {
            width: 100%;
        }


    :where(a) {
        color: unset;
        text-decoration: none;
    }
}


@layer branding {
    :root {
        /*        --primary-accent-color: hsl( var(--primary-accent-color-h), var(--primary-accent-color-s), var(--primary-accent-color-l) );*/
        --primary-accent-color: var(--primary-500);
        --secondary-accent-color: hsl( var(--secondary-accent-color-h), var(--secondary-accent-color-s), var(--secondary-accent-color-l) );
        /*        --secondary-accent-color: oklch(0.93 0.03);*/
        --text-color-white: white;
        --text-color-gray: rgb(204, 204, 204);
        --text-color-primary-accent-color: var(--primary-accent-color);
        interpolate-size: allow-keywords;
    }
}



.btn-primary:not(:disabled) {
    background-color: var(--primary-500);
    color: var(--text-color-white);
    transition: background-color 1s;

    &:hover {
        background-color: var(--primary-700);
    }

    &:focus-within {
        outline-color: var(--primary-900);
    }
}

.btn-secondary {
    background-color: white;
    color: var(--primary-accent-color);
    outline-color: var(--primary-accent-color);
    transition: all 0.3s;

    &:hover {
        outline: solid 2px var(--primary-700);
    }
}

body {
    background-color: var(--bg-surface);
    /*    background-color: azure;*/
    min-height: 100vh;
    min-height: 100dvh;
    min-width: 100vw;
    min-width: 100dvw;
    min-width: 100%;
    max-width: 100%;
    max-width: 100dvw;
    display: grid;
    grid-template-areas:
        "sidebar header"
        "sidebar main"
        "sidebar footer";
    grid-template-columns: max-content 1fr;
    grid-template-rows: auto 1fr auto;
    transition: grid-template-columns 1s cubic-bezier(0.4, 0, 0.2, 1);
    align-items: start;
}

    body:not(:has(.sidebar)) {
        grid-template-areas: "header " "main" "footer";
        grid-template-columns: 1fr;

        & main {
            margin-inline: 10vw;
        }
    }



    body:has(.split-panel) {
        display: grid;
        grid-template-columns: 1fr;
        grid-template-rows: 1fr;
        grid-template-areas: "main";
    }


.header {
    /*    padding: 1rem;*/
    grid-area: header;
    background-color: var(--primary-500);
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: sticky;
    top:0;
    z-index: 99999;
}

.header-button {
    /*        position: absolute;*/
    bottom: 0;
    right: 2rem;
    margin-block: 0;
    transform: translateY(50%);
}

.header img {
    height: 100%;
    object-fit: contain;
    padding: var(--space-3);
    max-height: 6rem;
}

    .header img + img {
        margin-left: 1rem;
    }

.sidebar {
    grid-area: sidebar;
    /*    grid-row: 1/-1;*/
    position: sticky;
    top: 0;
    align-self: start;
    overflow-y: auto;
    /*    align-items: start;*/
    min-width: min-content;
    height: 100vh;
    /*    max-height: 100vh;*/
    height: 100dvh;
    /*    max-height: 100dvh;*/
    box-shadow: var(--shadow-lg);
    /*    background-color: azure;*/
    transition: width 5s;
    transition: min-width 5s;
}

.footer {
    grid-area: footer;
    display: flex;
    gap: var(--space-3);
    justify-content: space-between;
    background-color: var(--gray-700);
    color: var(--text-color-gray);
    font-size: 0.8rem;
    padding: var(--space-3);

    @media (width <= 450px) {
        flex-direction: column;
    }

    & a {
        color: var(--primary-500);
    }
}



/*    .footer p {
        margin-block: 0.25rem;
    }*/

.main {
    grid-area: main;
    margin: 1rem;
    /*    outline: gray 1px solid;*/
    /*margin-left: 250px;*/
}




a, .btn-link {
    color: #006bb7;
}

button .btn-primary {
    color: #fff;
    background-color: var(--primary-accent-color);
    border-color: var(--primary-accent-color);
    border-radius: 2px;
}

/*.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}*/



.search-panel {
    display: flex;
    align-items: start;
    gap: 1rem;

    & button.btn-search {
        margin-block: 0;
    }
}

.content {
    /*    padding-top: 1.1rem;*/
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.form-control.invalid, div.radio-group.invalid, {
    outline: 1px solid var(--color-error);
}


/*.invalid {
    outline: 5px var(--color-error)  solid;
}*/

.validation-message, .text-danger {
    color: var(--color-error);
}

.blazor-error-boundary {
    display: none;
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }


.link-plus-icon {
    display: flex;
    width: max-content;
    color: inherit;
    /*    color: var(--text-color-primary-accent-color);*/
    gap: 0.5rem;
    padding: 0.55rem 0.5rem 0.5rem 1rem;
    /*    border: solid 1px gray;*/
    /*    border-radius: 15px;*/
    text-decoration: none;
    color: var(--primary-500);
    /*    align-content: center;*/
    align-items: center;

    & span {
        font-size: 0.9rem;
        vertical-align: middle;
    }

    &:hover {
        cursor: pointer;
        color: var(--primary-700);

        svg.fa-icon {
            fill: var(--primary-700);
        }
    }
}

/*a {
    text-decoration: none;
    color: var(--prinary-500);
}
*/


a p {
    text-decoration: underline;
    text-underline-offset: 5px;
}

.address-container {
    --primary-accent-color-h: 136;
    --primary-accent-color-s: 52%;
    --primary-accent-color-l: 45%;
    background-color: hsl( var(--primary-accent-color-h), var(--primary-accent-color-s), var(--primary-accent-color-l));
    background-color: hsla(136,52%,45%,0.1);
    color: black;
    width: max-content;
    padding: 0.75em;
    margin-block-start: 0.5rem;
    margin-inline-start: 0.5rem;
    border-radius: 8px;
    box-shadow: 1px 1px 1px hsla(136,52%,45%,0.2);
}

.address-container-header {
    grid-column: 1/-1;
    display: flex;
    gap: 3.5rem;
    justify-content: space-between;
    align-items: center;
    margin-block-end: 0.5rem;
}

.address-container-display {
    /*    background-color: inherit;
    color: inherit;*/
}

.address-container-edit {
    border: 5px solid red;
    grid-column: 1/-1;
}


button {
    border: unset;
    cursor: pointer;
    outline: solid 1px var(--primary-accent-color);
    padding: 0.5rem 1.25rem;
    transition: background-color, .5s;

    &:hover:not(:disabled, .width-full, .btn-secondary) {
        background-color: var(--primary-300);
    }
}

.primary {
    background-color: var(--primary-accent-color);
    color: var(--text-color-white);
}

.btn.btn-secondary {

    &:hover {
        outline: solid 3px var(--primary-100);
    }
}


form {
    display: grid;
    column-gap: 1rem;
    grid-template-columns: 1fr;
    /*    border: solid red 2px;*/
    padding: 0.5rem;
    /*    min-width:100%;*/
    /*    width: auto;*/
    /*@media (width> 400px) {
        grid-template-columns: min(150px,auto) 1fr;*/
    /*        min-width: max-content;*/
    /*width:max-content;
    }*/
}

fieldset legend {
    margin-block-end: 0.25rem;
}

/*form > :not(div.form-input-template) {
    grid-column: 1/-1;
    padding: 0.25rem;
}*/
.form-input-template {
    /*    grid-column: span 2;*/
    /*    border: 1px solid var(--primary-accent-color);*/
    display: grid;
    gap: 0.3rem;
    grid-template-columns: 1fr;
    align-items: center;
    padding: 0.25rem;
    /*    min-width: 100%;*/
    margin-block: 0.5rem 0.25rem;
    /*    @media (width > 500px) {
        grid-column: span 2;
        grid-template-columns:subgrid;
    }*/
}

    .form-input-template input {
        width: 100%
        /*        @media (width > 500px) {
            width: max(35ch, 150px);
        }*/
    }

input, select {
    max-width: 100%;
    width: 100%;
    font-family: inherit;
    /*    max-width: 50ch;*/
}

    input.form-control,
    select,
    div.radio-group {
        font-size: 1rem;
        border: unset;
        outline: solid 1px var(--primary-accent-color);
        border-radius: var(--radius-sm);
    }

        input.form-control, select.form-control {
            padding-inline: 0.5rem;
            padding-block: 0.6rem;
        }

    input[type="search"].form-control {
        width: 100%;
        padding-block: 0.35rem;
        padding-inline-start: 0.35rem;
        padding-inline-end: .65rem;
        margin-block-end: 0.35rem;
    }

    input:active,
    input:focus,
    div.radio-group:has(:checked),
    select.form-control:active,
    select.form-control:focus {
        border: unset;
        outline-width: 2px;
    }

.hint-text {
    font-size: 0.8rem;
    grid-column: 1/-1;
    font-style: italic;
    color: dimgray;
    max-width: 60ch;
}

h4 {
    margin-block-start: 1rem;
    margin-block-end: 0.5rem;
}


.form-group fieldset {
    display: grid;
    grid-template-columns: repeat(auto-fit,minmax(150px, 1fr));
    gap: 1rem;
    border: unset;
    margin-block: 1rem;
    padding: 0.25rem;
}

    .form-group fieldset legend {
        padding-inline: 0rem;
    }

    .form-group fieldset legend {
        padding-inline: 0rem;
    }

fieldset legend {
    display: flex;
    gap: 1ch;

    &::after {
        content: "*";
        color: var(--primary-accent-color);
    }
}

input[type="radio"] {
    color: white;
    width: 1.2rem;
    aspect-ratio: 1/1;
}

.radio-group {
    position: relative;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0.25rem;
    justify-content: space-between;
    border: 1px solid gray;
    border-radius: 6px;

    &:focus-visible {
        outline-color: red;
    }
}


    .radio-group:has([type="radio"]:checked) {
        background-color: var(--primary-accent-color);
        font-weight: bold;
    }

    .radio-group:has([type="radio"]) label {
        align-self: center;
        padding: 1em;
    }

    .radio-group:has([type="radio"]) input {
        margin-inline: 1rem;
        transform: scale(1.5);
        accent-color: white;
        place-self: center;
        padding: 0.5rem;
    }


.container {
    min-width: 300px;
    max-width: 80%;
    padding: 1rem;
    margin-inline: 0;
    /*    @media (width > 450px) {
        width:35dvw;
        margin-inline:auto;
        min-width:max-content;
    }*/
}

    .container.panel-centered {
        min-width: 300px;
        width: fit-content;
        box-shadow: var(--shadow-xl);
        background-color: white;
        /*place-self: center;
        transform: translateY(-3%);*/ /* Nudges the panel 20px higher, making the top gap smaller than the bottom */
    }


.w-10 {
    width: 15ch;

    @media (width > 500px) {
        width: 15ch;
    }
}



input.form-control.w-10 {
    width: 15ch;

    @media (width > 500px) {
        width: 18ch;
    }
}

input.form-control.w-6 {
    width: 10ch;

    @media (width > 500px) {
        width: 12ch;
    }
}


button:disabled {
    background-color: var(--gray-50);
    color: var(--gray-400);
}



input.form-control.fill-container-width, select.form-control.fill-container-width {
    display: flex;
    margin-inline: 1.6px;
    /*    border: 2px orange solid;*/
    background-color: lavender;
    width: 100%;
    flex-grow: 1;
}



button.btn-search {
    color: white;
    background-color: var(--primary-accent-color);
}

form.modal-panel {
    height: 98dvh;
    grid-template-areas: "header" "content" "footer";
    grid-template-rows: auto 1fr auto;
    gap: 0.75rem;
}

.grid-header {
    grid-area: header;
}

.grid-footer {
    grid-area: footer;
    /*    background-color: var(--primary-accent-color);*/
    color: gray;
}

.grid-content {
    grid-area: content;
    /*    overflow: auto;*/
}

div.validation-message, div.text-danger {
    font-size: 12px;
    text-align: right;
}


.card-grid-view {
    --min-col-size: 300px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(var(--min-col-size),100%),1fr));
    /*    grid-template-columns: repeat(auto-fit, minmax(min(auto,100%),1fr));*/
    gap: var(--space-8);
    margin-block: var(--space-8);
}

.card {
    display: grid;
    gap: var(--space-3);
    grid-template-areas: "header" "body" "footer";
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
    border: solid 1px var(--gray-50);
    box-shadow: var(--shadow-sm);
    max-width: 450px;
    border-radius: 5px;
    border-block-start: 3px solid var(--primary-500);
    transition: border-inline 0.4s border-block-end 0.4s;
    position: relative;

    &:hover {
        border-inline: var(--primary-500) solid 2px;
        border-block-end: var(--primary-500) solid 2px;
    }

    &.active {
        background-color: lightcyan;
    }
}

    .card .card-header {
        /*    display: flex;
    
    gap: 1rem;
    justify-content: space-between;
    position: relative;
    align-items: flex-start;*/
        padding: 0.5rem;
        display: grid;
        gap: 1.5rem;
        grid-template-columns: max-content 1fr;
        grid-template-rows: 1fr;
        align-content: center;
        border-block-end: solid 1px var(--gray-100);
        /*    justify-content: start;*/
        /*    align-content: center;*/
    }
        /*    .card .card-header:after {
        content:'';
        height: 2px;
        position: relative;
        left: 10px;
        right: 10px;
        background-color: red;
    }
*/

        .card .card-header > h2 {
            padding-block-end: 0.2rem;
            /*        width: max-content;  */
        }



.pill {
    background-color: var(--primary-50);
    padding: 6px 20px;
    font-size: var(--text-sm);
    border-radius: var(--radius-xl);
    color: var(--primary-500);
    font-weight: 700;
    /*    white-space: nowrap;*/
    height: min-content;
    width: fit-content;
    margin-inline-start: auto;
}

.card .card-body {
    grid-area: body;
    display: grid;
    grid-template-columns: 1fr;
    padding-inline: 1rem;
    /*    justify-items: center;*/
    justify-content: left;
    /* grid-template-rows: span / 2;*/
}

.card .card-footer {
    grid-area: footer;
    margin-top: 0.2rem;
    text-align: left;
    background-color: var(--gray-100);
    color: var(--gray-600);
    font-size: var(--text-sm);
    padding: 0.5rem 0.35rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: default;
}

/*div.list:has(.radio-group).fieldset{
    width: 100%;
    display: grid;
    grid-template-columns: repeat(4,1fr);
    grid-template-rows: repeat(2,1fr);

}*/

div.list .radio-group {
    min-width: fit-content;
    max-width: 300px;
}


/*span.material-symbols-outlined.medium-icon {
    font-size: 3em;
}


span.material-symbols-outlined.large-icon {
    font-size: 6em;
}*/


/* app.css */

/* Style the dialog itself */
.blazor-modal {
    border: 1px solid #ccc;
    border-radius: 8px 0;
    padding: 0;
    width: 500px;
    max-width: 500px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    height: 100vh;
    display: grid;
    grid-template-rows: auto 1fr auto;
    margin: 0;
    /* 2. Set margin-left to 'auto' to push it right */
    margin-left: auto;
}

.blazor-confirm-modal {
    border: 1px solid #ccc;
    padding: 0;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    border-radius: 8px 8px;
    margin: auto;
    width: auto;
    max-width: 680px;
    display: block;
    transform: translateY(8px) scale(0.995);
    opacity: 0;
    animation: modalIn 200ms ease forwards;
}

    .blazor-confirm-modal::backdrop {
        background: rgba(0, 0, 0, 0.2);
        backdrop-filter: blur(2px);
    }
/* Style the modal backdrop when using showModal() */

/* Style the modal backdrop when using showModal() */
.blazor-modal::backdrop {
    background: rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(2px);
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    border-bottom: 1px solid #eee;
}

.modal-title {
    margin: 0;
    font-size: 1.25rem;
}

.close-button {
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    line-height: 1;
}

.modal-body {
    padding: 1rem;
}

.modal-footer {
    display: flex;
    justify-content: flex-end;
    padding: 1rem;
    gap: 0.5rem;
    border-top: 1px solid #eee;
}


body:has(dialog[open]) {
    overflow: hidden;
}


.panel-single-row {
    max-width: 500px;
    min-width: 200px;
    /*    width: max-content;*/
}
/*
    .panel-single-row:has(.radio-group) fieldset {
        grid-template-columns: 1fr;
    }
*/

.informational-panel {
    background-color: lightgray;
    border: solid 2px var(--secondary-accent-color);
    border-radius: 5px;
    padding: 1rem;
    max-width: 750px;
    margin: 2rem;
}

    .informational-panel h2 {
        margin-block: 0.5rem;
    }

    .informational-panel h3 {
        margin-block: 0.35rem;
    }

    .informational-panel p {
        margin-block: 0.35rem;
    }

    .informational-panel ul {
        margin-left: 1rem;
        margin-block-end: 0.5rem;
    }


        .informational-panel ul li {
            list-style: none;
            padding-inline-start: 1rem;
        }


            .informational-panel ul li::marker {
                content: '✓';
            }

.logout-link {
    background: none;
    border: none;
    padding: 0;
    margin: 0;
    color: black;
    cursor: pointer;
    text-decoration: none;
    outline: none;
}

.identity-validation-error {
    color: #e51680;
}

.identity-div-login {
    text-align: center;
    width: 50%;
    margin: auto;
}

.identity-mb10 {
    margin-bottom: 10px;
}

.unit-input-group {
    display: inline-flex;
    border: 1px solid #ced4da;
    border-radius: .25rem;
    overflow: hidden;
    width: 300px;
}

    .unit-input-group .unit-select {
        flex-shrink: 0;
        width: auto;
        border: none;
        border-left: 1px solid #ced4da;
        padding: 0.375rem 0.75rem;
        background-color: #e9ecef;
        cursor: pointer;
        font-size: 1rem;
        line-height: 1.5;
        outline: none;
    }

    .unit-input-group input[type="number"] {
        flex-grow: 1;
        border: none;
        padding: 0.375rem 0.75rem;
        font-size: 1rem;
        line-height: 1.5;
        outline: none;
    }

.unit-input-group-select {
    display: inline-block;
    font-size: 1rem;
    line-height: 1.5;
    outline: none;
    width: fit-content;
}

.unit-input-group input[type="number"]:focus {
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

.btn-update-value {
    padding: 0 .5rem;
    margin-block: 0;
}

.tbl-update-value-months, .tbl-update-value-months td {
    border: 1px solid black;
}

.tbl-update-value-months-header {
    font-weight: bold;
    background-color: darkgray;
}



a .nav-link, button.logout-link {
    color: black;
}


.nav-item {
    color: black;
}


h1 img {
    height: 48px;
    object-fit: contain;
}

.container.split-panel {
    display: flex;
    max-width: 100%;
    width: 100%;
    height: 100%;
    padding: 0;

    @media (width < 550px) {
        /*        background-color:var(--gray-300);*/
    }
}

.split-panel-image {
    position: relative;
    height: 100%;
    flex: 1.2;
    background-color: var(--primary-600);
    /*    background: linear-gradient(90deg, rgba(28, 89, 46, 1) 0%,rgba(255, 249, 91, 1) 100%);*/
    background-image: url('./images/panel-image.png');
    /*    , linear-gradient(90deg, rgba(28, 89, 46, 1) 0%,rgba(255, 249, 91, 1) 100%);*/
    background-size: contain;
    background-repeat: no-repeat;
    background-position: bottom;
    /*    padding: var(--space-12);*/
    color: #ffffff; /* Always white over image */
    overflow: clip;
    /*    z-index: -2;*/
}


/*.split-panel-image:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to top, oklch(15% 0.03 265 / 0.95), oklch(15% 0.03 265 / 0.1));
    z-index: 1;
}*/

.split-panel-form {
    flex: 1; /* Expands element in line with the image side */
    display: grid;
    grid-template-rows: 1fr auto;
    padding: var(--space-12);
    /*    grid-area: form;*/
    min-width: 200px;
    align-content: center;
}




.split-panel-image-content {
    padding: var(--space-3);
    height: 100%;
    margin-block-start: auto;
}

.split-panel-form form {
    padding: 0;
    place-content: center;
    /*    display:grid;
    grid-template-rows: 1fr auto 1.2fr;*/
}



.login-wrapper {
    width: 100%;
    min-width: 250px;
    max-width: 450px;
    place-self: center;
    transform: translateY(-5%);
    /*    margin-inline:auto;*/
}

.icon-input {
    position: relative;
}

    .icon-input input,
    .icon-input input:-webkit-autofill,
    .icon-input input:-webkit-autofill:hover,
    .icon-input input:-webkit-autofill:focus,
    .icon-input input:-webkit-autofill:active {
        /* 1. Override the text color */
        padding-inline-start: 2.2rem;
        -webkit-text-fill-color: var(--text-tertiary) !important;
        /* 2. (Optional) Force the font to match your site if Chrome changes it */
        font-family: inherit !important;
        font-size: inherit !important;
        /* 3. Keep the background color consistent (likely needed if text is white) */
        transition: background-color 5000s ease-in-out 0s;
    }

    .icon-input span {
        /*    background-color: var(--gray-200);*/
        position: absolute;
        /*    color: var(--gray-300);
    padding:0;
    padding-right: 0.2rem;
    margin-block: auto*/
        left: var(--space-1);
        top: 50%;
        transform: translateY(-50%);
        color: var(--text-tertiary);
        pointer-events: none;
        /*    background-color: white;*/
        /*    border: 5px orange solid;*/
        display: flex;
        align-content: center;
    }

    .icon-input > svg {
        position: absolute;
        left: var(--space-2);
        top: 50%;
        transform: translateY(-50%);
        color: var(--text-tertiary);
        pointer-events: none;
        display: flex;
        align-content: center;
        z-index: 1;
    }

label [type="checkbox"] {
    width: auto;
}

label:has([type="checkbox"]) {
    display: flex;
    align-items: center;
    justify-content: start;
    justify-items: start;
    gap: 0.6rem;
}

.radio-button {
    display: grid;
    gap: 0.5rem;
    grid-template-rows: 1fr;
    grid-template-columns: 1fr auto;
    outline: solid 1px var(--primary-500);
    border-radius: var(--radius-sm);
    align-content: center;
    align-items: center;
    position: relative;
}



    .radio-button input[type="radio"] {
        outline: none;
        margin-inline-end: 0.85rem;
    }


    .radio-button.selected {
        background-color: var(--primary-100);
    }

    .radio-button label {
        padding: 0.85rem;
    }

        .radio-button label:after {
            content: '';
            position: absolute;
            inset: 0;
        }


img.logo-m {
    max-width: 70%;
    object-fit: contain;
    margin-block-end: 1rem;
}


.centered {
    text-align: center;
}

.left-aligned {
    text-align: start;
}

.right-aligned {
    text-align: end;
}

.width-full {
    width: 100%;
    margin-inline: 0;
}

.btn-primary.width-full:hover {
    transform: unset;
}

.text-secondary {
    color: var(--text-secondary);
}

btn-primary.width-full:hover {
    transform: none;
}

.tag-container {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    position: absolute;
    bottom: 30px;
    left: 15px;
    right: 15px;
    justify-content: flex-start;
}

.tag {
    background-color: var(--primary-500);
    padding: 0.6em 1.5em;
    border: 1px solid white;
    border-radius: var(--radius-xl);
    width: fit-content;
    margin: 0.25rem;
    font-size: var(--text-xs);
    box-shadow: var(--shadow-xl)
}

@media (max-width: 900px) {
    .split-panel-image {
        display: none;
    }

    .form-side {
        background-color: var(--bg-app);
    }

    .login-wrapper {
        background: var(--bg-surface);
        padding: var(--space-8);
        border-radius: var(--radius-xl);
        box-shadow: var(--shadow-lg);
        border: 1px solid var(--border-subtle);
    }
}

@media (max-width: 540px) {

    body {
        grid-template-columns: 72px 1fr;
    }



    .split-panel-form {
        padding: 0.5rem;
    }

    .login-wrapper {
        box-shadow: none;
        padding: 0;
        background: transparent;
        border: none;
    }

    .logo-area {
        justify-content: center;
    }

    .header-text {
        text-align: center;
    }
}

.parent-grid {
    display: grid;
    grid-template-columns: auto 2rem;
    grid-template-rows: min-content;
    align-items: stretch;
    gap: 0.5rem;
}

    .parent-grid .radio-button {
        grid-column: 1/-1;
        grid-template-columns: subgrid;
        grid-template-rows: subgrid;
    }

h1.strapline {
    font-weight: 800;
    margin-inline: auto;
    text-align: center;
    margin-block: 1rem;
}

.split-panel-image-content p {
    max-width: 70ch;
    text-align: center;
    margin-inline: auto;
    letter-spacing: 0.5px;
}


.fa-icon-button {
    cursor: pointer;
    transition: all 0.5s;
}

    .fa-icon-button:hover {
        cursor: pointer;
    }



.fa-icon {
    width: 1.25rem;
    height: 1.25rem;
    fill: var(--primary-500);
}

.fa-icon-gray {
    fill: var(--gray-500);
}

.fa-icon-white {
    fill: white;
}

.fa-icon-red {
    fill: red;
}


.fa-icon.lg {
    width: 2.25rem;
    height: 2.25rem;
}

.fa-icon-sm {
    width: 0.75rem;
    height: 0.75rem;
}



h2.prominent-text {
    color: var(--text-secondary);
    font-weight: 800;
    letter-spacing: 0.5px;
    font-size: var(--text-2xl);
    margin-block-end: 0.25rem;
}

h3.prominent-text {
    color: var(--primary-600);
    font-weight: 700;
    letter-spacing: 0.5px;
    font-size: var(--text-3xl);
}

.supporting-text {
    color: var(--gray-300);
    font-size: var(--text-md);
    font-weight: 600;
    margin-block-start: var(--space-1);
    margin-block-end: var(--space-3);
}

.icon-with-label {
    display: flex;
    padding: 0.25rem 0;
    gap: 0.5rem;
}

button.icon-button {
    appearance: none;
    display: flex;
    gap: 1rem;
    border: unset;
    outline: unset;
    background-color: unset;
}


.flex-column {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 1rem;
}


img.profile-avatar {
    --avatar-size: 3rem; /* clamp(2rem, calc(1.25rem + 25vw), 5rem);*/
    width: var(--avatar-size);
    height: var(--avatar-size);
    aspect-ratio: 1/1;
    object-fit: fill;
    border-radius: 5px;
    /*        margin-inline-end: 1rem;*/
    align-self: center;
}

    img.profile-avatar.small {
        --avatar-size: 2rem; /* clamp(2rem, calc(1.25rem + 25vw), 5rem);*/
    }

    img.profile-avatar.medium {
        --avatar-size: 2.5rem; /* clamp(2rem, calc(1.25rem + 25vw), 5rem);*/
    }

.user-profile-container {
    display: flex;
    gap: 1rem;
    margin-block: 0.5rem;
    padding: 0.2rem;
}

.password-display-wrapper {
    /*    display:flex;*/
}

    .password-display-wrapper input {
        padding-inline-end: 3rem;
    }

    .password-display-wrapper svg {
        position: absolute;
        right: var(--space-4);
        top: 50%;
        transform: translateY(-50%);
        fill: var(--text-secondary);
        pointer-events: all;
    }


.bg-secondary-surface {
    background-color: var(--bg-surface-alt);
}


div.layout-container {
    width: 100%;
    height: 100%;
    background-color: var(--bg-surface-alt);
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr auto 1.5fr;
    place-items: center;
    place-content: start;
}


a:has(svg) {
    display: flex;
    gap: 0.5rem;
    align-items: start;

    & span {
        font-size: 1.25rem;
        vertical-align: middle;
    }

    & svg {
        height: 1.5rem;
        width: 1.5rem;
    }
}

.information-panel {
    display: grid;
    grid-template-areas: "icon header"
        "x body";
    grid-template-rows: auto auto;
    gap: 1rem;
    background-color: white;
}

    .information-panel .panel-icon {
        grid-area: icon;
        grid-row: 1/-1;
        align-items: center;
    }

    .information-panel .panel-header {
        grid-area: header;
        align-content: center;
        align-items: center;
        font-size: 1.75rem;
        font-weight: 600;
        margin-block-end: 0;
    }

        .information-panel .panel-header h2 {
            margin-block-end: 0;
        }


    .information-panel .panel-body {
        grid-area: body;
        grid-column: 2;
    }

    .information-panel p {
        margin-block-end: 0.95rem;
        line-height: 1.3rem;
    }


.dual-container {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr auto;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
}

passkey-submit {
    display: none;
}


.breadcrumb {
    margin: 2rem;
    place-self: start;
}

.fa-error {
    fill: red;
}

.fa-valid {
    fill: green;
}

ul.password-validation-rules-panel {
    display: grid;
    grid-template-columns: repeat(2,1fr);
    margin-block: 0.5rem;
}

li.password-validation-rule {
    display: flex;
    gap: 0.5rem;
    list-style: none;
    align-content: center;
    padding: 0.25rem;
    font-size: 0.8rem;
}

    li.password-validation-rule.invalid-rule .fa-icon {
        fill: red;
    }

main.main:has(.form-container) {
    background-color: azure;
    height: 100%;
    display: grid;
    grid-template-columns: 1fr max-content 1fr;
    grid-template-rows: 1fr auto 2fr;
    justify-content: center;
}

div.form-container {
    grid-row: 2;
    grid-column: 2;
    height: fit-content;
    width: max-content;
    background-color: white;
    padding: 1rem;
    box-shadow: var(--shadow-xl)
}


.form-container.account-form-wide {
    width: clamp(300px, 15rem+ 60vw, 90%);
}

    .form-container.account-form-wide p {
        /*    min-width: 30ch;
    max-width: 70ch;*/
        width: clamp(290px, 1rem + 30vw,70ch);
        margin-block-end: 0.65rem;
    }

        .form-container.account-form-wide p:last-of-type {
            margin-block-end: 0;
        }


a.button {
    display: inline-block;
    outline: var(--primary-500) solid 2px;
    padding: 0.5rem 1.25rem;
    text-align: center;
    border-radius: var(--radius-sm);
}

input[type="email"] {
    /*    width: 35ch;*/
}


div.account-form {
    min-width: 300px;
    max-width: 375px;
}


.flex-flow {
    display: flex;
    gap: 1rem;
}

    .flex-flow button {
        margin-block: 0;
    }



.framed-image {
    width: 10rem;
    height: 8rem;
    box-shadow: var(--shadow-md);
    background-color: var(--primary-50);
    border: 3px solid var(--primary-500);
    border-radius: var(--radius-md);
    place-items: center;
    display: grid;
}

    .framed-image svg {
        /*    font-size: 3rem;*/
        width: 3rem;
        height: 3rem;
    }

.profile-section.card {
    padding: 1rem;
}

.card-body {
    width: 100%;
}

.profile-section .card.profile-card .card-body {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
    padding: 1rem;
}

.loan-purpose-card {
    display: grid;
    grid-template-areas: "header" "body" "footer";
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
    border: solid 1px var(--gray-50);
    box-shadow: var(--shadow-sm);
    border-radius: 5px;
    border-block-start: 3px solid var(--primary-500);
    margin-top: 10px;
    margin-left: 10px;
    text-align: center;
    padding: 10px;
    background-color: #f0f2f5;

    &:hover {
        border-inline: var(--primary-500) solid 2px;
        border-block-end: var(--primary-500) solid 2px;
        cursor: pointer;
        transform: scale(1.01);
    }

    &.active {
        border-inline: var(--primary-500) solid 2px;
        border-block-end: var(--primary-500) solid 2px;
        cursor: pointer;
        transform: scale(1.01);
    }
}

.loan-purpose-card-image-wrapper {
    position: relative;
    width: 100%;
    min-height: 200px;
    overflow: hidden;
}

    .loan-purpose-card-image-wrapper::before {
        content: "";
        position: absolute;
        inset: 0;
        background-image: var(--bg);
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
        filter: blur(16px);
        transform: scale(1.1);
    }

    .loan-purpose-card-image-wrapper img {
        position: relative;
        z-index: 1;
        max-width: 200px;
        height: auto;
        display: block;
        margin: auto;
    }

.loan-purpose-card-desc h3 {
    margin-bottom: 10px;
    margin-top: 10px;
}

.loan-purpose-card-desc ul {
    margin-left: 10px;
    text-align: justify;
}

.loan-purpose-card-desc li {
    margin-bottom: 10px;
}

.loan-purpose-card-grid-view {
    --min-col-size: 350px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(var(--min-col-size),100%),1fr));
    gap: var(--space-5);
    margin-block: var(--space-8);
    width: 98%;
    margin-left: auto;
    margin-right: auto;
}


.form-container.account-form-wide {
    width: clamp(300px, 15rem+ 60vw, 90%);
}

    .form-container.account-form-wide p {
        /*    min-width: 30ch;
    max-width: 70ch;*/
        width: clamp(290px, 1rem + 30vw,70ch);
        margin-block-end: 0.65rem;
    }

        .form-container.account-form-wide p:last-of-type {
            margin-block-end: 0;
        }


a.button {
    display: inline-block;
    outline: var(--primary-500) solid 2px;
    padding: 0.5rem 1.25rem;
    text-align: center;
    border-radius: var(--radius-sm);
}

.loan-purpose-card-btn-container {
    display: flex;
    gap: 10px;
    justify-content: center;
}

.loan-purpose-card-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0;
    padding: 0.4rem 0.6rem;
}



div.account-form {
    min-width: 300px;
    max-width: 375px;
}


.flex-flow {
    display: flex;
    gap: 1rem;
}

.framed-image {
    width: 10rem;
    height: 8rem;
    box-shadow: var(--shadow-md);
    background-color: var(--primary-50);
    border: 3px solid var(--primary-500);
    border-radius: var(--radius-md);
    place-items: center;
    display: grid;
}

    .framed-image svg {
        /*    font-size: 3rem;*/
        width: 3rem;
        height: 3rem;
    }

.profile-section.card {
    padding: 1rem;
}

.card-body {
    width: 100%;
}


.loan-purpose-card-image-wrapper {
    position: relative;
    width: 100%;
    min-height: 200px;
    overflow: hidden;
}

    .loan-purpose-card-image-wrapper::before {
        content: "";
        position: absolute;
        inset: 0;
        background-image: var(--bg);
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
        filter: blur(16px);
        transform: scale(1.1);
    }

    .loan-purpose-card-image-wrapper img {
        position: relative;
        z-index: 1;
        max-width: 200px;
        height: auto;
        display: block;
        margin: auto;
    }

.loan-purpose-card-desc h3 {
    margin-bottom: 10px;
    margin-top: 10px;
}

.loan-purpose-card-desc ul {
    margin-left: 10px;
    text-align: justify;
}

.loan-purpose-card-desc li {
    margin-bottom: 10px;
}

.loan-purpose-card-grid-view {
    --min-col-size: 300px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(var(--min-col-size),100%),1fr));
    gap: var(--space-5);
    margin-block: var(--space-8);
}


.form-container.account-form-wide {
    width: clamp(300px, 15rem+ 60vw, 90%);
}

    .form-container.account-form-wide p {
        /*    min-width: 30ch;
    max-width: 70ch;*/
        width: clamp(290px, 1rem + 30vw,70ch);
        margin-block-end: 0.65rem;
    }

        .form-container.account-form-wide p:last-of-type {
            margin-block-end: 0;
        }


a.button {
    display: inline-block;
    outline: var(--primary-500) solid 2px;
    padding: 0.5rem 1.25rem;
    text-align: center;
    border-radius: var(--radius-sm);
}

.loan-purpose-card-btn-container {
    display: flex;
    gap: 10px;
    justify-content: center;
}

.loan-purpose-card-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0;
    padding: 0.4rem 0.6rem;
}

.file-drop-zone {
    position: relative;
    width: 100%;
    min-height: 200px;
    padding: 20px;
    border: 2px dashed #cbd5e1; /* Soft gray border */
    border-radius: 12px;
    background-color: #f8fafc;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

/* Make the actual input invisible but clickable */
.file-input {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    cursor: pointer;
    z-index: 2;
}

.file-label {
    display: flex;
    flex-direction: column;
    color: #64748b;
    pointer-events: none; /* Let clicks pass through to the input */
}

/* Visual feedback when dragging over */
.file-drop-zone:hover, .file-drop-zone:focus-within {
    border-color: #3b82f6; /* Blue highlight */
    background-color: #eff6ff;
}


.passkey-list-item {
    text-decoration: none;
    list-style: none;
    padding-inline: 1rem;
    padding-block: 0.5rem;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}


.orange {
    background-color: orange;
    color: white;
}

.red {
    background-color: red;
    color: white;
}


.icon-with-multi-row-text {
    min-width: 98%;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--space-3);
    margin-block-end: var(--space-2);
}


.multi-row-text {
    align-content: center;
    align-items: center;

    & p {
        margin-block: var(--space-1);
    }

        & p:last-of-type {
            margin-block-end: 0;
        }
}

.icon-placeholder {
    width: 2.5rem;
    height: 2.5rem;
    display: grid;
    place-items: center;
    place-self: center;
    background-color: var(--gray-50);
    border-radius: 50%;
}


.loan-summary-grid {
    display: grid;
    width: 100%;
    border: 1px solid var(--gray-300);
    grid-template-columns: repeat(3,1fr);
    grid-template-rows: auto 1fr;
    text-align: center;
    margin-block-end: var(--space-3);

    & p {
        padding: var(--space-2);
        border: 1px solid var(--gray-300);
    }
}

    .loan-summary-grid .row-header {
        display: inline-block;
        background-color: var(--gray-50);
        color: var(--gray-600);
    }


a.nav-link {
    text-decoration: none;
}


a:has(.card) * {
    text-decoration: none;
    color: unset;
}

.card > * {
    text-decoration: none;
}



.question-row {
    width: 100%;
    padding: 0.75rem 0.75rem;
    display: flex;
    align-items: center;
    justify-content: space-between;


    & select {
        padding: 0.3rem 0.5rem;
        width: auto;

        &:focus-visible, :focus {
            outline: solid 2px var(--primary-500);
        }
    }
}

textarea {
    margin-inline: auto;
    width: 100%;
    field-sizing: content;
    min-height: 3lh;
    padding: 12px;
    border: 1px solid var(--primary-500);
    border-radius: 8px;
    font: inherit; /* Matches the rest of your site */
    box-sizing: border-box; /* Ensures padding doesn't add to width */
    resize: none;
    scrollbar-gutter: stable;

    &:focus-within {
        outline: none;
        border-color: var(--primary-500);
        box-shadow: 0 0 0 2px var(--primary-500);
        transition: min-height 0.2s border-color 0.2s, box-shadow 0.2s;
    }
}



.stretched-link::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1; /* Makes the link cover the whole card area */
}


.contact-card-compact {
    display: flex;
    flex-direction: column;
    margin-block: 0.5rem;
    padding: 0.45rem;
    outline: 2px solid var(--primary-500);
    background-color: var(--gray-50);
    border-radius: var(--radius-md);

    & h3 {
        margin-block-start: 0.25rem;
        color: var(--primary-700);
    }
}

    .contact-card-compact:has(button) {
        display: grid;
        grid-template-columns: 1fr auto;
        grid-template-rows: auto;

        & button {
            background-color: transparent;
            border: unset;
            outline: unset;
            margin: 0;
            height: auto;
            border-inline-start: 1px solid gray;
            border-radius: unset;
            place-content: safe center;
        }
    }


.compact-contact-card-header {
    color: var(--primary-600);
    font-weight: 600;
    margin-block-end: 0.35rem;
}

.contact-card-compact-detail {
    align-content: space-between;
    gap: 0.15rem;

    & p.supporting-text {
        font-size: 0.8rem;
        margin-block: 0;
    }
}


.action-button {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0;
    padding: var(--space-2) var(--space-4) var(--space-2) var(--space-3);
    color: white;

    & svg {
        fill: var( --primary-text-accent);
    }

    & :has(svg) .animating {
        fill: var( --primary-500);
    }
}
/*  LTButton  */
.busy-icon {
    vertical-align: middle;
}

.spin {
    animation: spin 1s linear infinite;
}


/* MultiActionButton styles */
/*button:has(span.dropdown-toggle) {
    padding: 0;

    & span {padding: 0.5rem;}
}

span.dropdown-toggle {
    background-color: var(--primary-700);*/
/*    padding-inline: 0.5rem;*/
/*}


.button-dropdown {
    background-color: white;
    border: 2px solid var(--primary-800);
    width: max-content;
    position:relative;
   
}

.button-dropdown div {
    background-color: white;
    border: 1px solid var(--primary-800);
    padding: 0.3rem 0.7rem;
    width: 100%;
    z-index:999;
    position:absolute;
}


.dropdown-list {
    position: absolute;
    width: max-content;
    right: 0;
    list-style: none;
    padding: 0;
    margin-top: 2px;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    background-color: #fff;
    z-index: 1000;
    max-height: 200px;
    overflow-y: auto;
    padding: 1rem;*/
/*    visibility:hidden;*/
/*}*/

.header-content-placeholder {
    position: relative;
    background-color: transparent;
    margin-inline-end: 2rem;
    margin-inline-start: auto;
    place-self: end;
    transform: translateY(50%);
}



.custom-select-container.form-control.w-10 {
    width: 15ch;
}


body:has([popover]:popover-open) {
    overflow: hidden;
}

html {
    /* Prevents content jumping by reserving scrollbar space */
    scrollbar-gutter: stable;
}


.CalcsResultValueUpdated {
    font-weight: bold;
    color: red;
}

.CalcsResultTitleUpdated {
    font-weight: bold;
    color: red;
}

.CalcsResultTitleValue {
    padding-bottom: 5px
}



button.link-button {
    border: unset;
    outline: unset;
    background-color: transparent;
    color: var(--primary-500);
    text-decoration: underline;
    margin-block: 0;
    padding: var(--space-1);

    &:hover {
        background-color: transparent;
        color: var(--primary-700);
        cursor: pointer;
    }
}


section {
    margin-block: var(--space-4);
}



p.sub-title {
    font-size: var(--text-lg);
    font-weight: bolder;
    color: var(--primary-900);
}


.text-color-red {
    color: red;
    font-size: var(--text-sm);
    font-style: italic;
}

.alert {
    outline: solid 1px red;
    padding: 0.75rem;
    color: var(--color-error);
    background-color: var(--color-error-faded);
    border-radius: var(--radius-sm);
    font-size: var(--text-xs);
    box-shadow: var(--shadow-lg);
    margin-block: 1rem;
    width: fit-content;
}

    .alert.alert-error {
        --shadow-tint: var(--color-error-faded);
        color: var(--color-error);
        background-color: var(--color-error-faded);
    }

    .alert.alert-success {
        --shadow-tint: var(--color-success-faded);
        outline: solid 1px var(--color-success);
        padding: 0.75rem;
        color: var(--color-sucess);
        background-color: var(--color-success-faded);
    }


.key-value-grid-view {
    --min-col-size: 49%;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(var(--min-col-size),100%),1fr));
    gap: var(--space-5);
    margin-block: var(--space-8);
    width: 98%;
    margin-left: auto;
    margin-right: auto;
}

.key-value-grid-item {
    display: inline-table;
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
}


.selected {
    border: 2px solid var(--primary-500);
}


.page-wrapper {
    background-color: beige;
}


h1.strapline {
    font-weight: 900;
    font-size: 2.85rem;
    text-align: start;
    margin-inline-start: 0;
}

p:has(.strapline) {
    width: 50%;
}

p.strapline-alt {
    max-width: 60%;
    font-weight: 600;
    font-size: 2rem;
    text-align: start;
    color: var(--gray-700);
    margin-inline: 0;
    margin-block-end: 4vh;
}


p.strapline {
    max-width: 50%;
    font-weight: 500;
    font-size: 1.25rem;
    text-align: start;
    /*    text-align: justify;*/
    color: white;
    margin-inline: 0;
    ;
}

.nested-template {
    margin-top: 0px;
    margin-bottom: 0px;
}

.header img.branding {
    padding-block-end: 0;
}

div.footer-icon-panel {
    display: flex;
    gap: 0.25rem;
    align-items: safe center;
}


button.delete-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    border: 2px solid yellow;
    gap: 0.5rem;
}

    button.delete-placeholder svg {
        font-size: 5rem;
        width: 2rem;
        height: 2rem;
        background-color: transparent;
        cursor: pointer;
    }

/* Used for Virtualized List of introducers*/

div.grid-list {
    border: 4px red solid;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
    grid-template-areas: "header" "items";
    height: 80vh;
    overflow: hidden;
}

.grid-list.header {
    border: 4px blue solid;
    grid-areaL header;
}

.grid-list-content {
    flex-grow: 1; /* Fills the grid cell */
    overflow-y: auto; /* Enables scrolling here */
}


/* Users grid from Team page */

div.team-grid {
    --min-col-width: 350px;
    display: grid;
    /* Adjust 250px to your desired minimum column width */
    grid-template-columns: repeat(auto-fill, minmax(var(--min-col-width), 1fr));
    gap: var(--space-8);
    padding: 0.25rem;
    margin-block: 1rem;
}


.grid-meeting {
    margin-block: 1rem;
    width: 100%;
    border: 0.5px solid var(--primary-500);
    display: grid;
    /* Defining 4 columns: 2 for each inner div */
    grid-template-columns: max-content 1fr;
    box-sizing: border-box;
}

.grid-meeting-row {
    display: grid;
    grid-template-columns: subgrid;
    /*    padding: var(--space-3);*/
    border-bottom: 1px solid var(--primary-300);
    grid-column: span 2;
    /* 3. Enable subgrid to use the parent's tracks */
    display: grid;
    grid-template-columns: subgrid;
    box-sizing: border-box;
}

.header-column {
    font-weight: 600;
    margin-inline-end: 4rem;
    border-inline-end: 1px solid var(--primary-300);
    /*    padding: 10px;*/
    /*    outline: 1px solid var(--primary-500);*/
    /*outline-offset: 12px;*/ */ /* Pulls the outline inside the padding */
}


.container.panel-centered:has(.registration-panel) {
    width: 650px;

    @media (width <= 800px) {
        width: 600px;
        border: 4px solid red;
    }

    @media (width <= 500px) {
        width: 100%;
        border: 4px solid red;
    }
}

fieldset
{
    border:none;
}
.registration-panel {
    width: 100%;
}


/*Validation summary css */
.validation-summary {
    margin-block: 1rem;

    & h4 {
        color: var(--color-error);
        font-weight: 400;
    }

    p.non-model-error {
        margin: 0.5rem 0.35rem;
    }
    /*    p.non-model-error::before {
        content: 'X'
    }*/


    & button.link-button, p.non-model-error {
        color: var(--color-error);
        text-underline-offset: 0.25rem;
        font-size: 0.9rem;
        font-weight: 400;
    }
}


.warning-wrapper-icon_text {
    display: flex;
    gap: var(--space-2);
    padding: var(--space-2);
    align-items: center;
    flex-shrink: 0;

    & svg {
        fill: var(--color-error);
    }
}


div.button-group {
    display: flex;
}




div.button-group {
    display: flex;
}



.grid-table {
    width: auto;
    display: grid;
    /*    gap:1rem;*/
    grid-template-columns: min-content max-content min-content;

    & div {
        border: 1px solid var(--primary-300);
        padding: 0.5rem 1rem;
    }

    & svg {
        --size: 1.2rem;
        height: var(--size);
        width: var(--size);
        font-size: 2rem;
    }
}

.grid-table.col-2 {

    grid-template-columns: 1fr auto;

}

    .grid-table.col-3 {
        grid-template-columns: 1fr auto auto;
    }

body:not(:has(.sidebar):has(.footer)) {
    grid-template-areas: "header " "main";
    grid-template-columns: 1fr;
    gap: 0;

    & main {
        margin: 0;
        width: 100%;
/*        background-color: deeppink;*/

        
    }
}

.additional-fee-row {

    display:flex;
    gap: var(--space-2);
    align-items: safe center;


    & * {
        margin-block:0;
    }
}


.simple-notification-message {
    color: var(--primary-500);
    font-weight:500;
}


.fa-icon-sm.delete {

}


.breadcrumb-container {
    grid-column: 1/-1;
}

kbd {
    font-weight: 600;
    font-size: 1.05rem;
    margin-block: 0.75rem;
    text-align: center;
}

div.image-center {
    display:flex;
    justify-content: center;
    
    & img {
        margin-block:0.5rem;
    }
}


input.form-control:focus-within, button:focus-within {
    outline: 3px double var(--primary-800);
}

.button-group-container {
    display: flex;
    gap: 5px;
}

.button-group-container a {
    margin-top: auto;
    margin-bottom: auto
}