/* System Font Stack - No external fonts needed */
/* Using native system fonts for better privacy and performance */

/* CSS Animations */

@keyframes pulse {
    0%, 100% {
        transform: scale(1);
        opacity: 1;
    }
    50% {
        transform: scale(1.1);
        opacity: 0.9;
    }
}

@keyframes float {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-2px);
    }
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

@keyframes tilt {
    0%, 100% {
        transform: rotate(0deg);
    }
    25% {
        transform: rotate(-6deg);
    }
    75% {
        transform: rotate(6deg);
    }
}

:root {
    --bmstwofa-c-brand1: #A13535 !important;
    --bmstwofa-c-brand2: #327E8B !important;
    --bmstwofa-c-white: #ffffff;
    --bmstwofa-c-black: #181818;
    --bmstwofa-c-grey: #dddddd;
    --bmstwofa-c-grey-medium: #aaaaaa;
    --bmstwofa-c-grey-dark: #5E5E5D;
    --bmstwofa-c-grey-light: #F2F2F2;
    --bmstwofa-font-icons: "icomoon";
    --bmstwofa-c-error: #d50303;
    --bmstwofa-c-success: darkgreen;
}

.bsms-captcha {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
    box-sizing: border-box !important;
    position: relative;
    display: block;
    width: 300px !important;
    height: 95px !important;
    min-width: 300px !important;
    min-height: 95px !important;
    max-width: 300px;
    max-height: 95px;
    border: 1px solid var(--bmstwofa-c-grey-medium);
    background: var(--bmstwofa-c-grey-light);
    border-radius: 5px;
    border-bottom: 4px solid var(--bmstwofa-c-brand1);
    margin-top: 20px;
    margin-bottom: 20px;
    padding: 0;
    line-height: 1;
    align-items: flex-start !important;
}

.bsms-captcha * {
    box-sizing: border-box !important;
}

.bsmscaptcha-logo {
    position: absolute;
    right: 30px !important;
    top: 14px !important;
    width: 23px !important;
    height: 27px !important;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 42.92 58.49'><polygon points='0 0 0 30.4 21.46 58.49 42.92 30.4 42.92 0 21.46 16.77 0 0' fill='%23A13535' fill-rule='evenodd'/></svg>") !important;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center !important;
    display: none;
}

.bsmscaptcha-logo:after {
    content: "";
    display: block;
    position: absolute;
    right: -20px;
    bottom: -23px;
    width: 60px;
    height: 20px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 217 40'><path d='M8.73,4.44c0,2.35-1.78,4.08-4.27,4.08S.19,6.79.19,4.44,2.06.41,4.46.41s4.27,1.68,4.27,4.03ZM1,12.6h6.86v26.4H1V12.6Z' fill='%23A13535'/><path d='M39.5,2.04v36.96h-6.87v-3.55c-1.82,2.5-4.61,4.13-8.3,4.13-6.86,0-12.05-5.67-12.05-13.78s5.23-13.78,12-13.78c3.74,0,6.53,1.73,8.35,4.27V2.04h6.87ZM32.63,25.8c0-4.32-2.93-7.25-6.77-7.25s-6.67,2.93-6.67,7.25,2.88,7.25,6.67,7.25,6.77-2.88,6.77-7.25Z' fill='%23A13535'/><path d='M71.08,27.58h-20.26c.43,4.22,3.31,6.34,6.86,6.34,2.64,0,4.94-1.2,5.86-3.31h7.1c-1.97,6.24-7.25,8.98-12.91,8.98-8.26,0-13.92-5.86-13.92-13.73s5.71-13.83,13.78-13.83c8.74,0,14.16,6.87,13.49,15.55ZM51.16,22.54h12.62c-.77-2.88-2.93-4.85-6.24-4.85s-5.52,2.02-6.38,4.85Z' fill='%23A13535'/><path d='M99.8,22.44v16.56h-6.86v-15.07c0-3.46-1.3-5.38-4.94-5.38-3.89,0-5.95,2.26-5.95,6.58v13.87h-6.86V12.6h6.86v3.6c1.92-2.69,4.56-4.18,8.21-4.18,5.95,0,9.55,3.94,9.55,10.42h-.01Z' fill='%23A13535'/><path d='M125,37.47c-1.44.96-4.71,2.11-7.87,2.11-5.28,0-9.89-3.17-9.89-10.75v-9.75h-4.71v-6.48h4.71v-5.71l6.86-1.49v7.2h9.79v6.48h-9.79v9.36c0,3.12,1.49,4.75,4.22,4.75,1.54,0,3.36-.53,5.52-1.3l1.15,5.57h0Z' fill='%23A13535'/><path d='M136.55,4.44c0,2.35-1.78,4.08-4.27,4.08s-4.27-1.73-4.27-4.08,1.87-4.03,4.27-4.03,4.27,1.68,4.27,4.03ZM128.82,12.6h6.86v26.4h-6.86V12.6Z' fill='%23A13535'/><path d='M150.36,12.5v.1h8.79v6.48h-8.79v19.92h-6.86v-19.92h-4.71v-6.48h4.71v-.43c0-7.54,5.28-10.71,10.75-10.71,2.06,0,4.56.43,6.24,1.2l-1.25,5.57-.91-.24c-1.15-.34-2.3-.53-3.31-.53-3.12,0-4.66,1.63-4.66,5.04Z' fill='%23A13535'/><path d='M189.08,25.8c0,7.97-6.05,13.78-13.78,13.78s-13.73-5.86-13.73-13.78,6.14-13.78,13.73-13.78,13.78,5.81,13.78,13.78ZM168.48,25.8c0,4.37,2.98,7.25,6.82,7.25s6.82-2.88,6.82-7.25-2.98-7.25-6.82-7.25-6.82,2.93-6.82,7.25Z' fill='%23A13535'/><path d='M208.65,39l-5.42-8.3-5.14,8.3h-8.26l9.31-13.63-8.83-12.77h8.16l4.99,7.73,4.66-7.73h8.26l-8.83,12.96,9.26,13.44s-8.16,0-8.16,0Z' fill='%23A13535'/></svg>");
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center !important;
}

.captcha_namecontainer {
    position: absolute;
    top: 52px;
    right: 10px;
    font-size: 9.5px;
    font-weight: 600;
    color: var(--bmstwofa-c-black);
    display: none;
}

.captcha_additionallinks {
    position: absolute;
    bottom: 4px;
    right: 0;
    height: 18px;
    font-size: 12px !important;
    font-weight: 300;
    width: 100%;
    text-align: right;
    padding: 5px 9px;
    font-family: Arial, Helvetica, sans-serif;
}

.captcha_additionallinks a:link,
.captcha_additionallinks a:visited {
    text-decoration: none;
    font-size: 12px !important;
    color: var(--bmstwofa-c-black);
}

.captcha_additionallinks a:hover,
.captcha_additionallinks a:active {
    text-decoration: underline;
}

.bsms-captcha-text {
    text-align: left !important;
    color: var(--bmstwofa-c-black) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    line-height: 1.12;
    width: auto !important;
    margin-left: 15px !important;
    max-width: 170px;
    position: absolute;
    left: 50px;
    top: 50%;
    transform: translateY(-50%);
}

.bsms-captcha-text.ok,
.bsms-captcha-text.completed {
    color: var(--bmstwofa-c-success) !important;
}

.bsms-captcha-text.error {
    color: var(--bmstwofa-c-error);
}

.bsms-captcha-state-icon {
    position: absolute !important;
    left: 10px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    background-image: none !important;
    width: 40px !important;
    height: 40px !important;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 24px 24px;
    background-color: var(--bmstwofa-c-brand1);
    border-radius: 50%;
    padding: 10px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer;
}

/* Default icon - Shield Check */
.bsms-captcha-state-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 1L3 5v6c0 5.55 3.84 10.74 9 12 5.16-1.26 9-6.45 9-12V5l-9-4zm-2 16l-4-4 1.41-1.41L10 14.17l6.59-6.59L18 9l-8 8z'/%3E%3C/svg%3E");
}

.bsms-captcha-state-icon.expired {
    background: var(--bmstwofa-c-error);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z'/%3E%3C/svg%3E");
    animation: pulse 0.85s ease-in-out infinite;
}

.bsms-captcha-state-icon.wait {
    background: #bb9d05;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 2C6.5 2 2 6.5 2 12s4.5 10 10 10 10-4.5 10-10S17.5 2 12 2zm4.2 14.2L11 13V7h1.5v5.2l4.5 2.7-.8 1.3z'/%3E%3C/svg%3E");
    animation: tilt 0.9s linear infinite;
}

/* Rotating spinner icon */
.bsms-captcha-state-icon.running {
    background: var(--bmstwofa-c-brand2);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 4V2C6.48 2 2 6.48 2 12h2c0-4.42 3.58-8 8-8z'/%3E%3CanimateTransform attributeName='transform' attributeType='XML' type='rotate' from='0 12 12' to='360 12 12' dur='1s' repeatCount='indefinite'/%3E%3C/svg%3E");
    animation: spin 1.1s linear infinite;
}

.bsms-captcha-state-icon.completed {
    background: #03881d;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E");
    animation: float 0.85s ease-in-out infinite;
}

.bsms-captcha-state-icon.error {
    background: var(--bmstwofa-c-error);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z'/%3E%3C/svg%3E");
    animation: pulse 0.85s ease-in-out infinite;
}
