ui {
    position: absolute;
    /* inset: 0; */
    inset: 0 10px;
    pointer-events: none;
}

ui:has(dialog.active) :is(messager) {
    z-index: 1999;
}

ui:has(dialog.active) :is(modal) {
    pointer-events: none;
    opacity: 0;
}

ui modal:has(com.focus) .wrap {
    & .wrap-scroll {
        pointer-events: auto;
    }
    & .wrap-scroll .wrap-data {
        pointer-events: none;
    }
}

/* popup */

dialog {
    position: absolute;
    padding: 0;
    margin: 0;
    border-radius: 20px;
    z-index: 2002;
    display: flex;
    flex-direction: column;
    inset-inline: auto;
    min-width: 160px;
    max-width: min-content;
    align-items: center;
    overflow: hidden;
    box-shadow: 0 0 40px #00000033;
    background: white;
    border: none;
    pointer-events: auto;
    transition: transform .2s cubic-bezier(0.25, 0.1, 0.2, 1.49), opacity .2s, visibility .2s;
    transform: scale(.88) translateY(-15px);
    visibility: hidden;
    opacity: 0;
    --gap: calc(var(--gapMin) / 2);
}

dialog.center {
    inset: 0px;
    position: fixed;
    margin: auto;
}

dialog img.preview {
    position: relative;
    max-height: 140px;
    width: calc(100% - var(--gap)* 2);
    object-fit: cover;
    border-radius: var(--radiusMin);
}

dialog img.preview.load-error {
    background-image: repeating-linear-gradient(45deg, white 0, white 5px, #f3f3f3 5px, #f3f3f3 15px);
    max-height: 50px;
}

/* dialog.center img.preview {
    width: auto;
} */

dialog .message {
    /* text-align: center; */
    color: black;
    display: flex;
    flex-direction: column;
    gap: var(--gap);
    line-height: 1;
    /* padding: var(--gap); */
    padding: var(--padding-top) var(--padding-inline) var(--gap);
    --padding-top: calc(var(--gap) + 2px);
    --padding-inline: calc(var(--gap) + 5px);
}

dialog .message .title {
    font-weight: 700;
    font-size: 1.15em;
}

dialog .message .description {
    font-size: .85em;
}

dialog .buttons {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    /* gap: var(--gap); */
    gap: var(--gapMicro);
    box-sizing: border-box;
    padding: var(--gap);
    width: 100%;
}

/* dialog:has( */
    /* .message:has(.title:empty):has(.description:empty) */ /*! не работает */
/*     .title:empty
) .buttons {
    &:has(button:nth-child(3)) {
        flex-wrap: nowrap;
    }
    &:not(:has(button:nth-child(3))) button {
        justify-content: flex-start;
        padding-inline: 12px;
    }
} */

dialog:has(.title:empty) {
    min-width: auto;
}

dialog:has(.title:empty):has(button:nth-child(3)) {
    border-radius: 20px 12px 12px 20px;
}

dialog:has(.title:empty) .buttons {
    padding: var(--gapMicro);

    &:has(button:nth-child(6)) {
        width: auto;
        max-height: 30vh;
        overflow-y: scroll;
        padding: 0 var(--gapMicro) 0 0;
        scroll-snap-type: y mandatory;
        margin: var(--gapMicro);
    }
    & button {
        justify-content: flex-start;
        /* padding-inline: 12px; */
        scroll-snap-align: end;
    }
}

dialog .buttons button {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--gapMicro);
    width: 100%;
    /* transition: transform .2s cubic-bezier(0.25, 0.1, 0.2, 1.49);
    transition-delay: .08s;
    transform: scale(.9); */
    background: var(--bg-color);
    color: var(--text-color);
    --bg-color: var(--blue);
    --text-color: white;
}

dialog .buttons button * {
    pointer-events: none;
}

dialog .buttons button .ico {
    width: 18px;
    min-width: 18px;
    height: 18px;
    background-color: var(--text-color);
    mask-image: var(--ico-url);
    mask-size: contain;
    -webkit-mask-image: var(--ico-url);
    -webkit-mask-size: contain;
}

/* dialog .buttons button:nth-child(2) {
    transition-delay: .12s;
}

dialog .buttons button:nth-child(3) {
    transition-delay: .16s;
}

dialog .buttons button:nth-child(4) {
    transition-delay: .20s;
}

dialog .buttons button:nth-child(5) {
    transition-delay: .24s;
}

dialog .buttons button:nth-child(6) {
    transition-delay: .28s;
} */

dialog .message :is(.title, .description):empty,
dialog .message:has(.title:empty):has(.description:empty),
dialog img.preview[src=''],
dialog .buttons:empty {
    display: none;
}

dialog.active {
    transition: 
        transform .2s cubic-bezier(0.25, 0.1, 0.2, 1.49), 
        opacity .2s, 
        visibility 0s;
}

dialog.active,
dialog.active .buttons button {
    visibility: visible;
    transform: none;
    opacity: 1;
}

dialog:has(:not(.title, .description, img)) .buttons {
    text-wrap: nowrap;
}

dialog.auto-wide {
    min-width: auto;
}

/* popup */



/* messager */

messager {
    position: fixed;
    left: var(--gapMin);
    bottom: var(--gapMin);
    z-index: 2003;
    max-width: 360px;
    pointer-events: auto;
}

messager .wrap {
    display: flex;
    flex-direction: column;
}

messager:not(:hover) .wrap:has(.message:nth-child(10)) .message:not(:first-child, :last-child, .out) {
    margin: -8px 0;
}

messager:not(:hover) .wrap:has(.message:nth-child(10)) .message:not(.out):first-child {
    margin: 3px 0 14px;
}

messager .wrap .message:first-child {
    margin-top: 0;
}

messager .wrap .message:last-child {
    margin-bottom: 0;
}

messager .wrap .message {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--gapMicro);
    padding: var(--gapMin);
    font-weight: 300;
    border-radius: var(--radius);
    background: var(--bg-color);
    color: var(--text-color);
    width: fit-content;
    cursor: pointer;
    --bg-color: black;
    --text-color: white;
    transition: 
        transform .4s cubic-bezier(0, 0.02, 0, 1.22),
        opacity .3s,
        margin .3s,
        box-shadow .3s;
    animation: appearance .4s cubic-bezier(0, 0.02, 0, 1.22);
    overflow: hidden;
    margin: 3px 0;
    box-sizing: border-box;
    z-index: 1;
}

messager .wrap .message.keep:before {
    content: "";
    position: absolute;
    inset: 9px 0 0 9px;
    background-color: var(--text-color);
    width: 5px;
    height: 5px;
    border-radius: 10px;
}

messager .wrap .message.out {
    transform: translateY(10px);
    opacity: 0;
    margin: var(--margin) 0;
}

@keyframes appearance {
    0% {
        opacity: 0;
        transform: translateY(-100px) scale(.9) rotateX(5deg); 
    }
    100% {
        opacity: 1;
        transform: perspective(100px);
    }
}

messager .wrap .message .title {
    display: flex;
    gap: var(--gapMicro);
    align-items: flex-start;
}

messager .wrap .message .title .ico {
    width: 18px;
    min-width: 18px;
    height: 18px;
    background-color: var(--text-color);
    mask-image: var(--ico-url);
    mask-size: contain;
    -webkit-mask-image: var(--ico-url);
    -webkit-mask-size: contain;
}

messager .wrap .message .title .ico:not([style]) {
    display: none;
}

messager .wrap .message .title .text {
    font-size: 1.1em;
    width: fit-content;
    line-height: 1;
}

messager .wrap .message .description {
    width: fit-content;
    font-size: .9em;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: var(--lines);
    overflow: hidden;
    --lines: 4;
}

/* messager .wrap .message .description ~ .description {
    margin-top: -5px;
} */

/* @supports not (mask-image: var(--ico-url)) {
    messager .wrap .message .title .ico {
        display: none;
    }
} */

@media (max-width: 1200px) and (max-height: 770px) {
    messager .wrap .message {
        padding: calc(var(--gapMin) / 2);
        gap: calc(var(--gapMicro) / 2);
        font-size: 75%;
        border-radius: 12px;
    }
}

/* messager .wrap .message:is(:hover, .hover) .description {
    --lines: initial;
} */

/* messager .wrap .message.keep {
    order: 1;
} */

/* messager */



/* modal */

modal {
    display: flex;
    position: absolute;
    inset: var(--gapMin) auto auto var(--gapMin);
    cursor: auto;
    width: fit-content;
    max-width: var(--max-size);
    min-width: 33vw;
    max-height: 60vh;
    margin: auto;

    transform: translateY(30px) scale(.9) rotateX(5deg);
    transition: opacity .15s, visibility .15s, transform .3s cubic-bezier(0, 0.02, 0, 1.22);
    opacity: 0;
    visibility: hidden;
    
    pointer-events: auto;
    z-index: 2001;
    isolation: isolate;
    
    --max-size: min(calc(var(--max-width) / 1.1), calc(100% - var(--gapMax)));

    &[data-left-side="true"] {
        right: auto;
    }

    &[data-left-side="false"]:before {
        left: auto;
        right: var(--arrow-margin);
    }

    &.stick {
        margin: 0;
    }

    &.open {
        transform: perspective(600px);
        opacity: 1;
        visibility: visible;
    }

    &.fullscreen {
        position: fixed;
        inset: var(--gapMin) !important;
        max-width: 100%;
        max-height: 100vh;
        width: auto;
        transition: .15s;

        &:not(.scroll-off) > .wrap .wrap-scroll {
            max-height: 100vh;
        }

        & > .wrap {
            width: 100% !important;
            height: 100% !important;
            resize: none;
        }
    }

    & > .wrap {
        position: relative;
        display: grid;
        width: 100%;
        /* grid-template-rows: .01fr auto; */
        grid-template-rows: .01fr minmax(0, 1fr);
        border-radius: var(--radiusMin);
        background: white;
        box-shadow: 0 0 40px #00000033;
        overflow: hidden;
        resize: both;
        contain: layout paint;
    }

    & .control {
        display: flex;
        gap: var(--gapMicro);
        flex-wrap: nowrap;
        width: 100%;
        padding: 8px 8px 10px var(--gapMin);
        box-sizing: border-box;
        background: var(--lightGray);
        border-radius: var(--radiusMin) var(--radiusMin) 0 0;
        justify-content: flex-end;
        border-bottom: 1px solid var(--borderGray);
        align-items: center;

        & .title {
            line-height: 1;
            margin-right: auto;
            color: var(--gray);
            font-weight: 100;
            display: block;
            display: -webkit-box;
            -webkit-box-orient: vertical;
            -webkit-line-clamp: var(--lines);
            text-wrap: nowrap;
            /* overflow: hidden; */
            text-overflow: ellipsis;
            pointer-events: none;
            --lines: 1;
        }

        & .btn {

            display: flex;
            width: 16px;
            cursor: pointer;
            user-select: none;
            z-index: 2;
    
            &:active {
                transition: .05s;
                transform: translateY(1.5px) scale(0.96);
            }
        
            & img {
                width: 100%;
                pointer-events: none;
            }
        }
    }

    &:not(.scroll-off) > .wrap .wrap-scroll {
        display: flex;
        flex-direction: column;
        gap: var(--gapMin);
        flex-wrap: nowrap;
        overflow-y: scroll;
        margin: 6px 6px 6px auto;
        padding: var(--gapMicro) var(--gapMin);
        padding: 0 var(--gapMicro) var(--gapMicro) 0;
        box-sizing: border-box;
        max-height: 80vh;
        width: calc(100% - var(--gapMicro));
    }

    &:not(.with-popup) .open-in {
        display: none;
    }

    & .wrap-scroll > .wrap-data {
        display: flex;
        flex-direction: column;
        padding-inline: var(--gapMin);
        padding-block: var(--gapMin);
        gap: var(--between-gap);
        --between-gap: var(--gapMiddle);

        & .block {
            display: flex;
            flex-wrap: wrap;
            padding-block-end: var(--between-gap);
            gap: var(--gapData);
            align-items: inherit;
            border-bottom: 1px solid var(--borderGray);
        
            /* view-transition-name: block; */
        
            transition-duration: .3s;
            transition-property: transform, opacity, display;
            transition-behavior: allow-discrete;

            &:not([hidden]) {
                opacity: 1;
                transform: none;
                
                @starting-style {
                    opacity: 0;
                    transform: translateY(-35px);
                }
            }

            &[hidden] {
                display: none;
                opacity: 0;
                transform: translateY(-35px);
            }

            &:nth-last-child(1 of .block:not([hidden])) {
                border-bottom: none;
            }

            /* &:first-child {
                margin-block-start: var(--gap);
            } */

            & data {
                width: 100%;
            }
        }
    }
}

html:has(modal.fullscreen) {
    overflow: hidden;
}

modal.fullscreen {
    & com[name=table] > .wrap-com > .wrap-main {
        max-width: initial;

        & > .wrap {
            max-height: initial;
        }
    }
}

/* modal */



/* progress */

pro {
    position: fixed;
    width: 30px;
    height: 5px;
    margin: 10px auto auto 15px;
    pointer-events: none;
    user-select: none;
    background-color: var(--lightGray);
    border-radius: var(--radiusMin);
    overflow: hidden;
    z-index: 3000;
    transition: opacity .15s;
    opacity: 0;
    --value: 0;
}

pro.active {
    opacity: 1;
}

pro.success:before {
    background-color: var(--green);
}

pro.fail:before {
    background-color: var(--red);
}

pro:before {
    content: "";
    position: absolute;
    inset: 0 0 0 0;
    background-color: var(--blue);
    transition: transform .1s;
    transform-origin: left center;
    transform: scaleX(calc(var(--value) / 100));
}

/* progress */



/* blackout */

blackout {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    background: black;

    &:not(.transparent) {
        transition: .15s;

        &.active {
            opacity: .2;
            transition: .25s;
        }
    }

    &.active {
        visibility: visible;
        pointer-events: all;
    }
}

/* blackout */



/* scroller */

ui scroller {

    --height: 10px;

    position: fixed;
    inset: auto var(--gapMin) 2px;
    margin: auto;
    max-width: var(--max-width);
    height: calc(var(--height) + 1px);
    overflow: scroll hidden;
    pointer-events: all;
    z-index: 10;
    /* scroll-behavior: smooth; */
    transition: .25s;
    transform: translateY(calc(var(--height) + 5px));

    &::-webkit-scrollbar {
        height: var(--height);
        background: transparent;
    }

    &::-webkit-scrollbar-thumb {
        height: var(--height);
        background-color: rgba(0, 0, 0, 0.7);
        border-radius: var(--radius);
    }

    &::-webkit-scrollbar-thumb:hover {
        background-color: black;
    }
}

html:has(com.fullscreen) ui scroller {
    display: none;
}

/* scroller */



/* modal table */

modal.scroll-off > .wrap .wrap-scroll {
    margin: var(--gapMicro) var(--gapMicro) calc(var(--gapMicro) + 5px);
    width: calc(100% -(var(--gapMicro)* 2));

    &:has(app[name=filter]) {
        display: grid;
        grid-template-rows: .01fr minmax(0, 1fr);
        gap: var(--gapMicro);
    }
}

modal com[name=table] {

    --td-padding: 4px;
    height: 100%;
    width: 100%;

    & .btn.resize {
        display: none;
    }

    & :is(.wrap-com, .wrap-main) {
        height: 100%;
        width: 100%;
        max-width: none;
    }

    & .wrap-main > .wrap {
        max-height: initial;
        height: 100%;
        overscroll-behavior: contain;
    }

    & table {
        width: 100%;
    }

    & thead tr:not(.groups) th:last-child::before {
        display: none;
    }

    & tbody tr {
        cursor: pointer;

        &.exist {
            pointer-events: none;

            & .is-data {
                opacity: .4;
            }
        }
    }
}

/* modal table */