.vti__flag{width:20px}.vti__flag.be{width:18px}.vti__flag.ch{width:15px}.vti__flag.mc{width:19px}.vti__flag.ne{width:18px}.vti__flag.np{width:13px}.vti__flag.va{width:15px}@media only screen and (-webkit-min-device-pixel-ratio: 2),only screen and (min--moz-device-pixel-ratio: 2),only screen and (-o-min-device-pixel-ratio: 2),only screen and (min-device-pixel-ratio: 2),only screen and (min-resolution: 192dpi),only screen and (min-resolution: 2dppx){.vti__flag{background-size:5630px 15px}}.vti__flag.ac{height:10px;background-position:0px 0px}.vti__flag.ad{height:14px;background-position:-22px 0px}.vti__flag.ae{height:10px;background-position:-44px 0px}.vti__flag.af{height:14px;background-position:-66px 0px}.vti__flag.ag{height:14px;background-position:-88px 0px}.vti__flag.ai{height:10px;background-position:-110px 0px}.vti__flag.al{height:15px;background-position:-132px 0px}.vti__flag.am{height:10px;background-position:-154px 0px}.vti__flag.ao{height:14px;background-position:-176px 0px}.vti__flag.aq{height:14px;background-position:-198px 0px}.vti__flag.ar{height:13px;background-position:-220px 0px}.vti__flag.as{height:10px;background-position:-242px 0px}.vti__flag.at{height:14px;background-position:-264px 0px}.vti__flag.au{height:10px;background-position:-286px 0px}.vti__flag.aw{height:14px;background-position:-308px 0px}.vti__flag.ax{height:13px;background-position:-330px 0px}.vti__flag.az{height:10px;background-position:-352px 0px}.vti__flag.ba{height:10px;background-position:-374px 0px}.vti__flag.bb{height:14px;background-position:-396px 0px}.vti__flag.bd{height:12px;background-position:-418px 0px}.vti__flag.be{height:15px;background-position:-440px 0px}.vti__flag.bf{height:14px;background-position:-460px 0px}.vti__flag.bg{height:12px;background-position:-482px 0px}.vti__flag.bh{height:12px;background-position:-504px 0px}.vti__flag.bi{height:12px;background-position:-526px 0px}.vti__flag.bj{height:14px;background-position:-548px 0px}.vti__flag.bl{height:14px;background-position:-570px 0px}.vti__flag.bm{height:10px;background-position:-592px 0px}.vti__flag.bn{height:10px;background-position:-614px 0px}.vti__flag.bo{height:14px;background-position:-636px 0px}.vti__flag.bq{height:14px;background-position:-658px 0px}.vti__flag.br{height:14px;background-position:-680px 0px}.vti__flag.bs{height:10px;background-position:-702px 0px}.vti__flag.bt{height:14px;background-position:-724px 0px}.vti__flag.bv{height:15px;background-position:-746px 0px}.vti__flag.bw{height:14px;background-position:-768px 0px}.vti__flag.by{height:10px;background-position:-790px 0px}.vti__flag.bz{height:14px;background-position:-812px 0px}.vti__flag.ca{height:10px;background-position:-834px 0px}.vti__flag.cc{height:10px;background-position:-856px 0px}.vti__flag.cd{height:15px;background-position:-878px 0px}.vti__flag.cf{height:14px;background-position:-900px 0px}.vti__flag.cg{height:14px;background-position:-922px 0px}.vti__flag.ch{height:15px;background-position:-944px 0px}.vti__flag.ci{height:14px;background-position:-961px 0px}.vti__flag.ck{height:10px;background-position:-983px 0px}.vti__flag.cl{height:14px;background-position:-1005px 0px}.vti__flag.cm{height:14px;background-position:-1027px 0px}.vti__flag.cn{height:14px;background-position:-1049px 0px}.vti__flag.co{height:14px;background-position:-1071px 0px}.vti__flag.cp{height:14px;background-position:-1093px 0px}.vti__flag.cr{height:12px;background-position:-1115px 0px}.vti__flag.cu{height:10px;background-position:-1137px 0px}.vti__flag.cv{height:12px;background-position:-1159px 0px}.vti__flag.cw{height:14px;background-position:-1181px 0px}.vti__flag.cx{height:10px;background-position:-1203px 0px}.vti__flag.cy{height:14px;background-position:-1225px 0px}.vti__flag.cz{height:14px;background-position:-1247px 0px}.vti__flag.de{height:12px;background-position:-1269px 0px}.vti__flag.dg{height:10px;background-position:-1291px 0px}.vti__flag.dj{height:14px;background-position:-1313px 0px}.vti__flag.dk{height:15px;background-position:-1335px 0px}.vti__flag.dm{height:10px;background-position:-1357px 0px}.vti__flag.do{height:13px;background-position:-1379px 0px}.vti__flag.dz{height:14px;background-position:-1401px 0px}.vti__flag.ea{height:14px;background-position:-1423px 0px}.vti__flag.ec{height:14px;background-position:-1445px 0px}.vti__flag.ee{height:13px;background-position:-1467px 0px}.vti__flag.eg{height:14px;background-position:-1489px 0px}.vti__flag.eh{height:10px;background-position:-1511px 0px}.vti__flag.er{height:10px;background-position:-1533px 0px}.vti__flag.es{height:14px;background-position:-1555px 0px}.vti__flag.et{height:10px;background-position:-1577px 0px}.vti__flag.eu{height:14px;background-position:-1599px 0px}.vti__flag.fi{height:12px;background-position:-1621px 0px}.vti__flag.fj{height:10px;background-position:-1643px 0px}.vti__flag.fk{height:10px;background-position:-1665px 0px}.vti__flag.fm{height:11px;background-position:-1687px 0px}.vti__flag.fo{height:15px;background-position:-1709px 0px}.vti__flag.fr{height:14px;background-position:-1731px 0px}.vti__flag.ga{height:15px;background-position:-1753px 0px}.vti__flag.gb{height:10px;background-position:-1775px 0px}.vti__flag.gd{height:12px;background-position:-1797px 0px}.vti__flag.ge{height:14px;background-position:-1819px 0px}.vti__flag.gf{height:14px;background-position:-1841px 0px}.vti__flag.gg{height:14px;background-position:-1863px 0px}.vti__flag.gh{height:14px;background-position:-1885px 0px}.vti__flag.gi{height:10px;background-position:-1907px 0px}.vti__flag.gl{height:14px;background-position:-1929px 0px}.vti__flag.gm{height:14px;background-position:-1951px 0px}.vti__flag.gn{height:14px;background-position:-1973px 0px}.vti__flag.gp{height:14px;background-position:-1995px 0px}.vti__flag.gq{height:14px;background-position:-2017px 0px}.vti__flag.gr{height:14px;background-position:-2039px 0px}.vti__flag.gs{height:10px;background-position:-2061px 0px}.vti__flag.gt{height:13px;background-position:-2083px 0px}.vti__flag.gu{height:11px;background-position:-2105px 0px}.vti__flag.gw{height:10px;background-position:-2127px 0px}.vti__flag.gy{height:12px;background-position:-2149px 0px}.vti__flag.hk{height:14px;background-position:-2171px 0px}.vti__flag.hm{height:10px;background-position:-2193px 0px}.vti__flag.hn{height:10px;background-position:-2215px 0px}.vti__flag.hr{height:10px;background-position:-2237px 0px}.vti__flag.ht{height:12px;background-position:-2259px 0px}.vti__flag.hu{height:10px;background-position:-2281px 0px}.vti__flag.ic{height:14px;background-position:-2303px 0px}.vti__flag.id{height:14px;background-position:-2325px 0px}.vti__flag.ie{height:10px;background-position:-2347px 0px}.vti__flag.il{height:15px;background-position:-2369px 0px}.vti__flag.im{height:10px;background-position:-2391px 0px}.vti__flag.in{height:14px;background-position:-2413px 0px}.vti__flag.io{height:10px;background-position:-2435px 0px}.vti__flag.iq{height:14px;background-position:-2457px 0px}.vti__flag.ir{height:12px;background-position:-2479px 0px}.vti__flag.is{height:15px;background-position:-2501px 0px}.vti__flag.it{height:14px;background-position:-2523px 0px}.vti__flag.je{height:12px;background-position:-2545px 0px}.vti__flag.jm{height:10px;background-position:-2567px 0px}.vti__flag.jo{height:10px;background-position:-2589px 0px}.vti__flag.jp{height:14px;background-position:-2611px 0px}.vti__flag.ke{height:14px;background-position:-2633px 0px}.vti__flag.kg{height:12px;background-position:-2655px 0px}.vti__flag.kh{height:13px;background-position:-2677px 0px}.vti__flag.ki{height:10px;background-position:-2699px 0px}.vti__flag.km{height:12px;background-position:-2721px 0px}.vti__flag.kn{height:14px;background-position:-2743px 0px}.vti__flag.kp{height:10px;background-position:-2765px 0px}.vti__flag.kr{height:14px;background-position:-2787px 0px}.vti__flag.kw{height:10px;background-position:-2809px 0px}.vti__flag.ky{height:10px;background-position:-2831px 0px}.vti__flag.kz{height:10px;background-position:-2853px 0px}.vti__flag.la{height:14px;background-position:-2875px 0px}.vti__flag.lb{height:14px;background-position:-2897px 0px}.vti__flag.lc{height:10px;background-position:-2919px 0px}.vti__flag.li{height:12px;background-position:-2941px 0px}.vti__flag.lk{height:10px;background-position:-2963px 0px}.vti__flag.lr{height:11px;background-position:-2985px 0px}.vti__flag.ls{height:14px;background-position:-3007px 0px}.vti__flag.lt{height:12px;background-position:-3029px 0px}.vti__flag.lu{height:12px;background-position:-3051px 0px}.vti__flag.lv{height:10px;background-position:-3073px 0px}.vti__flag.ly{height:10px;background-position:-3095px 0px}.vti__flag.ma{height:14px;background-position:-3117px 0px}.vti__flag.mc{height:15px;background-position:-3139px 0px}.vti__flag.md{height:10px;background-position:-3160px 0px}.vti__flag.me{height:10px;background-position:-3182px 0px}.vti__flag.mf{height:14px;background-position:-3204px 0px}.vti__flag.mg{height:14px;background-position:-3226px 0px}.vti__flag.mh{height:11px;background-position:-3248px 0px}.vti__flag.mk{height:10px;background-position:-3270px 0px}.vti__flag.ml{height:14px;background-position:-3292px 0px}.vti__flag.mm{height:14px;background-position:-3314px 0px}.vti__flag.mn{height:10px;background-position:-3336px 0px}.vti__flag.mo{height:14px;background-position:-3358px 0px}.vti__flag.mp{height:10px;background-position:-3380px 0px}.vti__flag.mq{height:14px;background-position:-3402px 0px}.vti__flag.mr{height:14px;background-position:-3424px 0px}.vti__flag.ms{height:10px;background-position:-3446px 0px}.vti__flag.mt{height:14px;background-position:-3468px 0px}.vti__flag.mu{height:14px;background-position:-3490px 0px}.vti__flag.mv{height:14px;background-position:-3512px 0px}.vti__flag.mw{height:14px;background-position:-3534px 0px}.vti__flag.mx{height:12px;background-position:-3556px 0px}.vti__flag.my{height:10px;background-position:-3578px 0px}.vti__flag.mz{height:14px;background-position:-3600px 0px}.vti__flag.na{height:14px;background-position:-3622px 0px}.vti__flag.nc{height:10px;background-position:-3644px 0px}.vti__flag.ne{height:15px;background-position:-3666px 0px}.vti__flag.nf{height:10px;background-position:-3686px 0px}.vti__flag.ng{height:10px;background-position:-3708px 0px}.vti__flag.ni{height:12px;background-position:-3730px 0px}.vti__flag.nl{height:14px;background-position:-3752px 0px}.vti__flag.no{height:15px;background-position:-3774px 0px}.vti__flag.np{height:15px;background-position:-3796px 0px}.vti__flag.nr{height:10px;background-position:-3811px 0px}.vti__flag.nu{height:10px;background-position:-3833px 0px}.vti__flag.nz{height:10px;background-position:-3855px 0px}.vti__flag.om{height:10px;background-position:-3877px 0px}.vti__flag.pa{height:14px;background-position:-3899px 0px}.vti__flag.pe{height:14px;background-position:-3921px 0px}.vti__flag.pf{height:14px;background-position:-3943px 0px}.vti__flag.pg{height:15px;background-position:-3965px 0px}.vti__flag.ph{height:10px;background-position:-3987px 0px}.vti__flag.pk{height:14px;background-position:-4009px 0px}.vti__flag.pl{height:13px;background-position:-4031px 0px}.vti__flag.pm{height:14px;background-position:-4053px 0px}.vti__flag.pn{height:10px;background-position:-4075px 0px}.vti__flag.pr{height:14px;background-position:-4097px 0px}.vti__flag.ps{height:10px;background-position:-4119px 0px}.vti__flag.pt{height:14px;background-position:-4141px 0px}.vti__flag.pw{height:13px;background-position:-4163px 0px}.vti__flag.py{height:11px;background-position:-4185px 0px}.vti__flag.qa{height:8px;background-position:-4207px 0px}.vti__flag.re{height:14px;background-position:-4229px 0px}.vti__flag.ro{height:14px;background-position:-4251px 0px}.vti__flag.rs{height:14px;background-position:-4273px 0px}.vti__flag.ru{height:14px;background-position:-4295px 0px}.vti__flag.rw{height:14px;background-position:-4317px 0px}.vti__flag.sa{height:14px;background-position:-4339px 0px}.vti__flag.sb{height:10px;background-position:-4361px 0px}.vti__flag.sc{height:10px;background-position:-4383px 0px}.vti__flag.sd{height:10px;background-position:-4405px 0px}.vti__flag.se{height:13px;background-position:-4427px 0px}.vti__flag.sg{height:14px;background-position:-4449px 0px}.vti__flag.sh{height:10px;background-position:-4471px 0px}.vti__flag.si{height:10px;background-position:-4493px 0px}.vti__flag.sj{height:15px;background-position:-4515px 0px}.vti__flag.sk{height:14px;background-position:-4537px 0px}.vti__flag.sl{height:14px;background-position:-4559px 0px}.vti__flag.sm{height:15px;background-position:-4581px 0px}.vti__flag.sn{height:14px;background-position:-4603px 0px}.vti__flag.so{height:14px;background-position:-4625px 0px}.vti__flag.sr{height:14px;background-position:-4647px 0px}.vti__flag.ss{height:10px;background-position:-4669px 0px}.vti__flag.st{height:10px;background-position:-4691px 0px}.vti__flag.sv{height:12px;background-position:-4713px 0px}.vti__flag.sx{height:14px;background-position:-4735px 0px}.vti__flag.sy{height:14px;background-position:-4757px 0px}.vti__flag.sz{height:14px;background-position:-4779px 0px}.vti__flag.ta{height:10px;background-position:-4801px 0px}.vti__flag.tc{height:10px;background-position:-4823px 0px}.vti__flag.td{height:14px;background-position:-4845px 0px}.vti__flag.tf{height:14px;background-position:-4867px 0px}.vti__flag.tg{height:13px;background-position:-4889px 0px}.vti__flag.th{height:14px;background-position:-4911px 0px}.vti__flag.tj{height:10px;background-position:-4933px 0px}.vti__flag.tk{height:10px;background-position:-4955px 0px}.vti__flag.tl{height:10px;background-position:-4977px 0px}.vti__flag.tm{height:14px;background-position:-4999px 0px}.vti__flag.tn{height:14px;background-position:-5021px 0px}.vti__flag.to{height:10px;background-position:-5043px 0px}.vti__flag.tr{height:14px;background-position:-5065px 0px}.vti__flag.tt{height:12px;background-position:-5087px 0px}.vti__flag.tv{height:10px;background-position:-5109px 0px}.vti__flag.tw{height:14px;background-position:-5131px 0px}.vti__flag.tz{height:14px;background-position:-5153px 0px}.vti__flag.ua{height:14px;background-position:-5175px 0px}.vti__flag.ug{height:14px;background-position:-5197px 0px}.vti__flag.um{height:11px;background-position:-5219px 0px}.vti__flag.us{height:11px;background-position:-5241px 0px}.vti__flag.uy{height:14px;background-position:-5263px 0px}.vti__flag.uz{height:10px;background-position:-5285px 0px}.vti__flag.va{height:15px;background-position:-5307px 0px}.vti__flag.vc{height:14px;background-position:-5324px 0px}.vti__flag.ve{height:14px;background-position:-5346px 0px}.vti__flag.vg{height:10px;background-position:-5368px 0px}.vti__flag.vi{height:14px;background-position:-5390px 0px}.vti__flag.vn{height:14px;background-position:-5412px 0px}.vti__flag.vu{height:12px;background-position:-5434px 0px}.vti__flag.wf{height:14px;background-position:-5456px 0px}.vti__flag.ws{height:10px;background-position:-5478px 0px}.vti__flag.xk{height:15px;background-position:-5500px 0px}.vti__flag.ye{height:14px;background-position:-5522px 0px}.vti__flag.yt{height:14px;background-position:-5544px 0px}.vti__flag.za{height:14px;background-position:-5566px 0px}.vti__flag.zm{height:14px;background-position:-5588px 0px}.vti__flag.zw{height:10px;background-position:-5610px 0px}.vti__flag{width:20px;height:15px;box-shadow:0 0 1px #888;background-image:url();background-repeat:no-repeat;background-color:#dbdbdb;background-position:20px 0}@media only screen and (-webkit-min-device-pixel-ratio: 2),only screen and (min--moz-device-pixel-ratio: 2),only screen and (-o-min-device-pixel-ratio: 2),only screen and (min-device-pixel-ratio: 2),only screen and (min-resolution: 192dpi),only screen and (min-resolution: 2dppx){.vti__flag{background-image:url()}}.vti__flag.np{background-color:transparent}.vue-tel-input{border-radius:3px;display:flex;border:1px solid #bbb;text-align:left}.vue-tel-input.disabled .selection,.vue-tel-input.disabled .dropdown,.vue-tel-input.disabled input{cursor:no-drop}.vue-tel-input:focus-within{box-shadow:inset 0 1px 1px #00000013,0 0 8px #66afe999;border-color:#66afe9}.vti__dropdown{display:flex;flex-direction:column;align-content:center;justify-content:center;position:relative;padding:7px;cursor:pointer}.vti__dropdown.show{max-height:300px;overflow:scroll}.vti__dropdown.open{background-color:#f3f3f3}.vti__dropdown.disabled{cursor:no-drop;outline:none;background-color:#f3f3f3}.vti__dropdown:hover{background-color:#f3f3f3}.vti__selection{font-size:.8em;display:flex;align-items:center}.vti__selection .vti__country-code{color:#666}.vti__flag{margin-right:5px;margin-left:5px}.vti__dropdown-list{z-index:1;padding:0;margin:0;text-align:left;list-style:none;max-height:200px;overflow-y:scroll;position:absolute;left:-1px;background-color:#fff;border:1px solid #ccc;width:390px}.vti__dropdown-list.below{top:33px}.vti__dropdown-list.above{top:auto;bottom:100%}.vti__dropdown-arrow{transform:scaleY(.5);display:inline-block;color:#666}.vti__dropdown-item{cursor:pointer;padding:4px 15px}.vti__dropdown-item.highlighted{background-color:#f3f3f3}.vti__dropdown-item.last-preferred{border-bottom:1px solid #cacaca}.vti__dropdown-item .vti__flag{display:inline-block;margin-right:5px}.vti__input{border:none;border-radius:0 2px 2px 0;width:100%;outline:none;padding-left:7px}.vti__search_box{border:1px solid #ccc;width:94%;padding:7px;margin:2px}

@media all and (max-width: 780px) {
    .v2-layout .table-preferences {
        .table-preferences-save-button,
        .table-preferences-columns-button,
        .table-preferences-remove-all-button {
            display: none;
        }

        .table-preferences-view-list-item {
            flex-direction: row;
        }
    }
}

@media all and (max-width: 600px) {
    .v2-layout.login-page, .v2-layout.reset-password, .v2-layout.user-activation, .v2-layout.buyer-login {
        & .login-page-form-carrier {
            & .login-page-column {
                & .login-page-form {
                    width: 80vw;
                    .info-container {
                        display: none;
                    }
                }
            }
        }
    }
}
.v2-layout .table-preferences {
    --asvg-width: calc(var(--module) + var(--couple-atoms));
    .table-pref-fav-icon {
        color: var(--c-main-yellow);
        fill: none;

        &:hover,
        &.is-fav {
            fill: var(--c-main-yellow);
        }
    }

    .asvg.table-pref-bin-icon {
        opacity: .2;
        color: var(--c-context-error-delete);
        &:hover {
            opacity: 1;
        }
    }

    .table-preferences-columns {
        max-height: calc(var(--module) * 30);
        overflow: auto;
    }

    #views {
        width: fit-content;
    }
}
.lending-free-app-div.v2-layout {
    width: unset;
    height: unset;
    display: block;
    overflow-y: auto;
    text-align: left;
    padding: var(--content-padding);
}
.v2-layout {
    .label-x,
    .rich-text-box {
        &.disabled {
            --label-x-bg: var(--c-validation-disabled-bg);
        }
    
        &.readonly {
            --label-x-bg: var(--c-validation-readonly-bg);
        }
    
        &.error {
            --label-x-bg: var(--c-validation-error-bg);
        }
    
        &.mandatory {
            --label-x-bg: var(--c-validation-mandatory-bg);
        }
    
        &.success {
            --label-x-bg: var(--c-validation-success-bg);
        }
    }
    
    .file-upload {
        &.error {
            --c-file-upload-bg: var(--c-validation-error-bg);
        }
    }

    .button-group.error .button {
        &.hover-great:hover {
            --button-color: var(--c-context-positive-add);
            --button-text-color: var(--c-context-positive-add-text);
        }
        &.great {
            --button-color: var(--c-context-error-delete);
            --button-text-color: var(--c-context-error-delete-text);
        }
        &.inactive {
            --button-color: var(--c-validation-error-bg);
            --button-text-color: var(--c-sup-grey);
        }
    }
}
.v2-layout {

    --scrollbar-color: var(--c-context-active-element);
    --scrollbar-back: var(--c-context-content-background);

    ::-webkit-scrollbar {
        width: var(--module);
        height: var(--module);
    }

    ::-webkit-scrollbar-button {}

    ::-webkit-scrollbar-track {
        background-color: var(--scrollbar-back);
    }

    ::-webkit-scrollbar-thumb {
        background-color: var(--scrollbar-color);
        border: var(--atom) solid var(--scrollbar-back);
        -webkit-border-radius: var(--module);
    }

    ::-webkit-scrollbar-corner {}

    ::-webkit-resizer {}

    ::-webkit-scrollbar-button:vertical:start:decrement {
        background:
            linear-gradient(130deg, var(--scrollbar-back) 40%, rgba(255, 0, 0, 0) 41%),
            linear-gradient(230deg, var(--scrollbar-back) 40%, rgba(0, 0, 0, 0) 41%),
            linear-gradient(0deg, var(--scrollbar-back) 40%, rgba(0, 0, 0, 0) 31%);
        background-color: var(--scrollbar-color);
    }

    ::-webkit-scrollbar-button:vertical:end:increment {
        background:
            linear-gradient(310deg, var(--scrollbar-back) 40%, rgba(0, 0, 0, 0) 41%),
            linear-gradient(50deg, var(--scrollbar-back) 40%, rgba(0, 0, 0, 0) 41%),
            linear-gradient(180deg, var(--scrollbar-back) 40%, rgba(0, 0, 0, 0) 31%);
        background-color: var(--scrollbar-color);
    }

    ::-webkit-scrollbar-button:horizontal:end:increment {
        background:
            linear-gradient(210deg, var(--scrollbar-back) 40%, rgba(0, 0, 0, 0) 41%),
            linear-gradient(330deg, var(--scrollbar-back) 40%, rgba(0, 0, 0, 0) 41%),
            linear-gradient(90deg, var(--scrollbar-back) 30%, rgba(0, 0, 0, 0) 31%);
        background-color: var(--scrollbar-color);
    }

    ::-webkit-scrollbar-button:horizontal:start:decrement {
        background:
            linear-gradient(30deg, var(--scrollbar-back) 40%, rgba(0, 0, 0, 0) 41%),
            linear-gradient(150deg, var(--scrollbar-back) 40%, rgba(0, 0, 0, 0) 41%),
            linear-gradient(270deg, var(--scrollbar-back) 30%, rgba(0, 0, 0, 0) 31%);
        background-color: var(--scrollbar-color);
    }
}
.v2-layout {
    /* MODULE SYSTEM */
    
    --atom: 4px;
    --couple-atoms: calc(var(--atom) * 2);
    --module: calc(var(--atom) * 4);
    --two-modules: calc(var(--module) * 2);
    --three-modules: calc(var(--module) * 3);
    --four-modules: calc(var(--module) * 4);
    --five-modules: calc(var(--module) * 5);
    
    /* MAIN PALETTE */
    --c-white: white;

    --s-main: 60%;
    --s-main-bg: 65%;
    --l-main: 45%;
    --l-main-bg: 96%;

    --h-main-company: 196;
    --c-main-company: hsl(var(--h-main-company), var(--s-main), calc(var(--l-main)));
    --c-main-company-text: white;
    --c-main-company-bg: hsl(var(--h-main-company), var(--s-main-bg), var(--l-main-bg));

    --h-main-green: 107;
    --c-main-green: hsl(var(--h-main-green), var(--s-main), var(--l-main));
    --c-main-green-text: white;
    --c-main-green-bg: hsl(var(--h-main-green), var(--s-main-bg), var(--l-main-bg));

    --h-main-purple: 300;
    --c-main-purple: hsl(var(--h-main-purple), var(--s-main), var(--l-main));
    --c-main-purple-text: white;
    --c-main-purple-bg: hsl(var(--h-main-purple), var(--s-main-bg), var(--l-main-bg));

    --h-main-red: 352;
    --c-main-red: hsl(var(--h-main-red), var(--s-main), var(--l-main));
    --c-main-red-text: white;
    --c-main-red-bg: hsl(var(--h-main-red), var(--s-main-bg), var(--l-main-bg));

    --h-main-orange: 25;
    --c-main-orange: hsl(var(--h-main-orange), var(--s-main), var(--l-main));
    --c-main-orange-text: white;
    --c-main-orange-bg: hsl(var(--h-main-orange), var(--s-main-bg), var(--l-main-bg));

    --h-main-pink: 350;
    --c-main-pink: hsl(var(--h-main-pink), var(--s-main), var(--l-main));
    --c-main-pink-text: white;
    --c-main-pink-bg: hsl(var(--h-main-pink), var(--s-main-bg), var(--l-main-bg));

    --h-main-teal: 180;
    --c-main-teal: hsl(var(--h-main-teal), var(--s-main), var(--l-main));
    --c-main-teal-text: white;
    --c-main-teal-bg: hsl(var(--h-main-teal), var(--s-main-bg), var(--l-main-bg));

    --h-main-yellow: 52;
    --c-main-yellow: hsl(var(--h-main-yellow), 80%, var(--l-main));
    --c-main-yellow-text: white;
    --c-main-yellow-bg: hsl(var(--h-main-yellow), var(--s-main-bg), var(--l-main-bg));
    
    /* SUPPORT PALETTE */
    --c-sup-grey: #7C869B;
    --c-sup-grey-text: #1C1D21;
    --c-sup-orange: #FAD389;
    --c-sup-orange-text: white;
    --c-sup-pink: #F8B1FC;
    --c-sup-pink-text: white;
    --c-sup-purple: #CCAAEE;
    --c-sup-purple-text: white;
    
    --c-sup-purple-bg: #FEEFEF;

    --c-main-black: #1C1D21;
    --c-main-black-text: white;
    --c-main-black-bg: hsl(240, calc(var(--s-main-bg) - 30%), calc(var(--l-main-bg) - 4%));

    --c-main-grey: #F7F7F7;
    --c-main-grey-text: #1C1D21;
    --c-main-grey-bg: hsl(240, calc(var(--s-main-bg) - 15%), calc(var(--l-main-bg)));

    --c-main-blue: var(--c-main-company);
    --c-main-blue-text: var(--c-main-company-text);
    --c-main-blue-bg: var(--c-main-company-bg);
    
    /* CONTEXT COLORS */

    --c-context-background: var(--c-main-grey);
    --c-context-content-background: var(--c-white);
    --c-context-text-default: var(--c-main-black);
    --c-context-text-inactive: var(--c-sup-grey);
    --c-context-active-element: var(--c-main-teal);
    --c-context-active-element-text: var(--c-main-teal-text);
    --c-context-error-delete: var(--c-main-red);
    --c-context-error-delete-text: var(--c-main-red-text);
    --c-context-warning: var(--c-main-yellow);
    --c-context-warning-text: var(--c-main-yellow-text);
    --c-context-positive-add: var(--c-main-green);
    --c-context-positive-add-text: var(--c-main-green-text);
    
    /* VALIDATION SYSTEM */
    --c-validation-disabled-bg: var(--c-main-black-bg);
    --c-validation-readonly-bg: var(--c-main-grey-bg);
    --c-validation-error-bg: var(--c-main-red-bg);
    --c-validation-mandatory-bg: var(--c-main-yellow-bg);
    --c-validation-success-bg: var(--c-main-green-bg);
    
    /* INPUT SYSTEM */
    
    --input-vertical-padding: calc(var(--atom) * 3);
    --input-total-height: var(--three-modules);
    --input-actual-height: calc(var(--input-total-height) - var(--input-vertical-padding));
    
    --button-height: var(--input-actual-height);
    
    /* FONT SYSTEM */
    --text-line-height: var(--two-modules);
    --caption-line-height: var(--module);
    --fs-title-1: 36px;
    --fs-title-2: 30px;
    --fs-title-3: 22px;
    --fs-title-4: 18px;
    --fs-text-1: 16px;
    --fs-text-2: 15px;
    --fs-caption-1: 14px;
    --fs-caption-2: 11px;
    
    --font-title-1: 500 var(--fs-title-1)/var(--three-modules) "Inter", sans-serif;
    --font-title-2: 500 var(--fs-title-2)/var(--text-line-height) "Inter", sans-serif;
    --font-title-3: 300 var(--fs-title-3)/var(--text-line-height) "Inter", sans-serif;
    --font-title-4: 400 var(--fs-title-4)/var(--text-line-height) "Inter", sans-serif;
    --font-text-1: 300 var(--fs-text-1)/var(--text-line-height) "Inter", sans-serif;
    --font-text-2: 300 var(--fs-text-2)/var(--text-line-height) "Inter", sans-serif;
    --font-button: 400 var(--fs-text-1)/var(--button-height) "Inter", sans-serif;
    --font-caption-1: 300 var(--fs-caption-1)/var(--module) "Inter", sans-serif;
    --font-caption-2: 400 var(--fs-caption-2)/var(--module) "Inter", sans-serif;
    
    /* Three-mod content pattern - BASE */
    --important-pattern-v-padding: var(--couple-atoms);
    --important-pattern-h-padding: var(--content-padding);
    --important-pattern-padding: var(--important-pattern-v-padding) var(--important-pattern-h-padding);
    --f-important-pattern-text: var(--font-text-1);
    --important-pattern-line-height: var(--text-line-height);
    
    /* Global Variables */
    --content-padding: var(--module);
    --standard-curve: var(--atom);
    --standard-shadow: 0px var(--couple-atoms) var(--couple-atoms) hsla(var(--h-accent), var(--s-main), var(--l-main), 0.2);
    --standard-transition: all 0.12s ease-in-out;
    --f-content: var(--font-text-2);
    --f-op: var(--font-text-2);
    --op-row-height: var(--three-modules);
    --c-signature-pad-accent: var(--c-context-active-element);
    --dimmed-bg: hsla(var(--h-main-company), var(--s-main), var(--l-main), 0.4);
    
    --c-chart-system: var(--c-context-text-default);
    --c-chart-data: var(--c-main-company-teal);
    --c-chart-data2: var(--c-main-green);
    --c-chart-data3: var(--c-main-red);
    --c-chart-not-important: var(--c-context-background);
    --c-chart-default: var(--c-sup-grey);
    
    --merge-fields-element-width: 780px;
    --merge-fields-element-page-height: 1103px;
    --merge-fields-element-page-gap: 50px;
    --merge-fields-preview-text-color: var(--c-context-text-default);
    
    --section-curve: var(--standard-curve);
    
    --fs-pdf-docs-merge-fields: 13px; /* Discrepancy of font sizes when the elements are inside the svg as a foreign object - they seem bigger. */
    --fs-pdf-docs-preview: 14px;
    --fs-preview: var(--fs-pdf-docs-preview);

    --h-accent: var(--h-main-company);
    --c-accent: hsl(var(--h-accent), var(--s-main), var(--l-main));
    --c-accent-text: white;
}

.v2-layout {
    width: 100%;
    overflow-y: hidden;
    background-color: var(--c-context-background);
    padding: 0;
    display: flex;
    font: var(--f-content);
    color: var(--c-context-text-default);
    stroke: currentColor;
    fill: currentColor;

    --header-font: var(--f-important-pattern-text);
    --header-h-padding: var(--important-pattern-h-padding);
    --header-v-padding: var(--module);
    --header-padding: var(--header-v-padding) var(--header-h-padding);
    --header-line-height: var(--important-pattern-line-height);
    --header-popup-position: calc(var(--header-line-height) + var(--header-v-padding) - var(--content-padding)); /* header size - content padding to make it start from within */
    --page-height: calc(100vh - var(--header-v-padding) * 2 - var(--header-line-height));
    
    --navigation-width: calc(var(--module) * 16);

    --user-menu-text-color: var(--c-accent-text);

    ::selection {
        background-color: var(--c-main-company);
        color: var(--c-main-company-text);
    }

    .default-logo {
        --asvg-height: var(--three-modules);
        --asvg-width: 100%;
        color: var(--c-main-company);
    }

    .navigation-menu-icon {
        display: none;
        color: var(--c-context-active-element);
    }

    .navigation {
        min-height: var(--page-height);

        background-color: var(--c-accent);
        padding: var(--module) 0;
        display: flex;
        flex-direction: column;
        gap: var(--content-padding);
        text-align: center;
        
        &.xmas {
            //background-image: url(), url(), url();
            //animation: christmas-snow 20s linear infinite;
        }

        &.navigation-right {
            display: none;

            max-height: var(--page-height);
            overflow-y: auto;
            width: 100vw;
        }

        .navigation-logo {
            color: white;
        }
        
        .navigation-menu {
            --navigation-font: var(--f-important-pattern-text);
            --navigation-v-padding: var(--couple-atoms);
            --navigation-h-padding: var(--atom);
            --navigation-item-height: var(--three-modules);
            --navigation-menu-item-offset: 0px;
            --c-navigation-selected: white;
            --c-navigation-selected-text: var(--c-accent);
            
            display: flex;
            flex-direction: column;
            flex: 1;
            --asvg-width: call(var(--navigation-item-height) - var(--navigation-v-padding) * 2);

            .navigation-item-container {
                position: relative;
                font: var(--navigation-font);

                .navigation-item {
                    padding: var(--navigation-v-padding) var(--navigation-h-padding);
                    transition: all .2s;
                    display: flex;
                    flex-direction: column;
                    color: white;

                    .navigation-item-text {
                        line-height: var(--module);
                        flex: 1;
                    }

                    &:hover,
                    &.selected {
                        background-color: var(--c-navigation-selected);
                        color: var(--c-navigation-selected-text);
                        cursor: pointer;

                        .navigation-item-text {
                            text-decoration: underline;
                        }
                    }
                }

                &.centered .navigation-item {
                    justify-content: center;
                }

                .navigation-item-menu {
                    position: absolute;
                    top: 0;
                    left: calc(100% - var(--atom));
                    box-shadow: var(--standard-shadow);
                    border-radius: var(--standard-curve);
                    border-top-left-radius: 0;

                    z-index: 1;
                    width: max-content;
                    background-color: var(--c-context-content-background);
                    //color: var(--c-context-active-element);

                    visibility: hidden;
                    opacity: 0;
                    height: 0;

                    &.shown {
                        visibility: visible;
                        opacity: 1;
                        height: unset;
                    }

                    transition: all 0.2s;

                    .navigation-item-menu-item {

                        padding: var(--couple-atoms) var(--content-padding);
                        padding-left: calc(var(--content-padding) + var(--navigation-menu-item-offset));
                        text-align: left;
                        cursor: pointer;

                        &:first-child {
                            border-top-right-radius: var(--standard-curve);
                        }

                        &:last-child {
                            border-bottom-right-radius: var(--standard-curve);
                            border-bottom-left-radius: var(--standard-curve);
                        }

                        &:hover {
                            background-color: var(--c-context-active-element);
                            color: var(--c-context-content-background);
                        }
                    }
                }
            }

            &.expanded {

                max-height: var(--page-height);
                overflow-y: auto;
                .navigation-item-container {
                    .navigation-item {
                        flex-direction: row;
                        gap: var(--content-padding);
                        --navigation-h-padding: var(--content-padding);

                        .navigation-item-text {
                            line-height: var(--asvg-height);
                        }
                    }
                }
            }

            &.expanded,
            &.no-expand {
                .navigation-item-container {
                    .navigation-item-menu {
                        width: unset;
                        position: relative;
                        top: unset;
                        left: unset;
                    }
                }
            }

            &.expanded {
                --navigation-menu-item-offset: var(--three-modules);
                .navigation-item-container {
                    .navigation-item {
                        .navigation-item-text {
                            text-align: left;
                            border-bottom: 1px solid var(--c-context-active-element);
                        }
                    }
                }
            }

            &.no-expand {
                .navigation-item-container {

                    .navigation-item {
                        border-radius: 0;
                    }

                    .navigation-item-menu .navigation-item-menu-item {
                        text-align: center;
                    }
                }
            }
        }


    }
    
    .content {
        flex: 1;
        background-color: var(--c-context-background);
        width: 100%;
        height: 100vh;
        overflow: hidden;
        position: relative;
        .header {
            font: var(--header-font);
            padding: var(--header-padding);
            display: flex;
            gap: var(--content-padding);
            background-color: var(--c-context-content-background);

            position: relative; /*for loading indicator*/
    
            --header-pic-size: var(--header-line-height);
            .header-svg {
                --asvg-height: var(--header-pic-size);
                border-radius: 50%;
            }
            
            .header-pic {
                width: var(--header-pic-size);
                height: var(--header-pic-size);
                border-radius: 50%;
            }
            
            .header-breadcrumb {
                flex: 1;
                display: flex;
                
                .breadcrumb-divider {
                    --asvg-width: calc(var(--two-modules));
                    color: var(--c-main-yellow);
                }
                
                .breadcrumb-item,
                .breadcrumb-menu-top {
                    white-space: nowrap;
                    text-transform: uppercase;
                    border-radius: var(--standard-curve);
                }
                
                .breadcrumb-menu {
                    display: flex;
                    position: relative;
                    
                    .breadcrumb-menu-top {
                        display: flex;
                    }
                    
                    .breadcrumb-menu-icon {
                        margin-right: var(--couple-atoms);
                        --asvg-width: calc(var(--two-modules) - var(--atom)*2 );
                        color: var(--c-context-text-inactive);
                    }
                    
                    .breadcrumb-menu-items {
                        z-index: 10000; /* because of leaflet */
                        position: absolute;
                        top: var(--header-popup-position);
                        left: 0;
                        
                        background-color: var(--c-accent);
                        color: var(--c-accent-text);
                        padding: var(--content-padding);
                        border-radius: var(--standard-curve);
                        font: var(--font-caption-2);
                        white-space: nowrap;
                        
                        --bread-item-padding: var(--atom);
                        
                        display: flex;
                        
                        .breadcrumb-menu-column {
                            padding-left: calc(var(--content-padding) - var(--bread-item-padding));
                            padding-right: var(--content-padding);
                            border-left: 1px var(--c-main-grey) solid;
                            
                            &:first-child {
                                padding-left: 0;
                                border-left: none;
                            }
                            
                            &:last-child {
                                padding-right: 0;
                            }
                        }
                        
                        .bread-menu-title {
                            padding: var(--module) var(--bread-item-padding) 0;
                            color: var(--c-main-blue-text);
                            font: var(--font-caption-1);
                            
                            &:first-child {
                                padding-top: 0;
                            }
                        }
                        
                        .bread-menu-small {
                            padding: 0 var(--bread-item-padding);
                            border-radius: var(--standard-curve);
                            cursor: pointer;
                            font: var(--font-text-1);
                            
                            --bread-menu-small-size: var(--module);
                            
                            --asvg-width: var(--bread-menu-small-size);
                            --asvg-height: var(--bread-menu-small-size);
                            
                            display: flex;
                            gap: var(--atom);
                            
                            &:hover,
                            &.selected {
                                background-color: var(--c-sup-grey);
                            }
                            
                            .error-svg {
                                color: var(--c-context-error-delete);
                            }
                        }
                        
                        .bread-menu-large {
                            padding: calc(var(--atom) * 1) var(--bread-item-padding) calc(var(--atom) * 2);
                            margin-top: var(--atom);
                            /*padding: var(--module) var(--bread-item-padding);*/
                            border-radius: var(--standard-curve);
                            cursor: pointer;
                            
                            --bread-menu-large-size: var(--three-modules);
                            --asvg-width: var(--bread-menu-large-size);
                            --asvg-height: var(--bread-menu-large-size);
                            
                            display: flex;
                            gap: var(--bread-item-padding);
                            
                            .asvg {
                                padding-top:var(--atom);
                            }
                            
                            .bread-menu-large-texts {
                                display: flex;
                                flex-direction: column;
                                
                                .bread-menu-large-texts-primary {
                                    font: var(--font-text-1);
                                    /*line-height: var(--module);*/
                                }
                            }
                            
                            &:hover,
                            &.selected {
                                background-color: var(--c-context-active-element);
                            }
                        }
                    }
                }
            }
        }

        --page-padding: var(--content-padding);
        .page {
            padding: var(--page-padding);
            height: var(--page-height);
            max-height: var(--page-height);
            overflow-y: auto;

            &.hidden-page {
                visibility: hidden;
            }

            .table-source {

            }

            .card-source {
                display: none;
            }
        }
    }

    .user-menu {
        position: relative;
        cursor: pointer;
        display: flex;
        gap: var(--atom);

        .user-menu-text {
            white-space: nowrap;
        }

        .user-menu-popup {
            --curve: var(--standard-curve);
            position: absolute;
            z-index: 1000;
            right: calc(var(--header-h-padding) * -1 + var(--atom));
            top: var(--header-popup-position);
            width: var(--navigation-width);
            border-radius: var(--curve);
            box-shadow: var(--standard-shadow);


            --user-menu-container-padding: var(--content-padding) 0;

            .user-menu-top {
                background-color: var(--c-accent);
                color: var(--user-menu-text-color);

                padding: var(--user-menu-container-padding);
                border-top-left-radius: var(--curve);
                border-top-right-radius: var(--curve);

                text-align: center;

                --pic-size: var(--four-modules);
                .asvg {
                    --asvg-width: var(--pic-size);
                    --asvg-height: var(--pic-size);
                    margin: 0 auto;
                    border-radius: 50%;
                }

                .user-menu-pic {
                    width: var(--pic-size);
                    height: var(--pic-size);
                    margin: 0 auto;
                    border-radius: 50%;
                }

                .user-menu-position {
                    font: var(--font-caption-2);
                }
            }

            .user-menu-bottom {
                border-bottom-left-radius: var(--curve);
                border-bottom-right-radius: var(--curve);
                padding: var(--user-menu-container-padding);
                background-color: var(--c-context-content-background);
                display: flex;
                flex-direction: column;

                .day {
                    color: var(--c-main-yellow);
                }

                .night {
                    color: var(--c-main-blue);
                }

                .label-checkbox-input {
                    --c-chb-switch-unchecked: var(--c-main-yellow);
                    --c-chb-switch-checked: var(--c-main-blue);
                }
            }
        }
    }

    .with-click {
        color: var(--c-context-active-element);
        cursor: pointer;
    }

    .column {
        display: flex;
        flex-direction: column;
        gap: var(--content-padding);

        &.central-column {
            max-width: calc(100% - var(--content-padding) * 2);
        }

        &.long-column {
            height: 80vh;
        }

        &.success-column {
            background-color: var(--c-main-green-bg);
        }
    }

    .row {
        display: flex;
        gap: var(--content-padding);

        &.half-row {
            width: 50%;
        }

        &.centered-row {
            justify-content: center;
        }

        &.reversed-row {
            flex-direction: row-reverse;
        }

        &.empty-row {
            height: var(--input-total-height);
        }

        .opexcol-1 {
            flex: 1;
        }

        .opexcol-2 {
            flex: 2;
        }

        .opexcol-3 {
            flex: 3;
        }

        .opexcol-4 {
            flex: 4;
        }

        .opexcol-5 {
            flex: 5;
        }

        .opexcol-6 {
            flex: 6;
        }

        .opexcol-7 {
            flex: 7;
        }

        .opexcol-8 {
            flex: 8;
        }

        .opexcol-9 {
            flex: 9;
        }

        .opexcol-10 {
            flex: 10;
        }

        .opexcol-11 {
            flex: 11;
        }
    }

    .links-container {
        > * {
            float: left;
        }
    }
    .float {
        float: left;
        margin-right: var(--atom);
        margin-bottom: var(--atom);
    }
    div:has(.float):after { /* a parent containing only floated children will collapse in height, thus rendering following content behind the floats - this fixes it */
        content: ".";
        visibility: hidden;
        display: block;
        height: 0;
        clear: both;
    }

    .left-container > * {
        float: left;
        margin-left: var(--content-padding);

        &:first-child {
            margin-left: 0;
        }
    }

    --tile-height: calc(var(--module) * 20);
    --tile-width: calc(var(--module) * 25);
    .tile-layout {
        --tile-layout-height: calc(var(--tile-width) + var(--content-padding));
        display: grid;
        grid-gap: var(--module);
        grid-template-columns: repeat(auto-fit, minmax(var(--tile-layout-height), 1fr));
        grid-template-rows: repeat(auto-fit, var(--tile-height));
        /*background-color: var(--header-gray-bg); */

        & > * {
            max-height: var(--tile-height);
            max-width: var(--tile-width);
        }
    }

    ul,
    ol {
        padding-inline-start: var(--two-modules);
    }

    h4 {
        font: var(--font-title-4);
        padding: calc(var(--module) * 0.5) 0
    }
    h3 {
        font: var(--font-title-3);
    }
    h2 {
        font: var(--font-title-2);
    }

    pre {
        border-left: var(--atom) solid var(--c-accent);
        padding-left: var(--content-padding);
    }

    a {
        color: var(--c-context-active-element);
        cursor: pointer;

        &.negative {
            color: var(--c-context-error-delete);
        }
    }
}

.v2-layout:has(.bg-img) {
    width: 100vw;
    height: 100vh;
    position: relative;
    overflow: hidden;

    .bg-img {
        width: 100%;
        height: 100%;
        animation: imageAnimation 60s linear infinite 0s;
        overflow: hidden;
        position: absolute;

        @keyframes imageAnimation {
            50% {
                transform: scale(1.1);
            }
        }

        &.no-bg-pic-animation {
            animation: none;
        }
    }
}

@keyframes christmas-snow {
    0% {background-position: 0 0, 0 0, 0 0;}
    100% {background-position: 500px 1000px, 400px 400px, 300px 300px;}
}
.v2-layout.jedinja {

    --jed-black:  #1C1D21;
    --jed-white:  #C7CAD6;

    --l-main: 55%;
    --s-main: 45%;

    --s-main-bg: 10%;
    --l-main-bg: 25%;

    --h-main-company: 196;
    --h-main-company-alt: 196;

    --c-white: hsl(240, 9.8%, 17.0%);
    --c-context-background: var(--jed-black);
    --c-context-text-default: var(--jed-white);
    --c-context-text-inactive: #A7AAB6;

    .op-table {
        --c-op-color: var(--c-main-grey-bg);
    }

    .section-title {
        --c-section-title-line: var(--c-main-grey-bg);
    }

    .navigation .navigation-menu {
        --c-navigation-selected: var(--c-context-content-background);
        --c-navigation-selected-text: var(--c-main-black-text);
    }
}
.v2-layout.darkTheme {
    --c-white: #1C1D21;
    --c-context-background: #121317;
    --c-context-text-default: #C7CAD6;
    --c-context-text-inactive: #A7AAB6;
    
    --c-sup-grey: hsl(228, 13%, 27%);
    --c-main-black-bg: 	hsl(240, 2%, 22%);
    --c-main-green-bg: hsl(150, 20%, 26%);
    --c-main-blue-bg: hsl(201, 24%, 25%);
    --c-main-red-bg: hsl(0, 18%, 27%);
    --c-main-yellow-bg: 	hsl(50, 22%, 25%);
    
    --merge-fields-preview-text-color: var(--c-main-black);
}
.v2-layout {
    .breadcrumb-item+.breadcrumb-item::before {
        content: none;
    }
    
    .row {
        flex-wrap: initial;
        margin-right: 0;
        margin-left: 0;
    }
    
    label {
        margin-bottom: 0;
    }
}
html {
    overflow: hidden;
}

body {
    margin: 0;
}

.v2-layout {
    
    /*! normalize._css v7.0.0 | MIT License | github.com/necolas/normalize._css */
    
    /* Document
       ========================================================================== */
    
    /**
     * 1. Correct the line height in all browsers.
     * 2. Prevent adjustments of font size after orientation changes in
     *    IE on Windows Phone and in iOS.
     */
    * {
        box-sizing: border-box;
        
    }
    
    h1, h2, h3, h4 {
        margin: 0;
    }
    
    /**
     * Add the correct display in IE 9-.
     */
    
    article,
    aside,
    footer,
    header,
    nav,
    section {
        display: block;
        
    }
    
    /* Grouping content
       ========================================================================== */
    
    /**
     * Add the correct display in IE 9-.
     * 1. Add the correct display in IE.
     */
    
    figcaption,
    figure,
    main {
        /* 1 */
        display: block;
        
    }
    
    /**
     * Add the correct margin in IE 8.
     */
    
    figure {
        margin: 1em 40px;
        
    }
    
    /**
     * 1. Add the correct box sizing in Firefox.
     * 2. Show the overflow in Edge and IE.
     */
    
    hr {
        box-sizing: content-box;
        /* 1 */
        height: 0;
        /* 1 */
        overflow: visible;
        /* 2 */
    }
    
    /**
     * 1. Correct the inheritance and scaling of font size in all browsers.
     * 2. Correct the odd `em` font sizing in all browsers.
     */
    
    /* Text-level semantics
       ========================================================================== */
    
    /**
     * 1. Remove the gray background on active links in IE 10.
     * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
     */
    
    a {
        background-color: transparent;
        color: unset;
        text-decoration: none;
        cursor: pointer;
        /* 1 */
    }
    
    /**
     * 1. Remove the bottom border in Chrome 57- and Firefox 39-.
     * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
     */
    
    abbr[title] {
        border-bottom: none;
        /* 1 */
        text-decoration: underline dotted;
        /* 2 */
    }
    
    /**
     * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
     */
    
    b,
    strong {
        font-weight: inherit;
        
    }
    
    /**
     * Add the correct font weight in Chrome, Edge, and Safari.
     */
    
    b,
    strong {
        font-weight: bold;
        
    }
    
    /**
     * Add the correct font style in Android 4.3-.
     */
    
    dfn {
        font-style: italic;
        
    }
    
    /**
     * Add the correct background and color in IE 9-.
     */
    
    mark {
        background-color: #ff0;
        color: #000;
        
    }
    
    sub {
        bottom: -0.25em;
        
    }
    
    sup {
        top: -0.5em;
        
    }
    
    /* Embedded content
       ========================================================================== */
    
    /**
     * Add the correct display in IE 9-.
     */
    
    audio,
    video {
        display: inline-block;
        
    }
    
    /**
     * Add the correct display in iOS 4-7.
     */
    
    audio:not([controls]) {
        display: none;
        height: 0;
        
    }
    
    /**
     * Remove the border on images inside links in IE 10-.
     */
    
    img {
        border-style: none;
        max-width: 100%;
    }
    
    /**
     * Hide the overflow in IE.
     */
    
    svg:not(:root) {
        overflow: hidden;
        
    }
    
    /* Forms
       ========================================================================== */
    
    /**
     * 1. Change the font styles in all browsers (opinionated).
     * 2. Remove the margin in Firefox and Safari.
     */
    
    button,
    input,
    optgroup,
    select,
    textarea {
        font-family: inherit;
        /* 1 */
        line-height: 1.15;
        /* 1 */
        margin: 0;
        /* 2 */
        padding: 0;
        border: none;
        outline: none;
        
    }
    
    /**
     * Show the overflow in IE.
     * 1. Show the overflow in Edge.
     */
    
    button,
    input {
        /* 1 */
        overflow: visible;
        
    }
    
    /**
     * Remove the inheritance of text transform in Edge, Firefox, and IE.
     * 1. Remove the inheritance of text transform in Firefox.
     */
    
    button,
    select {
        /* 1 */
        text-transform: none;
        
    }
    
    /**
     * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
     *    controls in Android 4.
     * 2. Correct the inability to style clickable types in iOS and Safari.
     */
    
    button,
    [type="button"],
        /* 1 */
    [type="reset"],
    [type="submit"] {
        appearance: button;
        /* 2 */
    }
    
    /**
     * Remove the inner border and padding in Firefox.
     */
    
    button::-moz-focus-inner,
    [type="button"]::-moz-focus-inner,
    [type="reset"]::-moz-focus-inner,
    [type="submit"]::-moz-focus-inner {
        border-style: none;
        padding: 0;
        
    }
    
    /**
     * Restore the focus styles unset by the previous rule.
     */
    
    button:-moz-focusring,
    [type="button"]:-moz-focusring,
    [type="reset"]:-moz-focusring,
    [type="submit"]:-moz-focusring {
        outline: 1px dotted ButtonText;
        
    }
    
    /**
     * Correct the padding in Firefox.
     */
    
    fieldset {
        padding: 0.35em 0.75em 0.625em;
        
    }
    
    /**
     * 1. Correct the text wrapping in Edge and IE.
     * 2. Correct the color inheritance from `fieldset` elements in IE.
     * 3. Remove the padding so developers are not caught out when they zero out
     *    `fieldset` elements in all browsers.
     */
    
    legend {
        box-sizing: border-box;
        /* 1 */
        color: inherit;
        /* 2 */
        display: table;
        /* 1 */
        max-width: 100%;
        /* 1 */
        padding: 0;
        /* 3 */
        white-space: normal;
        /* 1 */
    }
    
    table {
        border-spacing: 0;
        th {
            text-align: unset;
        }

        td {
            padding: 0;
        }
        
        caption {
            display: none;
        }
    }
    
    /**
     * 1. Add the correct display in IE 9-.
     * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
     */
    
    progress {
        display: inline-block;
        /* 1 */
        vertical-align: baseline;
        /* 2 */
    }
    
    /**
     * Remove the default vertical scrollbar in IE.
     */
    
    textarea {
        overflow: auto;
        
    }
    
    /**
     * 1. Add the correct box sizing in IE 10-.
     * 2. Remove the padding in IE 10-.
     */
    
    [type="checkbox"],
    [type="radio"] {
        box-sizing: border-box;
        /* 1 */
        padding: 0;
        /* 2 */
    }
    
    /**
     * Correct the cursor style of increment and decrement buttons in Chrome.
     */
    
    [type="number"]::-webkit-inner-spin-button,
    [type="number"]::-webkit-outer-spin-button {
        height: auto;
        
    }
    
    /**
     * 1. Correct the odd appearance in Chrome and Safari.
     * 2. Correct the outline style in Safari.
     */
    
    [type="search"] {
        appearance: textfield;
        /* 1 */
        outline-offset: -2px;
        /* 2 */
    }
    
    /**
     * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
     */
    
    [type="search"]::-webkit-search-cancel-button,
    [type="search"]::-webkit-search-decoration {
        appearance: none;
        
    }
    
    /**
     * 1. Correct the inability to style clickable types in iOS and Safari.
     * 2. Change font properties to `inherit` in Safari.
     */
    
    ::-webkit-file-upload-button {
        appearance: button;
        /* 1 */
        font: inherit;
        /* 2 */
    }
    
    /* Interactive
       ========================================================================== */
    
    /*
     * Add the correct display in IE 9-.
     * 1. Add the correct display in Edge, IE, and Firefox.
     */
    
    details,
        /* 1 */
    menu {
        display: block;
        
    }
    
    /*
     * Add the correct display in all browsers.
     */
    
    summary {
        display: list-item;
        
    }
    
    /* Scripting
       ========================================================================== */
    
    /**
     * Add the correct display in IE 9-.
     */
    
    canvas {
        display: inline-block;
        
    }
    
    /**
     * Add the correct display in IE.
     */
    
    template {
        display: none;
        
    }
    
    /* Hidden
       ========================================================================== */
    
    /**
     * Add the correct display in IE 10-.
     */
    
    [hidden] {
        display: none;
        
    }
    
    /* clean ul and li */
    ul,
    li {
        padding: 0;
        margin: 0;
        margin-block-start: 0;
        margin-block-end: 0;
        text-align: left;
    }
    
    ul,
    ol {
        padding-inline-start: 0;
    }
    
    p {
        margin-block-start: 0;
        margin-block-end: 0;
        margin-inline-start: 0;
        margin-inline-end: 0;
    }

    button {
        color: inherit;
        display: block;
    }

    [popover] {
        color: unset;
    }
}

.v2-layout .for-mobile {
    display: none;
}

@media all and (max-width: 1376px) {
    .v2-layout {
        --atom: 3px;
        
        --fs-title-1: 27px;
        --fs-title-2: 23px;
        --fs-title-3: 17px;
        --fs-title-4: 14px;
        --fs-text-1: 12px;
        --fs-text-2: 11px;
        --fs-caption-1: 10px;
        --fs-caption-2: 8px;
    }
}

@media all and (max-width: 780px) {
    .v2-layout {

        .row {
            flex-direction: column;

            &.reversed-row {
                flex-direction: column-reverse;
            }

            & > .opexcol-1,
            & > .opexcol-2,
            & > .opexcol-3,
            & > .opexcol-4,
            & > .opexcol-5,
            & > .opexcol-6,
            & > .opexcol-7,
            & > .opexcol-8,
            & > .opexcol-9,
            & > .opexcol-10,
            & > .opexcol-11 {
                flex: 1;
            }
        }

        .content .header {
            gap: var(--couple-atoms);
            .header-breadcrumb {

                .breadcrumb-item,
                .breadcrumb-menu .breadcrumb-menu-top {
                    text-transform: none;
                    font-weight: 400;
                }

                .breadcrumb-divider,
                .breadcrumb-menu-icon {
                    --asvg-width: var(--module);
                    margin-right: 0;
                }

                .breadcrumb-menu .breadcrumb-menu-items {
                    flex-direction: column;
                    gap: var(--module);

                    .breadcrumb-menu-column {
                        padding-left: 0;
                        border-left: none;
                    }
                }
            }
        }

        .navigation-menu-icon {
            display: block;
        }
        .navigation-left {
            display: none;
        }
        .navigation.navigation-right {
            display: block;
        }

        .user-menu .user-menu-name {
            display: none;
        }

        .user-menu .theme {
            flex-direction: row;
        }

        .header .header-breadcrumb > *:not(:last-child):not(:nth-last-child(2)):not(:nth-last-child(3)) {
            display: none;
        }
    
        --f-content: var(--font-text-1);
        
        .signature-pad {
            --sig-size: 13;
        }

        .section-title .section-title-inner .section-title-text {
            text-transform: none;
            font-weight: 400;
        }

        .content .page {
            padding-bottom: calc(var(--module) * 7);

            .table-source {
                display: none;
            }
            .card-source {
                display: flex;
            }
        }

        .for-mobile {
            display: inherit;
        }
    }
}
@media all and (max-width: 780px) {
    .v2-layout {
        .rich-text-box-menu {
            display: none;
        }
        
        .rich-text-box-preview {
            --fs-preview: calc(var(--fs-pdf-docs-preview) * 0.46);
        }
    }
}
.v2-layout {
    .confirm-popup-icon {
        --confirmation-icon-size: calc(var(--module) * 6);
        --asvg-height: var(--confirmation-icon-size);
        --asvg-width: var(--confirmation-icon-size);
    }
    .confirm-popup-message {
        white-space: pre;
        text-align: center;
    }
}
.v2-layout {
    .total-box {
        box-shadow: 0 0 0 1px;
        border-radius: var(--standard-curve);
        --asvg-width: 27px;
        --asvg-height: 27px;
        .total-box-value {
            padding-right: var(--couple-atoms);
        }
    }
}
.v2-layout {
    .toast-carrier {
        --toast-bottom-margin: var(--four-modules);
        
        position: absolute;
        width: 100%;
        bottom: var(--toast-bottom-margin);
        opacity: 1;
        
        animation: bake .5s ease-out;
        
        &.hide {
            bottom: calc(var(--toast-bottom-margin) * -1);
            opacity: 0;
            
            animation: eat .5s ease-out;
        }
    }
    
    .toast-notification {
        box-shadow: var(--standard-shadow);
        border-radius: var(--standard-curve);
        background-color: var(--c-accent);
        color: var(--c-accent-text);
        stroke: var(--c-accent-text);
        fill: var(--c-accent-text);
        
        padding: 0 calc(var(--module) * .5);
        
        .toast-notification-message {
            line-height: var(--three-modules);
            text-align: center;
        }
        
        .toast-notification-close {
            margin-top: calc(var(--module) * .5);
            --c-asvg-clickable: var(--c-accent-text);
            
            --asvg-height: var(--two-modules);
            --asvg-width: var(--two-modules);
        }
        
        &.error-notification {
            background-color: var(--c-context-error-delete);
        }
    }
}

@keyframes bake {
    0% {
        bottom: calc(var(--toast-bottom-margin) * -1);
        opacity: 0;
    }
    90% {
        bottom: calc(var(--toast-bottom-margin) * 1.2);
        opacity: 1;
    }
}

@keyframes eat {
    0% {
        bottom: var(--toast-bottom-margin);
        opacity: 1;
    }
}
.v2-layout {
    .timeline-step {
        
        --timeline-accent-color: var(--c-main-grey);
        --timeline-node-size: var(--module); /* works better with an even number, and even better with a dividable by 4 */
        --timeline-width: 1px;
        
        --timeline-node-real-size: calc(var(--timeline-node-size) - var(--timeline-width));
        
        --timeline-default-border: 1px transparent solid;
        --timeline-border: var(--timeline-width) solid var(--timeline-accent-color);
        --timeline-margin: calc(var(--timeline-node-size) / 2);
        --timeline-padding: calc(var(--content-padding) + var(--timeline-node-size) / 2);
        --timeline-node-position: calc(var(--timeline-node-size) * -0.5);
        
        &:last-child {
            --timeline-border: var(--timeline-default-border);
        }
        
        min-height: var(--timeline-node-size);
        border: var(--timeline-default-border);
        border-left: var(--timeline-border);
        margin-left: var(--timeline-margin);
        padding-left: var(--timeline-padding);
        
        position: relative;
        
        .timeline-node {
            width: var(--timeline-node-real-size);
            height: var(--timeline-node-real-size);
            background-color: var(--timeline-accent-color);
            border-radius: 50%;
            position: absolute;
            top: 0;
            left: var(--timeline-node-position);
        }
        
        &.passed {
            --timeline-accent-color: var(--c-main-blue);
        }
    
        &.current {
            --timeline-accent-color: var(--c-context-active-element);
        }
        
        &.future {
            --timeline-accent-color: var(--c-main-grey-bg);
        }

        &.passed-unsuccessfully {
            --timeline-accent-color: var(--c-main-red);
            color: var(--c-main-red);
        }
        
        &.right-align {
            border-left: var(--timeline-default-border);
            margin-left: unset;
            padding-left: unset;
    
            border-right: var(--timeline-border);
            margin-right: var(--timeline-margin);
            padding-right: var(--timeline-padding);
    
            .timeline-node {
                left: unset;
                right: var(--timeline-node-position);
            }
        }
        
        /* last to override all borders */
        &.with-hover:hover {
            border: 1px solid var(--timeline-accent-color);
        }
    }
}
.v2-layout {
    
    .status-bar-title {
        font: var(--font-caption-1);
    }
    
    .status-bar-item {
        font: var(--font-caption-2);
        color: var(--c-main-grey);
        gap: var(--atom);
    }
    
    .status-bar-item-icon {
        --asvg-width: var(--caption-line-height);
        --asvg-height: var(--caption-line-height);
        width: var(--caption-line-height);
        
        &.yellow {
            stroke: var(--c-main-yellow);
            fill: var(--c-main-yellow);
        }
        
        &.green {
            stroke: var(--c-main-green);
            fill: var(--c-main-green);
        }
        
        &.blue {
            stroke: var(--c-main-blue);
            fill: var(--c-main-blue);
        }
        
        &.grey {
            stroke: var(--c-main-grey);
            fill: var(--c-main-grey);
        }
        
        &.red {
            stroke: var(--c-main-red);
            fill: var(--c-main-red);
        }
    }
    
    .timeline-history {
        .timeline-step {
            padding-bottom: var(--content-padding);
        }
    }
}
.v2-layout {
    .tile-item {
        --tile-info-size: var(--two-modules);

        .tile-item-content {
            height: calc(100% - var(--tile-info-size));

            & > * {
                width: 100%;
                height: 100%;
                object-fit: cover;
                border-radius: var(--standard-curve);
            }

            .section-content-body {
                height: 100%;
            }

            .add-tile-element-section {
                height: calc(var(--module) * 15);

                .add-tile-element {
                    margin: auto;
                    color: var(--c-context-active-element);
                    --asvg-width: var(--three-modules);
                    --asvg-height: var(--three-modules);
                }
            }
        }

        .tile-item-info {
            max-height: var(--tile-info-size);
            padding-top: var(--atom);
        }
    }
}
.v2-layout {
    
    .speech-bubble {
        position: absolute;
        left: 0;
        right: 0;
        top: calc(100% + var(--pointer-margin));
        padding: var(--content-padding);
        background-color: var(--c-context-active-element);
        color: var(--c-context-active-element-text);
        border-radius: calc(var(--standard-curve));
        width: 100%;
        min-width: calc(var(--module) * 16);
        transition: all .5s linear;
        z-index: 1;
        
        .speech-bubble-text {
            line-height: var(--module);
        }
        
        &.free-speech {
            width: unset;
            min-width: calc(var(--module) * 9);
        }
    }
    
    .suggest-orientation-left .speech-bubble {
        left: unset;
    }
    
    .suggest-orientation-right .speech-bubble {
        right: unset;
    }
}
.v2-layout {
    .signature-pad {
        --sig-aspect: calc(20 / 9);
        --sig-size: 18;
        
        --sig-width: calc(var(--module) * var(--sig-size) * var(--sig-aspect));
        --sig-height: calc(var(--module) * var(--sig-size));
        --sig-accent: var(--c-signature-pad-accent);
        
        position: relative;
        
        &.initials-pad {
            --sig-height: calc(var(--sig-width) * 73 / 780);
        }
        
        background-color: white;
        color: var(--c-main-black);
        .signature-pad-canvas {
            width: var(--sig-width);
            height: var(--sig-height);
            z-index: 2;
        }
        
        .signature-pad-icon {
            position: absolute;
            right: 0;
            top: 0;
            stroke: var(--sig-accent);
            fill: var(--sig-accent);
        }
        
        .signature-pad-placeholder {
            z-index: 1;
            position: absolute;
            bottom: 0;
            right: var(--content-padding);
            user-select: none;
            color: var(--sig-accent);
        }
    }
}
.v2-layout {
    
    .section-content .section-footer,
    .popup-carrier .popup .popup-status {
        border-bottom-left-radius: var(--section-curve);
        border-bottom-right-radius: var(--section-curve);
        text-align: center;
    
        --sec-footer-text-color: var(--c-context-text-default);
        --sec-footer-color: transparent;
    
        color: var(--sec-footer-text-color);
        background-color: var(--sec-footer-color);
        &.section-footer-indifferent {
            --sec-footer-color: var(--c-main-grey);
            --sec-footer-text-color: var(--c-main-grey-text);
        }
    
        &.section-footer-great {
            --sec-footer-color: var(--c-context-positive-add);
            --sec-footer-text-color: var(--c-context-positive-add-text);
        }
    
        &.section-footer-not-great {
            --sec-footer-color: var(--c-context-error-delete);
            --sec-footer-text-color: var(--c-context-error-delete-text);
        }
    
        &.section-footer-almost-great {
            --sec-footer-color: var(--c-main-green-bg);
        }
    
        &.section-footer-progress {
            --sec-footer-color: var(--c-main-yellow-bg);
        }
        
        &.section-footer-warning {
            --sec-footer-text-color: var(--c-sup-orange-text);
            --sec-footer-color: var(--c-sup-orange);
        }
        
        &.section-footer-informative {
            --sec-footer-text-color: var(--c-main-blue-text);
            --sec-footer-color: var(--c-main-blue);
        }
    }

    .section-title {
        --c-section-title-background: transparent;
        --c-section-title-text-color: default;
        --c-section-title-line: var(--c-context-background);

        padding: var(--section-title-v-padding) var(--section-title-h-padding);
        border-top-left-radius: var(--section-curve);
        border-top-right-radius: var(--section-curve);

        color: var(--c-section-title-text-color);
        background-color: var(--c-section-title-background);

        .section-title-inner {
            display: flex;
            border-bottom: 1px solid var(--c-section-title-line);

            .section-title-text {
                flex: 1;
                font: var(--f-important-pattern-text);
                text-transform: uppercase;
            }
        }

        &.section-title-inline {
            padding: calc(var(--section-title-v-padding) * 2) 0 0 0;
        }
    }
    
    .section-content {
        --c-section-background: var(--c-context-content-background);
        --c-section-text-color: var(--c-context-text-default);

        background-color: var(--c-section-background);
        color: var(--c-section-text-color);
        border-radius: var(--section-curve);
        box-shadow: var(--standard-shadow);
        display: flex;
        flex-direction: column;
        
        --section-title-v-padding: var(--important-pattern-v-padding);
        --section-title-h-padding: var(--important-pattern-h-padding);
        --section-title-line-height: var(--important-pattern-line-height);
        --section-title-total-size: calc(var(--section-title-line-height) + var(--section-title-v-padding) * 2);
        
        .section-footer {
            .section-footer-text {
                flex: 1;
                text-transform: uppercase;
            }
        }
        
        .section-content-body {
            --section-content-body-padding: var(--content-padding);
            display: flex;
            flex-direction: column;
            padding: var(--section-content-body-padding);
        }
        
        &.green-title > .section-title {
            --c-section-title-text-color: var(--c-main-green-text);
            --c-section-title-background: var(--c-main-green);
        }

        &.active {
            --c-section-background: var(--c-context-active-element);
            --c-section-text-color: var(--c-context-active-element-text);

            > .section-title {
                --c-section-title-line: var(--c-context-active-element-text);
                --c-section-title-text-color: var(--c-context-active-element-text);
            }
        }

        &.sec-blue {
            --c-section-background: var(--c-main-blue);
            --c-section-text-color: var(--c-main-blue-text);

            > .section-title {
                --c-section-title-line: var(--c-main-blue-text);
                --c-section-title-text-color: var(--c-main-blue-text);
            }
        }

        &.sec-grey {
            --c-section-background: var(--c-main-grey);
            --c-section-text-color: var(--c-main-grey-text);

            > .section-title {
                --c-section-title-line: var(--c-main-grey-text);
                --c-section-title-text-color: var(--c-main-grey-text);
            }
        }

        &.opex-grey {
            --c-section-background: var(--c-main-grey);
            --c-section-text-color: var(--c-main-grey-text);

            > .section-title {
                --c-section-title-line: var(--c-main-grey-text);
                --c-section-title-text-color: var(--c-main-grey-text);
            }
        }

        &.sec-darkblue {
            --c-section-background: var(--c-main-blue);
            --c-section-text-color: var(--c-main-blue-text);

            > .section-title {
                --c-section-title-line: var(--c-main-blue-text);
                --c-section-title-text-color: var(--c-main-blue-text);
            }
        }
    }
}
.v2-layout {
    .rich-text-box-menu {
        display: flex;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
        
        --asvg-height: calc(var(--module) + var(--atom) * 2);
        .asvg {
            padding-top: var(--atom);
        }
        
        .rich-text-box-menu-items > * {
            cursor: pointer;
            
            --c-rich-box-active: var(--c-context-text-inactive);
            &.is-active {
                --c-rich-box-active: var(--c-context-active-element);
            }
    
            color: var(--c-rich-box-active);
            stroke: var(--c-rich-box-active);
            fill: var(--c-rich-box-active);
        }
        
        &.disabled > .label {
            cursor: default;
            background-color: var(--c-validation-disabled-bg);
        }
    }
    
    .rich-text-box {
        --label-x-bg: var(--c-main-company-bg);
        background-color: var(--label-x-bg);
        border-bottom-left-radius: var(--standard-curve);
        border-bottom-right-radius: var(--standard-curve);
        
        &.disabled {
            background-color: var(--c-validation-disabled-bg);
        }
        
        .ProseMirror {
            padding: 0 var(--content-padding);
            min-height: calc(var(--module) * 25);
        }
        
        .ProseMirror-focused {
            outline: none;
        }
        
        .ProseMirror[data-placeholder]::before {
            color: var(--c-context-text-inactive);
            position: absolute;
            content: attr(data-placeholder);
            pointer-events: none;
        }
    }
    
    .rich-text-box-section.merge-fields-popup {
        .merge-fields {
            padding: 0;
        }
    }
    
    .rich-text-box-subject {
        margin-top: var(--input-vertical-padding);
        .ProseMirror {
            height: var(--input-actual-height);
            min-height: var(--input-actual-height);
            text-wrap: none;
            overflow: auto;
        }
    }
    
    .prose-mirror-merge-field {
        color: var(--c-context-active-element);
    }
    
    .subject-editor {
        position: relative;
        
        .subject-editor-shortcuts .label-x-texts {
            margin-left: 0;
            padding-top: 0;
            .asvg {
                --asvg-width: var(--input-actual-height);
                --asvg-height: var(--input-actual-height);
            }
        }
    }
    
    .prose-mirror-merge-field-select {
        border-radius: var(--standard-curve);
        border: 1px solid var(--c-context-active-element);
        background-color: var(--c-context-active-element-text);
        z-index: 1000;
        
        max-height: calc(var(--two-modules) * 6);
        overflow-y: auto;
        position: absolute;
        
        display: none;
        &.shown {
            display: initial;
        }
        
        .prose-mirror-merge-field-select-item {
            cursor: pointer;
            padding: 0 var(--content-padding);
            
            &.selected,
            &:hover {
                background-color: var(--c-main-blue-bg);
            }
        }
    }
    
    .rich-text-box-preview {
        font-size: var(--fs-preview);
        
        p {
            min-height:  var(--fs-preview);
        }
    }
}
.v2-layout {
    .callout {
        --callout-background: var(--c-main-green);
        --callout-color: var(--c-main-green-text);
        --callout-padding: var(--atom);
        
        position: relative;
        border-top-left-radius: var(--standard-curve);
        border-top-right-radius: var(--standard-curve);
        
        .callout-content {
            width: 100%;
    
            background-color: var(--callout-background);
            color: var(--callout-color);
            padding: 0 var(--callout-padding) var(--callout-padding) var(--callout-padding);
            border-bottom-left-radius: var(--standard-curve);
            border-bottom-right-radius: var(--standard-curve);
        }
        
        &.shown {
            background-color: var(--callout-background);
            color: var(--callout-color);
            line-height: var(--module);
            padding: var(--callout-padding);
            
            --callout-translate: calc(var(--callout-padding) * -1);
            transform: translateX(var(--callout-translate));
        }
    }
}
.v2-layout {
    .progress-v2 {
        --progress-height: var(--module);
        --progress-part-height: var(--atom);
        height: var(--progress-height);
        display: flex;
        gap: var(--atom);
        padding-top: calc(var(--progress-height) / 2 - var(--progress-part-height) / 2);
    
        .progress-part {
            flex: 1;
            height: var(--progress-part-height);
            background-color: var(--c-context-content-background);
            border-radius: var(--standard-curve);
        
            &.dimmed {
                background-color: rgba(0, 0, 0, 0.5);
            }
        }
        
    }
}
.v2-layout {
    .progress-indicator {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;

        opacity: 0;
        transition: opacity .5s linear 1s;

        &.shown {
            opacity: 1;
        }

        .progress-indicator-value {
            font: var(--font-caption-2);
            line-height: var(--fs-caption-2);
            text-align: center;
            white-space: nowrap;
            border-radius: var(--standard-curve);

            &.style1 {
                background-color: var(--c-sup-pink);
                color: var(--c-sup-pink-text);
            }
            &.style2 {
                background-color: var(--c-sup-purple);
                color: var(--c-sup-purple-text);
            }
            &.style3 {
                background-color: var(--c-sup-grey);
                color: var(--c-sup-grey-text);
            }
            &.style4 {
                background-color: var(--c-sup-orange);
                color: var(--c-sup-orange-text);
            }
        }
        
        &.blink .progress-indicator-value {
            animation: blink 2s linear infinite;
            
            @keyframes blink {
                0% {
                    opacity: 1;
                }
                50% {
                    opacity: 0.5;
                }
            }
        }
    }
}
.v2-layout {

    .popup {
        --popup-padding: var(--content-padding);
        --popup-header-footer-size: var(--three-modules);
        --c-popup-header-footer-color: var(--c-context-content-background);
        --c-popup-content-background: var(--c-context-content-background);
        --f-popup-title: var(--f-important-pattern-text);
        --popup-curve: var(--standard-curve);
        --popup-shadow: var(--standard-shadow);
        --max-popup-content-height: calc(100vh - var(--module) * 10);
        --op-row-height: var(--two-modules);

        position: relative;
        margin: 0 auto;

        box-shadow: var(--popup-shadow);
        border-radius: var(--popup-curve);
        background-color: var(--c-popup-content-background);
        min-width: calc(var(--module) * 20);

        .popup-header {
            background-color: var(--c-popup-header-footer-color);
            padding: var(--popup-padding);
            padding-bottom: var(--content-padding);
            font: var(--f-popup-title);
            border-top-left-radius: var(--popup-curve);
            border-top-right-radius: var(--popup-curve);
        }

        &.centered-header .popup-header {
            display: flex;
            justify-content: center;
        }

        .popup-content {
            background-color: var(--c-popup-content-background);
            padding: 0 var(--popup-padding);
            max-height: var(--max-popup-content-height);
            max-width: 90vw;
            /*overflow-y: auto; // commented out as it breaks LabelSelects, its absolute-positioned items are calculated as part of this container for some unknown reason*/
        }

        .popup-footer {
            border-bottom-left-radius: var(--popup-curve);
            border-bottom-right-radius: var(--popup-curve);
            background-color: var(--c-popup-header-footer-color);
            padding: var(--popup-padding);
            padding-top: 0;

            &.with-status {
                border-bottom-left-radius: 0;
                border-bottom-right-radius: 0;
            }
        }

        &.centered-footer .popup-footer {
            justify-content: center;
        }

        &.gallery-popup {
            background-color: transparent;

            --gallery-handlers-width: var(--four-modules);

            .gallery-popup-navigation {
                margin: auto 0;
                --asvg-height: calc(var(--module) * 6);
                --asvg-width: var(--gallery-handlers-width);

                transition: var(--standard-transition);
                &:hover {
                    stroke: var(--c-context-active-element);
                }
            }

            .gallery-popup-content {
                & > * {
                    max-height: calc(100vh - var(--content-padding) * 2);
                    max-width: calc(100vw - var(--gallery-handlers-width) * 2);
                    border-radius: var(--standard-curve);
                }
            }
        }

        &.auto-scroll .popup-content {
            overflow-y: auto;
        }

        --popup-column-width: calc(100vw / 12);
        --popup-column-width_2: calc(var(--popup-column-width) * 2);
        --popup-column-width_3: calc(var(--popup-column-width) * 3);
        --popup-column-width_4: calc(var(--popup-column-width) * 4);
        --popup-column-width_5: calc(var(--popup-column-width) * 5);
        --popup-column-width_6: calc(var(--popup-column-width) * 6);

        &.popup-col-1 {
            min-width: var(--popup-column-width);
        }
        &.popup-col-2 {
            min-width: var(--popup-column-width_2);
        }
        &.popup-col-3 {
            min-width: var(--popup-column-width_3);
        }
        &.popup-col-4 {
            min-width: var(--popup-column-width_4);
        }
        &.popup-col-5 {
            min-width: var(--popup-column-width_5);
        }
        &.popup-col-6 {
            min-width: var(--popup-column-width_6);
        }

        .gif-in-popup {
            max-width: calc(var(--module) * 10);
        }
    }

    .popup-carrier {
        position: fixed;
        background-color: var(--dimmed-bg);
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        z-index: 999;
        visibility: hidden;
        opacity: 0;
        pointer-events: none;
        transition: var(--standard-transition);
        
        &:target {
            visibility: visible;
            opacity: 1;
            pointer-events: auto;
        }
        
        .popup-carrier-column {
            
            display: flex;
            align-items: center;
            height: 100%;
        }
    }

    .popover-trigger {
        background-color: transparent;
        cursor: pointer;
    }

    .popover {
        margin: 0;
        padding: 0;
        border: none;
        overflow: visible;
        position-area: bottom span-right;

        &.popover-position-bottom-left {
            position-area: bottom span-left;
        }
    }
}
.v2-layout {
    .paginator {
        display: flex;
        justify-content: center;
        font: var(--f-op);
        height: var(--two-modules);
        line-height: var(--two-modules);
        
        .paginator-item {
            padding: 0 var(--atom);
            text-align: center;
            cursor: pointer;
            
            &.paginator-item-nav,
            .asvg {
                --asvg-width: calc(var(--module) + var(--atom));
            }
            
            &.paginatored {
                background-color: var(--c-context-active-element);
                color: var(--c-context-active-element-text);
                border-radius: var(--standard-curve);
            }
            
            &.depaginatored {
                cursor: initial;
                fill: var(--c-context-text-inactive);
            }
        }
    }
}
.v2-layout {
    .options-button-container {
        display: flex;
        position: relative;

        .options-button-items {
            --button-items-color: var(--c-context-active-element);
            --button-item-text-color: var(--c-context-active-element-text);
            --button-item-hover-color: var(--c-main-blue);

            z-index: 10000;
            position: absolute;
            top: var(--input-total-height);
            display: flex;
            flex-direction: column;
            border-radius: var(--section-curve);
            box-shadow: var(--standard-shadow);
            padding: var(--couple-atoms);
            gap: var(--atoms);
            background-color: var(--button-items-color);
            color: var(--button-item-text-color);
            stroke: var(--button-item-text-color);
            fill: var(--button-item-text-color);


            .options-button-item {
                display: flex;
                flex-direction: row;
                cursor: pointer;
                height: var(--input-actual-height);
                border-radius: var(--standard-curve);
                padding: 0 var(--module);
                gap: var(--couple-atoms);
                font: var(--font-button);
                white-space: nowrap;

                --button-img-margin: var(--atom);
                --button-img-size: calc(var(--input-actual-height) - var(--button-img-margin) * 2);

                .button-text {
                    margin: auto 0;
                }

                .button-img {
                    --asvg-height: var(--button-img-size);
                    --asvg-width: var(--button-img-size);
                    margin: auto 0;
                }

                &:hover {
                    background-color: var(--button-item-hover-color);
                }
            }
        }
    }
}
.v2-layout {
    .op-table-container {
        overflow-y: hidden;
        overflow-x: auto;
        
        &.with-overflow {
            overflow: visible;
        }
    }
    
    .op-table {
        --op-padding: var(--module);
        --c-op-color: var(--c-context-background);
        --c-op-color-text: default;
        --op-asvg-padding: var(--atom);
        --op-border-width: 1px;
        --op-line-height: calc(var(--op-row-height) - var(--op-border-width) * 2);
        white-space: nowrap;
        border-radius: var(--standard-curve);
    
        .op-table--header-cell,
        .op-table--data-cell {
            font: var(--f-op);
            line-height: var(--op-line-height);
            padding: 0 var(--op-padding);
            height: var(--op-row-height);
            border: var(--op-border-width) solid var(--c-op-color);
            
            .asvg {
                --asvg-height: calc(var(--op-row-height) - var(--op-asvg-padding) * 2);
                margin-top: var(--op-asvg-padding);
            }
            
            &.hidden-column {
                display: none;
            }
            
            &.with-input {
                padding: 0;
    
                .label-x {
                    --input-vertical-padding: 0;
                    --label-x-img-margin: var(--module);
                }
                
                .label-input.label-input-white {
                    border: none;
                }
            }
            
            &.vertical-layout > div {
                display: flex;
                flex-direction: column;
                line-height: calc(var(--module) * 1.5);
            }
            
            &.centered > div {
                justify-content: center;
            }
            
            &.righted > div {
                justify-content: flex-end;
            }
            
            &.righted input {
                text-align: right;
            }

            &.bolded {
                font-weight: bold;
            }

            &.visual-col-span {
                border-right: none;
            }

            &.sticky {
                left: 0;
                position: sticky;
                background-color: var(--c-main-blue-bg);
                z-index: 1;
            }

            .row {
                gap: var(--couple-atoms);
            }
        }

        .op-table--header-cell {
            font: var(--font-text-1);
            line-height: var(--op-line-height);
            height: var(--op-row-height);
            background-color: var(--c-op-color);
            padding: 0 var(--op-padding);
            color: var(--c-op-color-text);
        }
    
        .op-table--header-value {
            &.asvg {
                fill: var(--c-context-text-default);
                stroke: var(--c-context-text-default);
            }
        }
    
        .op-table--header-value,
        .op-table--data-cell,
        .op-table--data-value {
            &.important,
            .important {
                font-weight: 400;
                color: var(--c-context-active-element);
                fill: var(--c-context-active-element);
                stroke: var(--c-context-active-element);
            }
            &.as-pre {
                white-space: pre;
            }
            
            &.hidden-value {
                display: none;
            }
            &.flexed {
                flex: 1;
            }
            &.with-click {
                font-weight: 400;
            }
        }
        
        .op-table--header-row,
        .op-table--data-row {
            .op-table--data-cell,
            .op-table--header-cell {
                
                --c-op-icon: var(--c-chart-default);
                
                .with-new,
                .with-delete,
                .with-hover {
                    opacity: 0;
    
                    stroke: var(--c-op-icon);
                    fill: var(--c-op-icon);
    
                    transition: var(--standard-transition);
                }
                
                .with-new {
                    --c-op-icon: var(--c-context-positive-add);
                }
                .with-delete {
                    --c-op-icon: var(--c-context-error-delete);
                }
            }
            
            &:hover .op-table--data-cell,
            .op-table--header-cell {
                .with-delete,
                .with-new,
                .with-hover {
                    opacity: 1;
                }
            }
        }
        
        .op-table--data-row,
        .op-table--data-cell,
        .op-table--data-value {
            &.selected {
                background-color: var(--c-main-blue-bg);
            }
            &.positive {
                background-color: var(--c-main-green-bg);
            }
            &.warning {
                background-color: var(--c-main-yellow-bg);
            }
            &.negative {
                background-color: var(--c-main-red-bg);
            }
            &.neutral {
                background-color: var(--c-main-grey-bg);
            }

            &.positive-fg {
                color: var(--c-main-green);
            }
            &.negative-fg {
                --negative-fg-color: var(--c-main-red);
                color: var(--negative-fg-color);
                --c-op-icon: var(--negative-fg-color);
            }

            &.with-click-row {
                cursor: pointer;
            }
        }
    
        .op-table--data-value {
            &.inline-table {
                .op-table {
                    --op-border-width: 0;
    
                    .op-table--data-cell:first-child {
                        padding-left: 0;
                    }
                    
                }
            }
            
            &.fit-in-cell {
                --multi-bar-height: calc(var(--module) * 1.5);
                
                &.fill-cell {
                    --multi-bar-height: var(--op-line-height);
                }
            }
        }

        .op-table--data-cell {
            &.op-chip {
                padding: 0 calc(var(--module) * 0.5);
                --chip-color: default;
                --chip-bg: default;
                width: calc(var(--module) * 15);
                line-height: calc(var(--module) * 1.5);
                position: relative;

                > * {
                    justify-content: center;
                    color: var(--chip-color);
                    background-color: var(--chip-bg);
                    border-radius: var(--standard-curve);
                    padding: 0 var(--couple-atoms);
                }

                .asvg {
                    position: absolute;
                    right: var(--atom);
                    top: 0;
                }

                &.op-progress-chip {
                    --chip-bg: var(--c-main-yellow);
                    --chip-color: var(--c-main-yellow-text);
                }

                &.op-negative-chip {
                    --chip-bg: var(--c-main-red);
                    --chip-color: var(--c-main-red-text);
                }

                &.op-positive-chip {
                    --chip-bg: var(--c-main-green);
                    --chip-color: var(--c-main-green-text);
                }

                &.op-neutral-chip {
                    --chip-bg: var(--c-main-grey);
                    --chip-color: var(--c-main-grey-text);
                }

                &.op-pinky-chip {
                    --chip-bg: var(--c-sup-pink);
                    --chip-color: var(--c-sup-pink-text);
                }

                &.op-dpurple-chip {
                    --chip-bg: var(--c-sup-purple);
                    --chip-color: var(--c-sup-purple-text);
                }

                &.op-dgrey-chip {
                    --chip-bg: var(--c-sup-grey);
                    --chip-color: var(--c-sup-grey-text);
                }
            }
        }
    }

    .doc-table .op-table {
        --c-op-color: var(--c-main-grey);
        --c-op-color-text: var(--c-main-grey-text);
        --op-border-width: 0;
        --doc-border: 1px solid var(--c-op-color);
        border: var(--doc-border);

        .op-table--data-cell:not(:last-child):not(.visual-col-span) {
            border-right: var(--doc-border); /* column lines */
        }

        .op-table--data-row.doc-table-border .op-table--data-cell {
            border-top: var(--doc-border); /* row lines */
        }
    }
}
.v2-layout .multi-row-label {
    padding-top: var(--input-vertical-padding);
}
.v2-layout {
    .with-pointer {
        --pointer-margin: calc(var(--module) * 1.5);
        --pointer-position: var(--pointer-margin);
        --pointer-shape: polygon(25% 25%, 75% 75%, 10% 100%, 0% 100%, 0% 90%);
        --pointer-left: var(--pointer-position);
        --pointer-right: var(--pointer-position);
        --pointer-rotate: rotateZ(135deg);
        
        &.steeper-pointer {
            --pointer-shape: polygon(25% 25%, 75% 50%, 10% 100%, 0% 100%, 0% 90%);
        }
        
        &.for-small-item {
            --pointer-position: var(--atom);
        }
        
        /* Draw a triangular pointer from a component */
        &:before {
            /* margin (M) should be equal to half of the square's diagonal, so square's side is 2x^2 = 4M^2 <=> x = 1.42M */
            --square-size: calc(var(--pointer-margin) * 1.42);
            content:'';
            display: block;
            height: var(--square-size);
            width: var(--square-size);
            background-color: inherit;
            border: inherit;
            position: absolute;
            top: calc(var(--square-size) * -0.5);
            left: var(--pointer-left);
            right: var(--pointer-right);
            clip-path: var(--pointer-shape);
            transform: var(--pointer-rotate);
            border-radius: var(--standard-curve);
        }
    }
    
    .suggest-orientation-left .with-pointer {
        --pointer-left: unset;
        --pointer-rotate: rotateY(180deg) rotateZ(135deg);
    }
    
    .multi-bar {
        --multi-bar-height: var(--two-modules);
        height: var(--multi-bar-height);
        width: 100%;
        
        cursor: pointer;
        position: relative;

        .multi-bar-items {
            display: flex;
            
            .multi-bar-item {
                text-align: center;
                line-height: var(--multi-bar-height);
                padding: 0 var(--atom);
                
                &:first-child {
                    border-bottom-left-radius: var(--standard-curve);
                    border-top-left-radius: var(--standard-curve);
                }
                &:last-child {
                    border-bottom-right-radius: var(--standard-curve);
                    border-top-right-radius: var(--standard-curve);
                }
            }
        }
        
        .multi-bar-tooltip {
            --pointer-margin: var(--multi-bar-height);
            --tooltip-bg: var(--c-accent);
            --c-tooltip: var(--c-accent-text);
            
            position: absolute;
            z-index: 1000;
            left: 0;
            top: calc(100% + var(--pointer-margin));
            padding: var(--content-padding);
            
            background-color: var(--tooltip-bg);
            color: var(--c-tooltip);
            border-radius: var(--standard-curve);
            box-shadow: var(--standard-shadow);
            
            line-height: var(--multi-bar-height);
            
            .tooltip-actions {
                border-left: 1px var(--c-main-grey) solid;
                justify-content: center;
                padding-left: var(--content-padding);
                
                --input-vertical-padding: 0;
            }
            
            .multi-bar-tooltip-item {
                --width-units: 0;
                --width-base: var(--atom);
                
                width: calc(var(--width-units) * var(--width-base));
                height: var(--multi-bar-height);
                border-radius: var(--standard-curve);
            }
            
            
        }
        
        .multi-bar-item,
        .multi-bar-tooltip-item {
            
            opacity: 0.8;
            
            &.green {
                background-color: var(--c-main-green);
                color: var(--c-main-green-text);
            }
            
            &.yellow {
                background-color: var(--c-main-yellow);
                color: var(--c-main-yellow-text);
            }
            
            &.grey {
                background-color: var(--c-main-grey);
                color: var(--c-main-grey-text);
            }

            &.blue {
                background-color: var(--c-main-blue);
                color: var(--c-main-blue-text);
            }
        }
    }
}
.v2-layout {
    .loading-indicator {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
    
        opacity: 0;
        transition: opacity .5s linear 1s;
        
        &.shown {
            opacity: 1;
        }
        
        --loading-default-state: calc(var(--module) * 13);
        .loading-indicator-worm {
            --curve: var(--standard-curve);
            color: white;
            font: var(--font-caption-2);
            line-height: var(--fs-caption-2);
            width: var(--loading-default-state);
            min-width: var(--loading-default-state);
            margin: 0 auto;
            text-align: center;
            border-bottom-right-radius: var(--curve);
            border-bottom-left-radius: var(--curve);
            animation: loading-indicator-animation 4s infinite linear;
            
            &.style1 {
                background-color: var(--c-sup-pink);
            }
            &.style2 {
                background-color: var(--c-sup-purple);
            }
            &.style3 {
                background-color: var(--c-sup-grey);
            }
            &.style4 {
                background-color: var(--c-sup-orange);
            }
        }
    }
}

@keyframes loading-indicator-animation{
    0%{
        width: var(--loading-default-state);
    }
    25%{
        width: 50%;
    }
    50%{
        width: 100%;
    }
    75%{
        width: 50%;
    }
    100%{
        width: var(--loading-default-state);
    }
};
.v2-layout {
    .list-item {
        --c-list-item: var(--c-main-grey);
        --total-size: var(--four-modules);
        --list-item-vertical-padding: var(--input-vertical-padding);
        --list-item-inner-size: calc(var(--total-size) - var(--list-item-vertical-padding));
        --list-item-inner-padding: var(--couple-atoms);
        --list-item-text-gap: var(--atom);
        --list-item-inner-content-size: calc(var(--list-item-inner-size) - var(--list-item-inner-padding) * 2);
        --list-item-vertical-texts-count: 2;
        --list-item-action-size: var(--two-modules);
        --c-list-item-action: var(--c-context-error-delete);
        --c-list-item-secondary: var(--c-main-grey);
        --f-list-item-secondary: var(--font-caption-1);
        
        margin-top: var(--list-item-vertical-padding);
        padding: 0 var(--content-padding);
        background-color: var(--c-context-background);
        border-radius: var(--standard-curve);
        
        .list-item-icon {
            --asvg-height: var(--list-item-inner-size);
            --asvg-width: var(--list-item-inner-size);
            
            &.red {
                --c-list-item: var(--c-main-red);
            }
            &.blue {
                --c-list-item: var(--c-main-blue);
            }
            &.green {
                --c-list-item: var(--c-main-green);
            }
            &.yellow {
                --c-list-item: var(--c-main-yellow);
            }
            &.purple {
                --c-list-item: var(--c-sup-purple);
            }
            
            .asvg {
                fill: var(--c-list-item);
                stroke: var(--c-list-item);
                tspan { /* deal with text inside svg */
                    fill: var(--c-list-item);
                }
            }
        }
        
        .list-item-info {
            display: flex;
            flex-direction: column;
            gap: var(--list-item-text-gap);
            padding: var(--list-item-inner-padding) 0;
            
            .list-item-text-2 {
                font: var(--f-list-item-secondary);
                color: var(--c-list-item-secondary);
            }
            
            > * {
                line-height: calc(
                    (var(--list-item-inner-content-size) - var(--list-item-text-gap) * (var(--list-item-vertical-texts-count) - 1)) / var(--list-item-vertical-texts-count)
                );
            }
            
            .list-item-text-1 {
                color: var(--c-context-active-element);
                cursor: pointer;
            }
        }
        
        .list-item-text-other {
            display: flex;
            flex-direction: column;
            justify-content: center;
            color: var(--c-list-item-secondary);
            font: var(--f-list-item-secondary);
        }
        
        .list-item-action {
            padding-top: calc((var(--list-item-inner-size) - var(--list-item-action-size)) / 2);
            .asvg {
                --asvg-height: var(--list-item-action-size);
                --asvg-width: var(--list-item-action-size);
                --c-asvg-clickable: var(--c-list-item-action);
            }
        }
    }
}
.v2-layout {
    .label-x.label {
        
        --label-x-bg: transparent;
        --label-x-text-color: unset;
        
        &.is-blob {
    
            padding-right: 0;
            padding-left: 0;
            
            &.is-inline {
                --inline-height: var(--two-modules);
                margin-top: 0;
                height: var(--inline-height);
                .label-x-texts {
                    padding-top: 0;
                }
                
                --asvg-height: calc(var(--inline-height) - var(--atom) * 2);
            }
            
            .label-x-value {
                border-radius: var(--standard-curve);
                font: var(--font-caption-1);
                line-height: var(--label-x-single-text-height);
                padding: 0 var(--content-padding);
                
                &:has(.asvg) {
                    padding-right: 0;
                }
            }
        }
    
        &.blob-var0 .label-x-value {
            background-color: var(--c-main-yellow);
            color: var(--c-main-yellow-text);

            .asvg {
                --c-asvg-clickable: var(--c-main-yellow-text);
                stroke: var(--c-main-yellow-text);
            }
        }
        &.blob-var1 .label-x-value {
            background-color: var(--c-sup-grey);
            color: var(--c-sup-grey-text);

            .asvg {
                --c-asvg-clickable: var(--c-sup-grey-text);
                stroke: var(--c-sup-grey-text);
            }
        }
        &.blob-var2 .label-x-value {
            background-color: var(--c-sup-purple);
            color: var(--c-sup-purple-text);

            .asvg {
                --c-asvg-clickable: var(--c-sup-purple-text);
                stroke: var(--c-sup-purple-text);
            }
        }
        &.blob-var3 .label-x-value {
            background-color: var(--c-sup-pink);
            color: var(--c-sup-pink-text);

            .asvg {
                --c-asvg-clickable: var(--c-sup-pink-text);
                stroke: var(--c-sup-pink-text);
            }
        }
        &.blob-var4 .label-x-value {
            background-color: var(--c-main-green);
            color: var(--c-main-green-text);
            
            .asvg {
                --c-asvg-clickable: var(--c-main-green-text);
                stroke: var(--c-main-green-text);
            }
        }
        &.blob-var5 .label-x-value {
            background-color: var(--c-main-red);
            color: var(--c-main-red-text);

            .asvg {
                --c-asvg-clickable: var(--c-main-red-text);
                stroke: var(--c-main-red-text);
            }
        }
    }
}
.v2-layout {
    .label-x {
        --label-x-text-heights: var(--module);
        --label-x-bg: var(--c-main-company-bg);
    
        --label-x-img-margin: var(--atom);
        --label-x-height: var(--input-actual-height);
        --label-x-input-height: var(--label-x-text-heights);
        --label-x-img-size: calc(var(--input-actual-height) - var(--label-x-img-margin) * 2);
        --label-x-left-margin: var(--content-padding);
        --label-x-font: var(--f-content);
        --label-x-text-color: var(--c-context-text-default);
        --caption-line-height: var(--fs-caption-2);
    
        background-color: var(--label-x-bg);
        height: var(--label-x-height);
        margin-top: var(--input-vertical-padding);
        padding: 0 var(--label-x-img-margin) 0 0;
        border-radius: var(--standard-curve);

        display: flex;
        gap: var(--couple-atoms);
        
        .label-x-texts {
            display: flex;
            flex-direction: column;
            flex: 1;
            padding-top: calc(var(--label-x-text-heights) - var(--caption-line-height));
            margin-left: var(--label-x-left-margin); /* margin here instead of padding in the parent, because when this is a flex item, the paddings mess up the calculations */
    
            .label-x-text {
                height: var(--caption-line-height);
                font: var(--font-caption-1);
                line-height: var(--caption-line-height);
                color: var(--c-context-text-inactive);
            }
    
            .label-x-value {
                height: var(--label-x-input-height);
                font: var(--label-x-font);
                line-height: var(--label-x-text-heights);
                border: none;
                background-color: var(--label-x-bg);
                color: var(--label-x-text-color);
            }
        }
        
        &.label-x-no-label {
            .label-x-text {
                height: 0;
            }
            
            .label-x-value {
                --label-x-single-text-height: calc(var(--caption-line-height) + var(--label-x-text-heights));
                height: var(--label-x-single-text-height);
                line-height: var(--label-x-single-text-height);
            }
        }
    
        .label-x-img {
            --asvg-height: var(--label-x-img-size);
            --asvg-width: var(--label-x-img-size);
            margin-top: var(--label-x-img-margin);
            stroke: var(--c-context-text-inactive);
            fill: var(--c-context-text-inactive);
        }
    }
}
.v2-layout .label-x.label-select {
    cursor: pointer;
    position: relative;
    
    &.label-input-white {
        --label-x-bg: var(--c-context-content-background);
    }
    
    .label-x-value {
        cursor: pointer;
    }
    
    .label-select-items {
        position: absolute;
        top: var(--input-actual-height);
        left: 0;
        z-index: 1000;
        background-color: var(--c-context-content-background);
        width: fit-content;
        min-width: 100%;
        box-shadow: 0 4px 4px var(--label-x-bg);
        max-height: calc(var(--text-line-height) * 8);
        overflow: auto;
        
        .label-select-item {
            padding: 0 var(--content-padding);
            transition: var(--standard-transition);
            color: var(--c-context-text-default);
            &:hover {
                background-color: var(--label-x-bg);
            }
        }
    }
}
.v2-layout {
    .label-phone {
        .vue-tel-input {
            border: none;
            box-shadow: none;
            
            .vti__dropdown {
    
                .vti__dropdown-arrow {
                    /*visibility: hidden; */
                }
                
                padding: 0;
                .vti__flag {
                    margin: 0 var(--atom) 0 0;
                }
                
                .vti__dropdown-list {
                    background-color: var(--c-context-content-background);
                    box-shadow: 0 4px 4px var(--label-x-bg);
                    padding: 0;
                    border: none;
    
                    .vti__dropdown-item {
                        padding: 0 var(--content-padding);
                        transition: var(--standard-transition);
                        &:hover {
                            background-color: var(--label-x-bg);
                        }
                        line-height: var(--text-line-height);
                    }
                }
            }
        }
    }
}
.v2-layout {
    .label-input {
        cursor: text;
        
        .label-x-img.clickable {
            cursor: pointer;
        }
        
        &:hover .label-x-img.clickable  {
            fill: var(--c-context-active-element);
            stroke: var(--c-context-active-element);
        }
        
        &.label-input-white {
            --label-x-bg: var(--c-context-content-background);
            border: 1px solid var(--c-main-grey-bg);
        }
        
        &.label-input-white-great {
            --label-x-bg: var(--c-context-content-background);
            border: 1px solid var(--c-context-positive-add);
        }
        
        &.label-input-white-danger {
            --label-x-bg: var(--c-context-content-background);
            border: 1px solid var(--c-context-error-delete);
        }
        
        &.label-input-reversed {
            flex-direction: row-reverse;
        }
        
        &.label-input-area {
            --label-input-area-more-height: calc(var(--module) * 5);
            
            --label-x-height: calc(var(--input-actual-height) + var(--label-input-area-more-height));
            --label-x-img-margin: calc(var(--atom) + var(--label-input-area-more-height)*0.5);
            --label-x-input-height: calc(var(--label-x-text-heights) + var(--label-input-area-more-height));
    
            .label-x-texts {
                .label-x-value {
                    resize: none;
                }
            }
        }
    }
}
.v2-layout .label-x.label-checkbox {
    cursor: pointer;
    --chb-size: var(--label-x-img-size);
    --label-x-bg: transparent;
    --label-x-text-color: unset;
    
    .label-x-texts {
        margin-left: 0;
    }
    
    .label-x-value {
        white-space: nowrap;
    }
    
    .label-checkbox-input {
        /* hide original */
        appearance: none;
        background-color: var(--c-context-content-background);
        
        /* display new frame */
        font: inherit;
        width: var(--chb-size);
        height: var(--chb-size);
        border: 1px solid var(--c-context-text-inactive);
        border-radius: var(--standard-curve);
        cursor: pointer;
        
        /* content and placement */
        display: grid;
        place-content: center;
        
        --chb-indicator-size: calc(var(--chb-size) - var(--atom) * 2);
        
        &::before {
            content: "";
            width: var(--chb-indicator-size);
            height: var(--chb-indicator-size);
            transform: scale(0);
            transition: var(--standard-transition);
            box-shadow: inset 1em 1em var(--c-context-content-background);
            transform-origin: bottom left;
            clip-path: polygon(7% 55%, 0 65%, 40% 100%, 100% 16%, 90% 8%, 37% 81%);
        }
        
        &:checked {
            background-color: var(--c-context-positive-add);
            border-width: 0;
            &::before {
                transform: scale(1);
            }
        }

        &:hover {
            filter: saturate(135%);
        }
    }
    
    &.label-checkbox-position-before {
        flex-direction: row-reverse;
    }
    
    --chb-switch-width: calc(var(--chb-size) * 2);
    --chb-switch-padding: var(--atom);
    --c-chb-switch-unchecked: var(--c-main-grey);
    --c-chb-switch-checked: var(--c-context-positive-add);
    
    &.label-switch .label-checkbox-input {
        width: var(--chb-switch-width);
        border: none;
        border-radius: calc(var(--chb-size) / 2);
        background-color: var(--c-chb-switch-unchecked);
        padding-left: var(--chb-switch-padding);
        
        justify-content: start;
        
        transition: var(--standard-transition);/*120ms background-color ease-in-out;*/
        
        --switch-width-diff-active: var(--atom);
        &:active::before {
            width: calc(var(--chb-indicator-size) + var(--switch-width-diff-active));
        }
        
        &::before {
            transform: scale(1);
            transform-origin: initial;
            clip-path: none;
            border-radius: 50%;
            transition: var(--standard-transition);
        }
        
        &:checked {
            background-color: var(--c-chb-switch-checked);
            
            --checked-position: calc(
                var(--chb-switch-width)
                - var(--chb-switch-padding) * 2
                - var(--chb-indicator-size)
            );
            
            &::before {
                transform: translateX(var(--checked-position));
            }
            
            &:active::before {
                --checked-position: calc(
                    var(--chb-switch-width)
                    - var(--chb-switch-padding) * 2
                    - var(--chb-indicator-size)
                    - var(--switch-width-diff-active)
                );
            }
        }
    }
}
.v2-layout {
    .info-section {
        --c-info-section-bg: var(--c-main-blue-bg);
        --c-info-section: var(--c-main-blue);
        
        text-align: center;
        margin-top: var(--input-vertical-padding);
        padding: var(--content-padding);
        border-radius: var(--standard-curve);
        
        background-color: var(--c-info-section-bg);
        .asvg {
            stroke: none;
            fill: var(--c-info-section);
        }
        
        &.warning {
            --c-info-section: var(--c-main-yellow);
            --c-info-section-bg: var(--c-main-yellow-bg);
        }
        
        &.danger {
            --c-info-section: var(--c-context-error-delete);
            --c-info-section-bg: var(--c-main-red-bg);
        }
    }
}
.v2-layout {
    hr {
        height: var(--module);
        border: 0;
        border-bottom: 1px solid var(--c-context-background);
        margin: 0;
        width: 100%;
        box-sizing: border-box;
        
        &.breadcrumb-menu-hr {
            width: calc(100% + var(--two-modules));
            transform: translateX(calc(var(--module) * -1));
            margin-bottom: var(--module);
        }
    }
}
.v2-layout {
    .opex-hint {
        --opex-hint-size: var(--three-modules);
        width: var(--opex-hint-size);
        height: var(--opex-hint-size);
        cursor: pointer;
        position: absolute;
        
        &.old-hint {
            transform: translateX(-50%) translateY(-50%);
        }
        
        .opex-hint-inside-circle,
        .opex-hint-outside-circle {
            width: 100%;
            height: 100%;
            border-radius: 50%;
            position: absolute;
            top: 0;
            bottom: 0;
            left: 0;
            right: 0;
            background-color: var(--c-main-company);
            animation: 2s ease-out infinite;
        }
        
        .opex-hint-inside-circle {
            animation-name: opex-hint-inside;
        }
        
        .opex-hint-outside-circle {
            animation-name: opex-hint-outside;
        }
        
        @keyframes opex-hint-inside {
            0% {
                transform: scale(0.25);
                opacity: .7;
            }
            50% {
                transform: scale(0.375);
            }
            100% {
                transform: scale(0.5);
                opacity: .7;
            }
        }
        
        @keyframes opex-hint-outside {
            0% {
                transform: scale(0.625);
                opacity: .1;
            }
            50% {
                transform: scale(0.75);
                opacity: .4;
            }
            100% {
                transform: scale(1);
                opacity: 0;
            }
        }
        
        .speech-bubble {
            visibility: hidden;
            opacity: 0;
            pointer-events: none;
        }
        
        .hint-anchor {
            position: absolute;
            visibility: hidden;
            top: -40vh;
        }
        
        &:has(:target) {
            .speech-bubble {
                visibility: visible;
                opacity: 1;
                pointer-events: auto;
            }
        }
    }
}
.v2-layout {
    .flow-diagram {
        --item-size: calc(var(--module) * 16);
        --item-ident-size: calc(var(--module) * 4);
        --c-item-border: var(--c-main-grey);
        --c-item-bg: var(--c-main-grey-text);
        --c-item: var(--c-context-text-default);
        
        padding: var(--content-padding);
        gap: var(--two-modules);
        
        .flow-diagram-row {
            display: flex;
            
            .flow-diagram-ident {
                width: calc(var(--item-size) - var(--item-ident-size));
            }
            
            .flow-diagram-item {
                width: var(--item-size);
                text-align: center;
                
                border: 1px solid var(--c-item-border);
                border-radius: var(--standard-curve);
                background-color: var(--c-item-bg);
                color: var(--c-item);
                
                &.blue {
                    --c-item-border: var(--c-main-blue);
                    --c-item-bg: var(--c-main-blue-bg);
                }
                &.red {
                    --c-item-border: var(--c-main-red);
                    --c-item-bg: var(--c-main-red-bg);
                }
                &.yellow {
                    --c-item-border: var(--c-main-yellow);
                    --c-item-bg: var(--c-main-yellow-bg);
                }
                &.green {
                    --c-item-border: var(--c-main-green);
                    --c-item-bg: var(--c-main-green-bg);
                }
                &.purple {
                    --c-item-border: var(--c-sup-purple);
                    --c-item-bg: var(--c-sup-purple-bg);
                }
                &.red-yellow {
                    --c-item-border: var(--c-main-red);
                    --c-item-bg: var(--c-main-yellow-bg);
                }
            }
            
            .flow-diagram-desc {
                font: var(--font-caption-1);
                line-height: var(--text-line-height);
                margin-left: var(--content-padding);
            }
        }
    }
}
.v2-layout {
    .flipper {
        
        --flipper-duration: 1s;
        perspective: 200vw;
        
        .flipper-front {
            visibility: visible;
            height: unset;
            &.flip {
                animation: closing-flip-effect var(--flipper-duration) linear;
                visibility: hidden;
                height: 0;
                > * {
                    /* children with margin will still be calculated, because height: 0 doesn't affect margins...
                    // This is dirty but handling top-level margins, although there is some flicker
                    // Better avoid margin in the components...*/
                    margin-top: 0;
                    margin-bottom: 0;
                }
            }
            
            &.fullflip {
                animation: opening-flip-effect var(--flipper-duration) linear;
            }
        }
        
        .flipper-back {
            visibility: hidden;
            height: 0;
            &.flip {
                animation: opening-flip-effect var(--flipper-duration) linear;
                visibility: visible;
                height: unset;
            }
            &.fullflip {
                animation: closing-flip-effect var(--flipper-duration) linear;
            }
        }
    }
    
    
    @keyframes closing-flip-effect {
        0% {
            transform: rotateY(0deg);
            visibility: visible;
            height: unset;
        }
        49% {
            transform: rotateY(90deg);
            visibility: visible;
            height: unset;
        }
        50% {
            visibility: hidden;
            height: 0;
        }
    }
    
    @keyframes opening-flip-effect {
        0% {
            transform: rotateY(270deg);
            visibility: hidden;
            height: 0;
        }
        50% {
            transform: rotateY(270deg);
            visibility: hidden;
            height: 0;
        }
        51% {
            transform: rotateY(270deg);
            visibility: visible;
            height: unset;
        }
        100% {
            transform: rotateY(360deg);
            visibility: visible;
            height: unset;
        }
    }
}
.v2-layout {
    .file-upload-container {
        position: relative;
    }
    .file-upload {
        --c-file-upload-bg: transparent;
        
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 1;
        
        background: var(--c-file-upload-bg);
        transition: var(--standard-transition);
        .file-upload-message {
            opacity: 0;
        }
        
        &:not(.disabled):hover {
            background: var(--dimmed-bg);
            cursor: pointer;
            .file-upload-message {
                opacity: 1;
            }
        }
        
        display: flex;
        flex-direction: column;
        justify-content: center;
        
        .file-upload-message {
            margin: auto;
            color: var(--c-context-active-element);
            font: var(--font-button);
        }
    }
    
    .file-upload,
    .op-file-upload {
        .file-upload-input {
            width: 0.1px;
            height: 0.1px;
            opacity: 0;
            overflow: hidden;
            position: absolute;
            z-index: -1;
        }
    }
}
.v2-layout {
    .emptiness {
        margin: auto;
        
        display: flex;
        flex-direction: column;
        
        .emptiness-pic {
            width: calc(var(--module) * 8);
            height: calc(var(--module) * 8);
            margin: 0 auto;
        }
    
        .emptiness-message {
            color: var(--c-main-grey);
            text-align: center;
            margin-top: var(--module);
        }
    }
}
.v2-layout .chip {
    --c-chip: var(--c-main-company);
    --c-chip-text: var(--c-main-company-text);
    --chip-size: var(--two-modules);
    --chip-icon-padding: var(--atom);

    font: var(--font-caption-2);
    line-height: var(--chip-size);

    --asvg-height: calc(var(--chip-size) - var(--chip-icon-padding) * 2);
    .asvg {
        margin-top: var(--chip-icon-padding);
    }

    background-color: var(--c-chip);
    color: var(--c-chip-text);

    padding: 0 var(--content-padding);
    border-radius: var(--standard-curve);
    width: fit-content;
    justify-content: center;

    &.chip-indifferent {
        --c-chip: var(--c-main-grey);
        --c-chip-text: var(--c-main-grey-text);
    }

    &.chip-great {
        --c-chip: var(--c-context-positive-add);
        --c-chip-text: var(--c-context-positive-add-text);
    }

    &.chip-not-great {
        --c-chip: var(--c-context-error-delete);
        --c-chip-text: var(--c-context-error-delete-text);
    }

    &.chip-warning {
        --c-chip: var(--c-context-warning);
        --c-chip-text: var(--c-context-warning-text);
    }

    &.chip-informative {
        --c-chip: var(--c-main-blue);
        --c-chip-text: var(--c-main-blue-text);
    }
}
.v2-layout {
    .button-group {
        display: flex;
        
        &.button-group-equals .button {
            flex: 1;
        }
        
        .button {
            --button-curve: 0;
            
            &:first-child {
                border-top-left-radius: var(--standard-curve);
                border-bottom-left-radius: var(--standard-curve);
            }
    
            &:last-child {
                border-top-right-radius: var(--standard-curve);
                border-bottom-right-radius: var(--standard-curve);
            }
        }
    }
}
.v2-layout {
    .button {
    
        --input-tab_padding: var(--module);/*calc(var(--atom) * 2);*/
        --button-curve: var(--standard-curve);
        --button-color: var(--c-context-active-element);
        --button-text-color: var(--c-context-active-element-text);
        --button-border-color: transparent;
        --button-hover-filter: saturate(140%);
        
        height: var(--input-actual-height);
        margin-top: var(--input-vertical-padding);
        border-radius: var(--button-curve);
        display: flex;
        padding-left: var(--input-tab_padding);
        padding-right: var(--input-tab_padding);
        gap: var(--couple-atoms);
        font: var(--font-button);
        background-color: var(--button-color);
        color: var(--button-text-color);
        cursor: pointer;
        text-decoration: none;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        border: 1px solid var(--button-border-color);

        &:hover {
            filter: var(--button-hover-filter);
        }
        
        .button-text {
            margin: auto;
        }
        
        --button-img-margin: var(--atom);
        --button-img-size: calc(var(--input-actual-height) - var(--button-img-margin) * 2);
        
        .button-img {
            --asvg-height: var(--button-img-size);
            --asvg-width: var(--button-img-size);
            margin-top: var(--button-img-margin);
            stroke: var(--button-text-color);
            fill: var(--button-text-color);
        }
        
        &.center {
            .button-img {
                margin-left: auto;
            }
            .button-text {
                margin-left: 0;
            }
        }

        &.darker {
            --button-color: var(--c-main-blue);
            --button-text-color: var(--c-main-blue-text);
        }

        &.danger {
            --button-color: var(--c-context-error-delete);
            --button-text-color: var(--c-context-error-delete-text);
        }

        &.warn {
            --button-color: var(--c-context-warning);
            --button-text-color: var(--c-context-warning-text);
        }

        &.great {
            --button-color: var(--c-context-positive-add);
            --button-text-color: var(--c-context-positive-add-text);
        }

        &.inactive {
            --button-color: var(--c-main-grey);
            --button-text-color: var(--c-main-grey-text);
        }
        
        &.white {
            --button-color: var(--c-context-content-background);
            --button-text-color: var(--c-context-text-default);
        }

        &.hover-default:hover {
            --button-color: var(--c-context-active-element);
            --button-text-color: var(--c-context-active-element-text);
        }
        
        &.alink,
        &.wired:not(:hover) {
            --alink-color: var(--button-color);
            
            color: var(--alink-color);
    
            .button-img {
                stroke: var(--alink-color);
                fill: var(--alink-color);
            }
        }
        
        &.alink {
            background-color: transparent;
            --input-tab_padding: 0;

            &:hover {
                text-decoration: underline;
            }
        }

        &.wired {
            --button-hover-filter: none;
        }
    
        &.wired:not(:hover) {
            --button-border-color: var(--button-color);
            background-color: var(--c-context-content-background);
        }
        
        &.bordered {
            --button-border-color:  var(--button-text-color);
        }
        
        &.inline {
            height: var(--two-modules);
            margin-top: 0;
        }
        
        &.hidden {
            display: none;
        }
    }
}
.v2-layout {
    .box {
        --box-accent: var(--c-context-active-element);
        --box-accent-text: var(--c-context-active-element-text);
        
        border: 1px solid var(--box-accent);
        border-radius: var(--standard-curve);
        
        .box-title {
            background-color: var(--box-accent);
            color: var(--box-accent-text);
        }
        
        .box-content {
            padding: var(--content-padding);
        }
        
        &.great {
            --box-accent: var(--c-main-green);
            --box-accent-text: var(--c-main-green-text);
        }
    }
}
.v2-layout {
    .big-header {
        font: var(--font-title-1);
    }
    .big-header2 {
        font: var(--font-title-2);
    }
    .big-header3 {
        font: var(--font-title-3);
    }
    .big-header4 {
        font: var(--font-title-4);
    }
}
.v2-layout {
    .banner {
        --c-banner: var(--c-context-active-element);
        --c-text-banner: var(--c-context-active-element-text);

        &.success {
            --c-banner: var(--c-context-positive-add);
            --c-text-banner: var(--c-context-positive-add-text);
        }
        &.attention {
            --c-banner: var(--c-context-warning);
            --c-text-banner: var(--c-context-warning-text);
        }
        &.disaster {
            --c-banner: var(--c-context-error-delete);
            --c-text-banner: var(--c-context-error-delete-text);
        }
        &.plain {
            --c-banner: var(--c-sup-grey);
            --c-text-banner: var(--c-main-grey-text);
        }
        &.asSection {
            --c-banner: var(--c-context-content-background);
            --c-text-banner: var(--c-context-text-default);
        }

        
        background-color: var(--c-banner);
        border-radius: var(--module);
        text-align: center;
        color: var(--c-text-banner);
        padding: var(--content-padding);
        
        .banner-title {
            font: var(--font-title-4);
        }
        
        .banner-subtitle {
            font: var(--font-caption-2);
        }
        
        .button {
            --button-color: var(--c-banner);
        }
        
        .asvg {
            fill: var(--c-text-banner);
            stroke: var(--c-text-banner);
        }
    }
}
.v2-layout {
    --asvg-height: var(--two-modules);
    --asvg-width: var(--two-modules);
    
    .asvg {
        --c-asvg-clickable: var(--c-context-active-element);
        
        height: var(--asvg-height);
        svg {
            width: var(--asvg-width);
            height: var(--asvg-height);
        }
        
        &.as-input {
            margin-top: var(--input-vertical-padding);
        }
        
        &.clickable {
            cursor: pointer;
            &:hover {
                color: var(--c-asvg-clickable);
            }
            transition: var(--standard-transition);
        }
    }
}
.v2-layout.login-page,
.v2-layout.reset-password,
.v2-layout.user-activation,
.v2-layout.buyer-login {
    
    .login-page-form-carrier {
        position: absolute;
        z-index: 1;
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
        
        display: flex;
        
        .login-page-column {
            margin: auto;
    
            .links-container {
                color: white;
                display: flex;
            }
    
            .login-page-form {
                width: calc(var(--module) * 48);
                display: flex;
                --accent-transparent: hsla(var(--h-accent), var(--s-main), var(--l-main), 0.7);
                --accent-transparent-more: hsla(var(--h-accent), var(--s-main), var(--l-main), 0.85);

                .default-logo {
                    margin: 0 auto;
                    --asvg-height: calc(var(--module) * 7);
                    --asvg-width: 100%;
                }

                .message-container,
                .info-container,
                .form-container {
                    flex: 1;
                    padding: calc(var(--module) * 5) var(--two-modules);
                    display: flex;
                    flex-direction: column;
                    
                    &.unbound {
                        flex: unset;
                    }
                }

                .message-container {
                    background-color: var(--accent-transparent);
                    color: white;

                    .message-container-message {
                        font: var(--font-title-4);
                        line-height: var(--module);
                        padding-top: var(--module);
                    }

                    .message-container-buttons {
                        padding-top: var(--three-modules);
                        padding-bottom: var(--two-modules);

                        .button {
                            font: var(--font-caption-1);
                            --input-tab_padding: var(--two-modules);
                        }
                    }
                }
        
                .info-container {
                    background-color: var(--accent-transparent);
                    color: white;
                    border-right: 1px solid var(--c-main-company-bg);

                    .info-container-title {
                        font: var(--font-title-3);
                    }

                    .info-container-content {
                        line-height: var(--module);
                        padding-top: var(--two-modules);

                        .info-container-rules-title {
                            padding-top: var(--module)
                        }

                        .info-container-rules-list {
                            padding-top: var(--module);
                            padding-left: var(--two-modules)
                        }
                    }
                }
        
                .form-container {
                    background-color: var(--accent-transparent-more);
                    color: white;
            
                    .button {
                        font: var(--font-caption-1);
                        --input-tab_padding: var(--two-modules);
                    }
            
                    .forgot-pass {
                        padding-left: 0;
                    }
            
            
                    .lds-ring {
                        width: var(--two-modules);
                        height: var(--two-modules);
                        position: absolute;
                        top: var(--input-vertical-padding);
                    }
            
                    .lds-ring div {
                        box-sizing: border-box;
                        display: block;
                        position: absolute;
                        width: var(--module);
                        height: var(--module);
                        margin: 10px;
                        border: 2px solid;
                        border-radius: 50%;
                        animation: lds-ring 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
                        border-color: white transparent transparent transparent;
                    }
            
                    .lds-ring div:nth-child(1) {
                        animation-delay: -0.45s;
                    }
            
                    .lds-ring div:nth-child(2) {
                        animation-delay: -0.3s;
                    }
            
                    .lds-ring div:nth-child(3) {
                        animation-delay: -0.15s;
                    }
                    @keyframes lds-ring {
                        0% {
                            transform: rotate(0deg);
                        }
                        100% {
                            transform: rotate(360deg);
                        }
                    }
                }
            }
        }
    }
    
    .buyer-login-code {
        border: 1px solid var(--c-context-error-delete);
        height: var(--input-actual-height);
        margin-top: var(--input-vertical-padding);
        font: var(--font-title-3);
        text-align: center;
        border-radius: var(--standard-curve);
        
        &.valid {
            border-color: var(--c-context-positive-add);
        }
    }

    &.login-page-admin .login-page-form-carrier .login-page-column .login-page-form{
        --accent-transparent: hsla(var(--h-main-yellow), var(--s-main), var(--l-main), 0.7);
        --accent-transparent-more: hsla(var(--h-main-yellow), var(--s-main), var(--l-main), 0.85);
    }
}
body:has(.flows-list) .leader-line {
    z-index: 1000;
}

.v2-layout {
    .palette-display {
      display: flex;
      border: 1px solid var(--c-context-text-default);

      & > div {
        min-height: var(--four-modules);
        flex: 1;

        &.black {
          background-color: var(--c-main-black);
        }
        &.company {
          background-color: var(--c-main-company);
        }
        &.grey {
          background-color: var(--c-sup-grey);
        }
        &.red {
          background-color: var(--c-main-red);
        }
        &.green {
          background-color: var(--c-main-green);
        }
        &.blue {
          background-color: var(--c-main-teal);
        }
        &.yellow {
          background-color: var(--c-main-yellow);
        }
      }

    }
}
.v2-layout.change-password:not(.editMode)  {
    
    .page {
        background-color: var(--c-main-green-bg);
    }
}
@keyframes best-face-animation {
    25%, 75% {
        stroke: var(--c-main-yellow);
    }
    36%, 64% {
        stroke: var(--c-main-green);
    }
    45%, 55% {
        stroke: var(--c-main-blue);
    }
}

.v2-layout.about {
    .about-authors {
        a {
            display: flex;
            gap: var(--module);
        }
        
        font: var(--font-title-4);
        
        .about-face-1 {
            stroke: var(--c-main-company);
        }
        .about-face-2 {
            stroke: var(--c-main-green);
        }
        .about-face-3 {
            stroke: var(--c-main-red);
            animation: best-face-animation 3s linear infinite 0s;;
        }
        .about-face-4 {
            stroke: var(--c-main-yellow);
        }
        .about-face-5 {
            stroke: var(--c-main-red);
        }
    }
    
    .about-dragon {
        cursor: pointer;
        --asvg-height: calc(var(--module) * 6);
    }
}
