.wp-elce {
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 99999;
    font-family: "Source Sans Pro", "Open Sans", Arial, sans-serif;
}
.elce-contact-card {
    width: 285px;
    margin: 0 0 10px 18px;
    padding: 14px 16px 15px;
    color: #ffffff;
    background: #143d2b;
    border: 2px solid #ffc300;
    border-radius: 8px;
    box-shadow: 0 18px 42px rgba(20, 61, 43, .28);
}
.elce-contact-card__title {
    margin-bottom: 8px;
    color: #ffc300;
    font-size: 16px;
    line-height: 1.2;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.elce-contact-card__row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 14px;
    padding: 6px 0;
    border-top: 1px solid rgba(255, 195, 0, .28);
}
.elce-contact-card__row span {
    color: rgba(255,255,255,.82);
    font-size: 14px;
    font-weight: 700;
}
.elce-contact-card__row a,
.elce-contact-card__row strong {
    color: #ffffff;
    font-size: 15px;
    font-weight: 900;
    text-align: right;
    text-decoration: none;
}
.elce-contact-card__row a:hover {
    color: #ffc300;
}
.elce-social-list {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    margin: 0 0 14px 18px;
}
.elce-social-item {
    position: relative;
    display: inline-flex;
    align-items: center;
    min-height: 54px;
    color: #ffffff;
    text-decoration: none;
}
.elce-social-pulse {
    position: absolute;
    left: -7px;
    top: -7px;
    width: 68px;
    height: 68px;
    border-radius: 50%;
    opacity: .68;
    animation: elce-social-zoom 1.6s infinite ease-in-out;
}
.elce-social-icon {
    position: relative;
    z-index: 2;
    width: 54px;
    height: 54px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    box-shadow: 0 10px 24px rgba(0,0,0,.18);
    animation: phone-elce-circle-fill 1s infinite ease-in-out;
}
.elce-social-icon svg {
    width: 31px;
    height: 31px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.elce-social-label {
    z-index: 1;
    display: inline-flex;
    flex-direction: column;
    min-width: 164px;
    margin-left: -8px;
    padding: 8px 12px 8px 18px;
    color: #ffffff;
    background: #143d2b;
    border: 1px solid rgba(255,195,0,.7);
    border-radius: 0 8px 8px 0;
    box-shadow: 0 10px 24px rgba(20,61,43,.2);
}
.elce-social-label strong {
    color: #ffc300;
    font-size: 13px;
    font-weight: 900;
    line-height: 1.1;
    text-transform: uppercase;
}
.elce-social-label em {
    color: #ffffff;
    font-size: 14px;
    font-style: normal;
    font-weight: 800;
    line-height: 1.35;
}
.elce-social-whatsapp .elce-social-icon,
.elce-social-whatsapp .elce-social-pulse {
    color: #fff;
    background: #25D366;
}
.elce-social-wechat .elce-social-icon,
.elce-social-wechat .elce-social-pulse {
    color: #fff;
    background: #09b83e;
}
.elce-social-kakaotalk .elce-social-icon,
.elce-social-kakaotalk .elce-social-pulse {
    color: #3b2a00;
    background: #ffe812;
}
.elce-social-line .elce-social-icon,
.elce-social-line .elce-social-pulse {
    color: #fff;
    background: #06c755;
}
@keyframes elce-social-zoom {
    0% { transform: scale(.78); box-shadow: 0 0 0 0 currentColor; opacity: .35; }
    70% { transform: scale(1); box-shadow: 0 0 0 16px transparent; opacity: .08; }
    100% { transform: scale(.78); box-shadow: 0 0 0 0 transparent; opacity: .25; }
}
.wp-elce .elce-social-contact {
    width: 270px;
    height: 76px;
    margin-bottom: -6px;
}
.wp-elce .elce-social-contact .elce-phone {
    width: 76px;
    height: 76px;
}
.wp-elce .elce-social-contact .elce-phone-circle-fill {
    width: 60px;
    height: 60px;
    top: 8px;
    left: 8px;
}
.wp-elce .elce-social-contact .elce-phone-img-circle {
    width: 42px;
    height: 42px;
    line-height: 42px;
    top: 17px;
    left: 17px;
}
.elce-social-letter {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    color: currentColor;
    font-size: 13px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0;
    text-align: center;
}
.elce-social-caption {
    position: absolute;
    left: 72px;
    top: 15px;
    z-index: 1;
    min-width: 150px;
    padding: 7px 12px 7px 15px;
    color: #ffffff;
    background: #143d2b;
    border: 1px solid rgba(255,195,0,.65);
    border-radius: 0 8px 8px 0;
    box-shadow: 0 8px 20px rgba(20,61,43,.18);
    text-decoration: none;
}
.elce-social-caption strong,
.elce-social-caption span {
    display: block;
    color: inherit;
    line-height: 1.2;
}
.elce-social-caption strong {
    color: #ffc300;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}
.elce-social-caption span {
    color: #ffffff;
    font-size: 13px;
    font-weight: 800;
}
#elce-whatsapp .elce-phone-circle-fill,
#elce-whatsapp .elce-phone-img-circle {
    color: #fff;
    background-color: #25d366;
    box-shadow: 0 0 0 0 #25d366;
}
#elce-wechat .elce-phone-circle-fill,
#elce-wechat .elce-phone-img-circle {
    color: #fff;
    background-color: #09b83e;
    box-shadow: 0 0 0 0 #09b83e;
}
#elce-kakaotalk .elce-phone-circle-fill,
#elce-kakaotalk .elce-phone-img-circle {
    color: #3b2a00;
    background-color: #ffe812;
    box-shadow: 0 0 0 0 #ffe812;
}
#elce-line .elce-phone-circle-fill,
#elce-line .elce-phone-img-circle {
    color: #fff;
    background-color: #06c755;
    box-shadow: 0 0 0 0 #06c755;
}
#elce-line .elce-social-letter {
    font-size: 10px;
}
.wp-elce .elce-social-contact {
    width: 76px;
    height: 76px;
    margin-bottom: -8px;
}
.elce-social-caption,
.elce-social-letter {
    display: none !important;
}
.elce-social-logo {
    max-width: 27px !important;
    max-height: 27px !important;
    width: 27px !important;
    height: 27px !important;
    display: block;
    object-fit: contain;
}
#elce-kakaotalk .elce-social-logo {
    max-width: 24px !important;
    max-height: 24px !important;
    width: 24px !important;
    height: 24px !important;
}
.wp-elce #elce-phone {
    transition: 0.7s all;
    -moz-transition: 0.7s all;
    -webkit-transition: 0.7s all;
}
.wp-elce .elce-contact {
    position: relative;
}
.wp-elce .elce-contact .elce-phone {
    position: relative;
    visibility: visible;
    background-color: transparent;
    width: 90px;
    height: 90px;
    cursor: pointer;
    z-index: 11;
    -webkit-backface-visibility: hidden;
    -webkit-transform: translateZ(0);
    transition: visibility .5s;
    left: 0;
    bottom: 0;
    display: block;
}
.elce-phone-img-circle {
    background-color: #e60808;
    width: 40px;
    height: 40px;
    line-height: 40px;
    top: 25px;
    left: 25px;
    position: absolute;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    -webkit-animation: phonering-alo-circle-img-anim 1s infinite ease-in-out;
    animation: phone-elce-circle-fill 1s infinite ease-in-out;
}
@-webkit-keyframes phone-elce-circle-fill {
    0% {-webkit-transform: rotate(0) scale(1) skew(1deg);  }
    10% {-webkit-transform: rotate(-25deg) scale(1) skew(1deg);}
    20% {-webkit-transform: rotate(25deg) scale(1) skew(1deg);}
    30% {-webkit-transform: rotate(-25deg) scale(1) skew(1deg);}
    40% {-webkit-transform: rotate(25deg) scale(1) skew(1deg);}
    50% {-webkit-transform: rotate(0) scale(1) skew(1deg);}
    100% {-webkit-transform: rotate(0) scale(1) skew(1deg);}
}
@-webkit-keyframes zoom{0%{transform:scale(.9)}70%{transform:scale(1);box-shadow:0 0 0 15px transparent}100%{transform:scale(.9);box-shadow:0 0 0 0 transparent}}@keyframes zoom{0%{transform:scale(.9)}70%{transform:scale(1);box-shadow:0 0 0 15px transparent}100%{transform:scale(.9);box-shadow:0 0 0 0 transparent}}
.elce-phone-img-circle a {
    display: block;
    line-height: 37px;
}
.elce-phone-img-circle img {
    max-height: 25px;
    max-width: 27px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    -moz-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    -o-transform: translate(-50%,-50%);
}
.elce-phone-circle-fill {
    width: 65px;
    height: 65px;
    top: 12px;
    left: 12px;
    position: absolute;
    box-shadow: 0 0 0 0 #c31d1d;
    background-color: rgba(230, 8, 8, 0.7);
    border-radius: 50%;
    border: 2px solid transparent;
    -webkit-animation: phone-elce-circle-fill 2.3s infinite ease-in-out;
    animation: phone-elce-circle-fill 2.3s infinite ease-in-out;
    transition: all .5s;
    -webkit-transform-origin: 50% 50%;
    -ms-transform-origin: 50% 50%;
    transform-origin: 50% 50%;
    -webkit-animuiion: zoom 1.3s infinite;
    animation: zoom 1.3s infinite;
}
.phone-bar.phone-bar-n {
    position: relative;
    visibility: visible;
    background-color: transparent;
    cursor: pointer;
    -webkit-backface-visibility: hidden;
    -webkit-transform: translateZ(0);
    transition: visibility .5s;
    display: block;
}
.phone-bar a {
    position: fixed;
    bottom: 25px;
    left: 30px;
    z-index: -1;
    color: #fff;
    font-size: 16px;
    padding: 8px 15px 7px 50px;
    border-radius: 100px;
    white-space: nowrap;
    text-decoration: none;
    font-weight: bold;
}

/* ZALO */
#elce-zalo .elce-phone-circle-fill {
    box-shadow: 0 0 0 0 #2196f3;
    background-color: rgba(33, 150, 243, 0.7);
}
#elce-zalo .elce-phone-img-circle {
    background-color: #2196F3;
}

/* Messenger */
#elce-messenger .elce-phone-circle-fill {
    box-shadow: 0 0 0 0 #714497;
    background-color: rgba(113, 68, 151, 0.8);
}
#elce-messenger .elce-phone-img-circle {
    background-color: #714497;
}
/* Contact */
#elce-contact .elce-phone-circle-fill {
    opacity: 0.7;
    box-shadow: 0 0 0 0 #79ba2a;
    background-color: #79ba2a;
}
#elce-contact .elce-phone-img-circle {
    background-color: #79ba2a;
}

@media (max-width: 549px) {
    .elce-contact-card {
        width: min(285px, calc(100vw - 32px));
        margin-left: 12px;
        margin-right: 12px;
    }
    .elce-social-list {
        margin-left: 12px;
        margin-right: 12px;
    }
    .elce-social-label {
        min-width: 142px;
    }
    .elce-social-item {
        min-height: 50px;
    }
    .elce-social-icon {
        width: 50px;
        height: 50px;
    }
    .elce-social-pulse {
        width: 64px;
        height: 64px;
    }
}

@media (max-width: 849px) {
    .wp-elce {
        left: 0 !important;
        right: 0 !important;
        bottom: 8px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        pointer-events: none;
    }

    .wp-elce .elce-social-contact {
        width: 54px !important;
        height: 54px !important;
        margin: 0 !important;
        pointer-events: auto;
    }

    .wp-elce .elce-social-contact .elce-phone {
        width: 54px !important;
        height: 54px !important;
    }

    .wp-elce .elce-social-contact .elce-phone-circle-fill {
        width: 52px !important;
        height: 52px !important;
        top: 1px !important;
        left: 1px !important;
    }

    .wp-elce .elce-social-contact .elce-phone-img-circle {
        width: 42px !important;
        height: 42px !important;
        line-height: 42px !important;
        top: 6px !important;
        left: 6px !important;
    }

    .elce-social-logo {
        width: 25px !important;
        height: 25px !important;
        max-width: 25px !important;
        max-height: 25px !important;
    }
}
