.button-row,
.button-group {
    position: relative;
}
.button-row {
    display: flex;
    width: 100%;
    /* width: calc(100% + 20px);
    margin: 0 -10px; */
}
.button-row.center {
    justify-content: center;  
}
.button-row.left {
    justify-content: flex-start;  
}
.button-row.right {
    justify-content: flex-end;  
}
/* .button-row>.button {
    margin: 0 10px;
} */
.button-group {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -10px;
    /* margin-left: -5px;
    margin-right: -5px; */
}
.button-group>.button {
    margin: 0 10px;
}

.button-group.min-space {
    margin: 0 -5px;
}
.button-group.min-space>.button {
    margin: 0 5px;
}

/* ============================================================================================== */
/* ========================================= btn customize ====================================== */
/* ============================================================================================== */

.button {
    position: relative;
    display: inline-flex;
    flex-wrap: nowrap;
    flex-direction: row;
    /* align-items: baseline; */
    align-items: center;
    justify-content: center;
    height: var(--cpn-btn-height);
    font-size: 15px;
    line-height: var(--cpn-btn-line-height);
    font-weight: 500;
    padding: 0 20px;
    border-radius: var(--cpn-btn-border-radius);
    border: none;
    outline: none !important;
    text-decoration: none !important;
    text-shadow: none !important;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -ms-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}
.button.disable {
    cursor: no-drop !important;
}
.button.clear {
    line-height: initial !important;
    height: auto !important;
    width: auto !important;
    padding: 0;
    color:  rgba(var(--cpn-color-black),1);
}

.button.w-min-50 {
    min-width: 50px;
}
.button.w-min-60 {
    min-width: 60px;
}
.button.w-min-70 {
    min-width: 70px;
}
.button.w-min-80 {
    min-width: 80px;
}
.button.w-min-90 {
    min-width: 90px;
}
.button.w-min-100 {
    min-width: 100px;
}
.button.w-min-110 {
    min-width: 110px;
}
.button.w-min-120 {
    min-width: 120px;
}
.button.w-min-130 {
    min-width: 130px;
}
.button.w-min-140 {
    min-width: 140px;
}
.button.w-min-150 {
    min-width: 150px;
}
.button.w-min-160 {
    min-width: 160px;
}
.button.w-min-170 {
    min-width: 170px;
}
.button.w-min-180 {
    min-width: 180px;
}
.button.w-min-190 {
    min-width: 190px;
}
.button.w-min-200 {
    min-width: 200px;
}
.button.w-min-250 {
    min-width: 250px;
}
.button.w-min-300 {
    min-width: 300px;
}

.button .icon {
    font-size: 20px;
    height: initial;
}
.button .icon[class*="cpn-icon-"],
.button .icon[class*="cpn-basic-icon-"] {
    height: 0;
}
.button .icon+.text,
.button .text+.icon {
    margin-left: 10px;
}
.button.button-more {
    font-weight: initial !important;
}
.button-more {
    position: relative;
    display: inline-flex;
    flex-wrap: nowrap;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    outline: none !important;
    text-decoration: none !important;
    text-shadow: none !important;
    font-weight: 600;
    color: rgba(var(--cpn-color-black),1);
}
.button-more .icon {
    font-size: 10px !important;
    margin-left: 5px !important;
    height: initial !important;
}

[data-btn-loading] {
    cursor: no-drop !important;
}
[data-btn-loading] .icon-loading {
	animation: buttonIconLoading 1s infinite linear;
    height: 0 !important;
}
[data-btn-loading] .icon-loading.opacity {
    opacity: 0.3;
}
@keyframes buttonIconLoading {
    100% {
       transform: rotate(1turn);
    }
}

/* --------------------------------------------------------------- */
/* ------------------------- btn fill ---------------------------- */
/* --------------------------------------------------------------- */

/* white */
.fill-color-white {
    background-color: rgba(var(--cpn-btn-bg),1);
    color: rgba(var(--cpn-btn-color),1);
}
.fill-color-white:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.fill-color-white:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* black */
.fill-color-black {
    background-color: rgba(var(--cpn-btn-bg),1);
    color: rgba(var(--cpn-btn-color),1);
}
.fill-color-black:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.fill-color-black:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* gray */
.fill-color-gray {
    background-color: rgba(var(--cpn-btn-bg),1);
    color: rgba(var(--cpn-btn-color),1);
}
.fill-color-gray:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.fill-color-gray:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* gray light */
.fill-color-gray-light {
    background-color: rgba(var(--cpn-btn-bg),1);
    color: rgba(var(--cpn-btn-color),1);
}
.fill-color-gray-light:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.fill-color-gray-light:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* primary */
.fill-color-primary {
    background-color: rgba(var(--cpn-btn-bg),1);
    color: rgba(var(--cpn-btn-color),1);
}
.fill-color-primary:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.fill-color-primary:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* primary light */
.fill-color-primary-light {
    background-color: rgba(var(--cpn-btn-bg),1);
    color: rgba(var(--cpn-btn-color),1);
}
.fill-color-primary-light:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.fill-color-primary-light:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* secondary */
.fill-color-secondary {
    background-color: rgba(var(--cpn-btn-bg),1);
    color: rgba(var(--cpn-btn-color),1);
}
.fill-color-secondary:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.fill-color-secondary:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* secondary light */
.fill-color-secondary-light {
    background-color: rgba(var(--cpn-btn-bg),1);
    color: rgba(var(--cpn-btn-color),1);
}
.fill-color-secondary-light:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.fill-color-secondary-light:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* --------------------------------------------------------------- */
/* -------------------- btn - tag outline ------------------------ */
/* --------------------------------------------------------------- */

.button[class*="outline-"],
.tag-item[class*="outline-"] {
    border-width: 1px;
    border-style: solid;
}

/* white */
.outline-color-white {
    background-color: rgba(var(--cpn-btn-bg),0);
    border-color: rgba(var(--cpn-btn-border-color),1);
    color: rgba(var(--cpn-btn-color),1);
}
.outline-color-white:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    border-color: rgba(var(--cpn-btn-hover-border-color),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.outline-color-white:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    border-color: rgba(var(--cpn-btn-active-border-color),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* black */
.outline-color-black {
    background-color: rgba(var(--cpn-btn-bg),0);
    border-color: rgba(var(--cpn-btn-border-color),1);
    color: rgba(var(--cpn-btn-color),1);
}
.outline-color-black:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    border-color: rgba(var(--cpn-btn-hover-border-color),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.outline-color-black:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    border-color: rgba(var(--cpn-btn-active-border-color),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* gray */
.outline-color-gray:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    border-color: rgba(var(--cpn-btn-hover-border-color),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.outline-color-gray:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    border-color: rgba(var(--cpn-btn-active-border-color),1);
    color: rgba(var(--cpn-btn-active-color),1);
}
.outline-color-gray,
.outline-color-gray.none-hover {
    background-color: rgba(var(--cpn-btn-bg),0);
    border-color: rgba(var(--cpn-btn-border-color),1);
    color: rgba(var(--cpn-btn-color),1);
}

/* gray light */
.outline-color-gray-light {
    background-color: rgba(var(--cpn-btn-bg),0);
    border-color: rgba(var(--cpn-btn-border-color),1);
    color: rgba(var(--cpn-btn-color),1);
}
.outline-color-gray-light:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    border-color: rgba(var(--cpn-btn-hover-border-color),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.outline-color-gray-light:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    border-color: rgba(var(--cpn-btn-active-border-color),1);
    color: rgba(var(--cpn-btn-active-color),1);
}


/* primary */
.outline-color-primary {
    background-color: rgba(var(--cpn-btn-bg),0);
    border-color: rgba(var(--cpn-btn-border-color),1);
    color: rgba(var(--cpn-btn-color),1);
}
.outline-color-primary:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    border-color: rgba(var(--cpn-btn-hover-border-color),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.outline-color-primary:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    border-color: rgba(var(--cpn-btn-active-border-color),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* primary-light */
.outline-color-primary-light {
    background-color: rgba(var(--cpn-btn-bg),0);
    border-color: rgba(var(--cpn-btn-border-color),1);
    color: rgba(var(--cpn-btn-color),1);
}
.outline-color-primary-light:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    border-color: rgba(var(--cpn-btn-hover-border-color),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.outline-color-primary-light:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    border-color: rgba(var(--cpn-btn-active-border-color),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* secondary */
.outline-color-secondary {
    background-color: rgba(var(--cpn-btn-bg),0);
    border-color: rgba(var(--cpn-btn-border-color),1);
    color: rgba(var(--cpn-btn-color),1);
}
.outline-color-secondary:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    border-color: rgba(var(--cpn-btn-hover-border-color),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.outline-color-secondary:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    border-color: rgba(var(--cpn-btn-active-border-color),1);
    color: rgba(var(--cpn-btn-active-color),1);
}

/* secondary-light */
.outline-color-secondary-light {
    background-color: rgba(var(--cpn-btn-bg),0);
    border-color: rgba(var(--cpn-btn-border-color),1);
    color: rgba(var(--cpn-btn-color),1);
}
.outline-color-secondary-light:hover {
    background-color: rgba(var(--cpn-btn-hover-bg),1);
    border-color: rgba(var(--cpn-btn-hover-border-color),1);
    color: rgba(var(--cpn-btn-hover-color),1);
}
.outline-color-secondary-light:active {
    background-color: rgba(var(--cpn-btn-active-bg),1);
    border-color: rgba(var(--cpn-btn-active-border-color),1);
    color: rgba(var(--cpn-btn-active-color),1);
}


/* ============================================================================================== */
/* ========================================= btn icon + text ==================================== */
/* ============================================================================================== */

.button-text-group {
    position: relative;
    display: flex;
    flex-wrap: nowrap;
}
ul.button-text-group,
ul.button-text-group>li {
    list-style: none;
    padding: 0;
    margin: 0;
}
ul.button-text-group>li {
    position: relative;
    display: flex;
}
ul.button-text-group>li+li {
    margin-left: 20px;
    padding-left: 20px;
}
ul.button-text-group>li+li:before {
    position: absolute;
    content: "";
    border-left: 1px solid rgba(var(--cpn-color-black),0.5);
    height: 20px;
    top: 50%;
    left: 0;
    margin-top: -10px;
}


.button-text-item {
    position: relative;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    cursor: pointer;
    outline: none;
    border: none;
    text-decoration: none;
}
.button-text-item>.icon,
.button-text-item>.text {
    position: relative;
}
.button-text-item>.icon {
    font-size: 120%;
    height: 0;
}
.button-text-item>.icon+.text {
    margin-left: 5px;
}

/* ============================================================================================== */
/* ============================================ btn close ======================================= */
/* ============================================================================================== */

.btn-close {
    background: none;
    border-radius: 0;
    opacity: 1 !important;
    cursor: pointer !important;
    outline: none !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important; 
    margin: 0 !important;
    width: 35px;
    height: 35px;
    font-size: 20px;
    line-height: 35px;
}
.btn-close.hover-opacity {
    opacity: .3 !important;
    transition: opacity .3s ease;
    -webkit-transition: opacity .3s ease;
    -moz-transition: opacity .3s ease;
    -ms-transition: opacity .3s ease;
    -o-transition: opacity .3s ease;
}
.btn-close.hover-opacity:hover {
    opacity: 1 !important;
}

.btn-close.black {
    color: rgba(var(--cpn-color-black),1);
}
.btn-close.white {
    color: rgba(var(--cpn-color-white),1);
}

/* bg */
/* .btn-close[class*="bg-"] {
    border-radius: 100% !important;
}
.btn-close.bg-white {
    background-color: rgba(var(--cpn-color-black),1) !important;
}
.btn-close.bg-gray {
    background-color: rgba(var(--custom-rgb-color-gray),1) !important;
}
.btn-close.bg-gray-light {
    background-color: rgba(var(--custom-rgb-color-gray-light),1) !important;
} */

/* ============================================================================================== */
/* ========================================= btn circle ========================================= */
/* ============================================================================================== */

.button-circle,
.button-circle-hover {
    width: 35px;
    height: 35px;
    border-radius: 100%;    
}
.button-circle-hover[class*="black"]:hover {
    background-color: rgba(var(--cpn-color-black),0.1);
}
.button-circle>.icon,
.button-circle-hover>.icon {
    height: 0;
}

/* ============================================================================================== */
/* ============================================= tag ============================================ */
/* ============================================================================================== */

.tag-item-row,
.tag-item-group,
.tag-item {
    position: relative;
}
.tag-item-group {
    display: flex;
    align-self: flex-start;
    flex-wrap: wrap;
    width: calc(100% + 5px);
    margin-left: -2.5px;
    margin-right: -2.5px;
}
.tag-item-group>.tag-item {
    height: 30px;
    line-height: 30px;
    padding: 0 10px;
    margin: 2.5px;
}

.tag-item {
    display: flex;
    align-items: center;
    max-width: 100%;
    text-decoration: none !important;
    outline: none !important;
    /* text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden; */
    border-radius: 10px;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -ms-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}
.tag-item[class*="tag-outline"] {
}
.tag-item>.text {
    text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
}

/* ============================================================================================== */
/* =========================================== social =========================================== */
/* ============================================================================================== */

/* facebook */
.fill-social-facebook {
    background-color: rgba(var(--social-facebook-color),1) !important;
    color: rgba(var(--social-facebook-on-color),1) !important;
}
.fill-social-facebook:hover {
    background-color: rgba(var(--social-facebook-color-hover),1) !important;
}

/* messenger */
.fill-social-messenger {
    background-color: rgba(var(--social-messenger-color),1) !important;
    color: rgba(var(--social-messenger-on-color),1) !important;
}
.fill-social-messenger:hover {
    background-color: rgba(var(--social-messenger-color-hover),1) !important;
}

/* instagram */
.fill-social-instagram {
    background-color: rgba(var(--social-instagram-color),1) !important;
    color: rgba(var(--social-instagram-on-color),1) !important;
}
.fill-social-instagram:hover {
    background-color: rgba(var(--social-instagram-color-hover),1) !important;
}

/* tiktok */
.fill-social-tiktok {
    background-color: rgba(var(--social-tiktok-color),1) !important;
    color: rgba(var(--social-tiktok-on-color),1) !important;
}
.fill-social-tiktok:hover {
    background-color: rgba(var(--social-tiktok-color-hover),1) !important;
}

/* youtube */
.fill-social-youtube {
    background-color: rgba(var(--social-youtube-color),1) !important;
    color: rgba(var(--social-youtube-on-color),1) !important;
}
.fill-social-youtube:hover {
    background-color: rgba(var(--social-youtube-color-hover),1) !important;
}

/* line */
.fill-social-line {
    background-color: rgba(var(--social-line-color),1) !important;
    color: rgba(var(--social-line-on-color),1) !important;
}
.fill-social-line:hover {
    background-color: rgba(var(--social-line-color-hover),1) !important;
}

/* xxl */
@media (min-width: 1400px) {}

/* xxl - 1 */
@media (min-width:1500px) and (max-width: 1599.98px) {}

/* xxl - 2 */
@media (min-width: 1400px) and (max-width: 1499.98px) {}

/* xl */
@media (min-width: 1200px) and (max-width: 1399.98px) {}

/* lg */
@media (min-width: 992px) and (max-width: 1199.98px) {}

/* md */
@media (min-width: 768px) and (max-width: 991.98px) {}

/* sm - xs */
@media (max-width: 767.98px) {}

/* sm */
@media (min-width: 576px) and (max-width: 767.98px) {

    .button-group.w-flex-sm {
        flex-wrap: nowrap;
    }
    .button-group.w-flex-sm,
    .button.w-flex-sm {
        min-width: 0;
        flex: 1 0 0;
    }

}

/* xs */
@media (max-width: 575.98px) {

    .button-group {
        margin: 0 -5px;
    }
    .button-group>.button {
        margin: 0 5px;
    }

    .button-group.w-flex-xs {
        flex-wrap: nowrap;
    }
    .button-group.w-flex-xs,
    .button.w-flex-xs {
        min-width: 0;
        flex: 1 0 0;
    }
    .button.w-full-xs {
        width: 100%;
    }

    /* break xs */
    .button-group.break-xs {
        flex-wrap: wrap;
        width: 100%;
    }
    .button-group.break-xs>.button {
        width: 100%;
        min-width: 0;
        flex: none;
    }
    .button-group.break-xs>.button+.button {
        margin-top: 15px;
    }

}

/* xs custom */
@media (max-width: 399.98px) {}

