@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Nunito+Sans:ital,opsz,wght@0,6..12,200..1000;1,6..12,200..1000&family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..800&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap");
* {
    padding: 0;
    margin: 0;
    box-sizing: border-box;
    -webkit-tap-highlight-color: transparent !important;
}

a {
    text-decoration: none;
    color: inherit;
    display: inline-block;
    cursor: pointer;
}

img {
    max-width: 100%;
}

span,
label {
    display: inline-block;
}

html {
    scroll-behavior: smooth;
}

input,
textarea {
    outline: none;
    border: 0;
    background: transparent;
    font-weight: 600;
}

button,
select {
    border: none;
    cursor: pointer;
    background: transparent;
    outline: 0;
    font-weight: 600;
}

address {
    font-style: normal;
}

.wrapper {
    width: 100%;
    overflow: hidden;
    min-height: 100svh;
}

ul,
ol,
dl {
    list-style: none;
    padding: 0;
    margin: 0;
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
    padding: 0;
    margin: 0;
    font-weight: 600;
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    -moz-appearance: none;
    margin: 0;
}

body {
    background: #fff;
    color: #000;
    font-family: "Nunito Sans", sans-serif;
    font-weight: 600;
}

button,
input,
textarea,
li,
div {
    font-family: "Nunito Sans", sans-serif;
    font-weight: 600;
}

html {
    font-size: 1px;
}

@media (max-width: 1850px) {
    html {
        font-size: 0.95px;
    }
}

@media (max-width: 1780px) {
    html {
        font-size: 0.9px;
    }
}

@media (max-width: 1680px) {
    html {
        font-size: 0.85px;
    }
}

@media (max-width: 1580px) {
    html {
        font-size: 0.8px;
    }
}

@media (max-width: 1480px) {
    html {
        font-size: 0.75px;
    }
}

@media (max-width: 1380px) {
    html {
        font-size: 0.7px;
    }
}

@media (max-width: 1330px) {
    html {
        font-size: 0.65px;
    }
}

@media (max-width: 1240px) {
    html {
        font-size: 0.6px;
    }
}

@media (max-width: 1140px) {
    html {
        font-size: 0.55px;
    }
}

@media (max-width: 1030px) {
    html {
        font-size: 0.5px;
    }
}

@media (max-width: 930px) {
    html {
        font-size: 0.45px;
    }
}

@media (max-width: 850px) {
    html {
        font-size: 1px;
    }
}

.container {
    max-width: 1680rem;
    width: calc(100% - 40rem);
    margin: 0 auto;
}

.form-inp {
    width: 100%;
    height: 70rem;
    border: 1rem solid #d40606;
    border-radius: 14rem;
    padding: 0 25rem;
    background: #FFF;
    font-family: "Roboto", sans-serif;
    font-weight: 600;
    font-size: 24rem;
    line-height: 140%;
    letter-spacing: -0.02em;
    color: #18171c;
}

@media screen and (max-width: 850px) {
    .form-inp {
        height: 56rem;
        font-size: 14rem;
    }
}

.form-inp::-moz-placeholder {
    font-weight: 400;
    font-family: "Roboto", sans-serif;
    color: #a9a9a9;
}

.form-inp::placeholder {
    font-weight: 400;
    font-family: "Roboto", sans-serif;
    color: #a9a9a9;
}

.form-checkbox {
    display: flex;
    align-items: center;
    gap: 12rem;
}

.form-checkbox__icon {
    border-radius: 4rem;
    border: 0.75rem solid #5d5d5d;
    width: 24rem;
    height: 24rem;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    z-index: 1;
    flex-shrink: 0;
}

.form-checkbox__icon input {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    cursor: pointer;
    z-index: 2;
    opacity: 0;
}

.form-checkbox__icon svg {
    width: 15.46rem;
    height: auto;
    display: none;
}

.form-checkbox__icon input:checked~svg {
    display: block;
}

.form-checkbox__text {
    font-family: "Gilroy", sans-serif;
    font-weight: 300;
    font-size: 14rem;
    color: #dbdbdb;
}

.main-btn {
    border-radius: 14rem;
    padding: 0 45rem;
    height: 70rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background: #d40606;
    font-family: "Roboto", sans-serif;
    font-weight: 700;
    font-size: 24rem;
    line-height: 120%;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: #fff;
}

@media screen and (max-width: 850px) {
    .main-btn {
        font-size: 20rem;
    }
}

.sec-title {
    font-weight: 600;
    font-size: 46rem;
    text-transform: uppercase;
    color: #282828;
}

@media screen and (max-width: 850px) {
    .sec-title {
        font-size: 26rem;
        text-align: center;
    }
}

.sec-title span {
    color: #d40606;
    display: inline;
}

.home {
    position: relative;
    z-index: 1;
}

.home::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: calc(100% - 99rem);
    background: #f2f2f2;
    border-radius: 60rem;
}

@media screen and (max-width: 850px) {
    .home::before {
        height: calc(100% - 280rem);
        border-radius: 27rem;
    }
}

.home-container {
    position: relative;
    z-index: 1;
    padding-top: 167rem;
}

@media screen and (max-width: 850px) {
    .home-container {
        padding-top: 43rem;
    }
}

.home .subtitle {
    font-style: italic;
    font-weight: 400;
    font-size: 32rem;
    text-transform: uppercase;
    color: #18171c;
    margin-bottom: 12rem;
}

@media screen and (max-width: 850px) {
    .home .subtitle {
        font-size: 14rem;
        margin-bottom: 4rem;
    }
}

.home h1 {
    font-weight: 700;
    font-size: 64rem;
    line-height: 107%;
    text-transform: uppercase;
    color: #d40606;
    margin-bottom: 25rem;
    max-width: 1089rem;
}

@media screen and (max-width: 850px) {
    .home h1 {
        font-size: 28rem;
        max-width: 100%;
        margin-bottom: 16rem;
    }
}

.home p {
    font-family: "Gilroy", sans-serif;
    font-weight: 400;
    font-size: 24rem;
    line-height: 133%;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: #000;
    max-width: 744rem;
    margin-bottom: 91rem;
}

@media screen and (max-width: 850px) {
    .home p {
        margin: 0;
        font-size: 16rem;
        max-width: 100%;
    }
}

.home p span {
    font-weight: 600;
    color: #d40606;
    display: inline;
}

.home-card {
    position: absolute;
    z-index: -1;
    top: 0;
    right: -99rem;
    width: 742rem;
}

@media screen and (max-width: 850px) {
    .home-card {
        position: relative;
        width: 100%;
        height: 342rem;
        top: auto;
        right: 0;
        text-align: center;
    }
}

.home-card img {
    width: 100%;
}

@media screen and (max-width: 850px) {
    .home-card img {
        max-width: 370rem;
        width: 100%;
        margin-top: -5rem;
    }
}

.home-content {
    border: 1rem solid #fff;
    border-radius: 39rem;
    padding: 40rem;
    width: 100%;
    backdrop-filter: blur(4rem);
    box-shadow: 0 4rem 4rem 0 rgba(0, 0, 0, 0.25);
    background: #18171c;
}

@media screen and (max-width: 850px) {
    .home-content {
        width: calc(100% + 24rem);
        margin-left: -12rem;
        padding: 40rem 12rem;
    }
}

.home-content h3 {
    font-weight: 600;
    font-size: 40rem;
    line-height: 130%;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    color: #fff;
    margin-bottom: 56rem;
}

@media screen and (max-width: 850px) {
    .home-content h3 {
        font-size: 24rem;
        text-align: center;
        padding-bottom: 8rem;
        border-bottom: 1px solid rgba(255, 255, 255, 0.59);
        margin-bottom: 24rem;
    }
}

.field-wrap {
    position: relative;
    height: 70rem;
}

@media screen and (max-width: 850px) {
    .field-wrap {
        height: 56rem;
    }
}

.field-wrap .form-inp {
    width: 100%;
    height: 100%;
}

/* Generic error label inside field-wrap */
.field-error {
    display: none;
    position: absolute;
    top: 100%;
    left: 16px;
    margin-top: 4px;
    font-size: 11px;
    font-family: Verdana, Arial;
    font-weight: 400;
    color: red;
    white-space: nowrap;
}

/* jQuery Validate error labels — uniform weight for all fields */
#name-error,
#email-error,
#phone-error {
    font-weight: 400 !important;
}

/* Contact section: white errors on red background */
.contact .field-error {
    color: #fff;
}

.home-content .form-group {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-bottom: 32px;
}

@media screen and (max-width: 850px) {
    .home-content .form-group {
        grid-template-columns: repeat(1, 1fr);
    }
}

.investment {
    padding-top: 90rem;
}

@media screen and (max-width: 850px) {
    .investment {
        padding-top: 74rem;
    }
}

.investment-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 12rem;
    border-bottom: 1rem solid #3d3d3d;
    margin-bottom: 58rem;
}

@media screen and (max-width: 850px) {
    .investment-head {
        flex-direction: column;
        gap: 18rem;
        margin-bottom: 32rem;
    }
}

.investment-head h2 {
    max-width: 569rem;
}

@media screen and (max-width: 850px) {
    .investment-head h2 {
        max-width: 100%;
    }
}

.investment-head p {
    font-family: "Gilroy", sans-serif;
    font-weight: 400;
    font-size: 28rem;
    line-height: 114%;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: #000;
    max-width: 687rem;
}

@media screen and (max-width: 850px) {
    .investment-head p {
        font-size: 20px;
        max-width: 100%;
        text-align: center;
    }
}

.investment-list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20rem;
}

@media screen and (max-width: 850px) {
    .investment-list {
        grid-template-columns: repeat(2, 1fr);
        gap: 36rem;
        width: calc(100% + 20rem);
        margin-left: -10rem;
    }
}

@media screen and (max-width: 600px) {
    .investment-list {
        grid-template-columns: repeat(1, 1fr);
    }
}

.investment-card {
    background: #18171c;
    border-radius: 35rem;
    padding: 16rem 0 12rem;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

@media screen and (max-width: 850px) {
    .investment-card {
        padding: 27rem 0 16rem;
    }
}

.investment-card h3 {
    font-weight: 600;
    font-size: 28rem;
    text-transform: uppercase;
    text-align: center;
    color: #fff;
    margin-bottom: 20rem;
    border-bottom: 0.5rem solid rgba(255, 255, 255, 0.59);
    padding: 0 12rem 12rem;
}

@media screen and (max-width: 850px) {
    .investment-card h3 {
        font-size: 18rem;
        margin-bottom: 11rem;
        padding: 0 40rem 8rem;
    }
    .investment-card h3 br {
        display: none;
    }
}

.investment-card p {
    font-family: "Gilroy", sans-serif;
    font-weight: 300;
    font-size: 24rem;
    letter-spacing: -0.04em;
    text-align: center;
    color: #f6f6f6;
    margin-bottom: 24rem;
    padding: 0 23rem;
}

@media screen and (max-width: 850px) {
    .investment-card p {
        font-size: 16rem;
    }
}

.investment-card .main-img {
    width: 100%;
    padding: 0 9.36rem;
}

@media screen and (max-width: 850px) {
    .investment-card .main-img {
        padding: 0 5rem;
    }
}

.investment-card .main-img img {
    width: 100%;
    border-radius: 30rem;
}

.investment-card .number {
    position: absolute;
    bottom: -25rem;
    right: -13rem;
    width: 135rem;
    height: 135rem;
    border-radius: 50%;
    background: #fff;
    z-index: 1;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-weight: 600;
    font-size: 30rem;
    text-transform: uppercase;
    text-align: center;
    color: #fff;
    padding-top: 33rem;
}

@media screen and (max-width: 850px) {
    .investment-card .number {
        width: 99rem;
        height: 99rem;
        font-size: 22rem;
        padding-top: 24.2rem;
    }
}

.investment-card .number::before {
    content: "";
    position: absolute;
    top: 15rem;
    left: 15rem;
    width: 105rem;
    height: 105rem;
    border-radius: 50%;
    background: #D40606;
    z-index: -1;
}

@media screen and (max-width: 850px) {
    .investment-card .number::before {
        left: 11rem;
        top: 11rem;
        width: 77rem;
        height: 77rem;
    }
}

.benefit {
    padding-top: 105rem;
}

@media screen and (max-width: 850px) {
    .benefit {
        padding-top: 56rem;
    }
}

.benefit h2 {
    text-align: center;
    margin-bottom: 32rem;
}

.benefit-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28rem;
}

@media screen and (max-width: 850px) {
    .benefit-list {
        grid-template-columns: repeat(1, 1fr);
        gap: 20rem;
    }
}

.benefit-card {
    background: #18171c;
    display: flex;
    align-items: center;
    gap: 20rem;
    padding: 19rem 12rem;
    border-radius: 17rem;
}

@media screen and (max-width: 850px) {
    .benefit-card {
        padding: 12rem;
    }
}

.benefit-card:nth-child(2) {
    background: #d40606;
}

.benefit-card img {
    flex-shrink: 0;
    width: 48rem;
}

.benefit-card p {
    font-family: "Inter", sans-serif;
    font-weight: 400;
    font-size: 24rem;
    line-height: 130%;
    letter-spacing: -0.03em;
    color: #fff;
}

@media screen and (max-width: 850px) {
    .benefit-card p {
        font-size: 18rem;
    }
}

.using {
    padding-top: 80rem;
}

.using-container {
    display: flex;
    justify-content: flex-end;
    padding: 50rem 83rem;
    background: #f2f2f2;
    border-radius: 55rem;
    position: relative;
    z-index: 1;
    overflow: hidden;
}

@media screen and (max-width: 850px) {
    .using-container {
        width: calc(100% - 20rem);
        border-radius: 30rem;
        padding: 24rem 10rem 20rem;
    }
}

.using-content {
    max-width: 828rem;
    width: 100%;
}

@media screen and (max-width: 850px) {
    .using-content {
        max-width: 100%;
    }
}

.using .main-img {
    position: absolute;
    left: 40rem;
    top: 50%;
    transform: translateY(-50%);
    width: 616rem;
}

@media screen and (max-width: 850px) {
    .using .main-img {
        position: static;
        transform: translateY(0);
        top: auto;
        width: 100%;
        text-align: center;
        margin-top: 22rem;
    }
}

.using .main-img img {
    width: 100%;
}

@media screen and (max-width: 850px) {
    .using .main-img img {
        width: 300rem;
    }
}

.using .title {
    margin: 18rem 0 25rem;
    padding: 10rem;
    position: relative;
    z-index: 1;
}

@media screen and (max-width: 850px) {
    .using .title {
        margin: 22rem 0 16rem;
    }
}

.using .title .icon-1 {
    position: absolute;
    left: 0;
    top: 0;
    z-index: -1;
    width: 36rem;
}

@media screen and (max-width: 850px) {
    .using .title .icon-1 {
        width: 23rem;
    }
}

.using .title .icon-2 {
    width: 36rem;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: -1;
}

@media screen and (max-width: 850px) {
    .using .title .icon-2 {
        width: 23rem;
    }
}

.using .title h3 {
    font-style: italic;
    font-weight: 300;
    font-size: 28rem;
    line-height: 114%;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: #000;
}

@media screen and (max-width: 850px) {
    .using .title h3 {
        font-size: 17rem;
        text-align: center;
    }
}

.using .title h3 span {
    font-weight: 600;
    color: #d40606;
    display: inline;
}

.using ul {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 24rem;
    max-width: 592rem;
    margin-bottom: 36rem;
}

@media screen and (max-width: 850px) {
    .using ul {
        align-items: center;
        gap: 16rem;
        margin-bottom: 28rem;
    }
}

.using ul li {
    font-family: "Gilroy", sans-serif;
    font-weight: 400;
    font-size: 24rem;
    letter-spacing: -0.04em;
    color: #18171c;
}

@media screen and (max-width: 850px) {
    .using ul li {
        font-size: 16rem;
        text-align: center;
    }
}

.using ul li b {
    font-weight: 600;
    color: #0c0c0c;
}

@media screen and (max-width: 850px) {
    .using .main-btn {
        width: 100%;
        text-align: center;
        justify-content: center;
        padding: 0 20rem;
    }
}

.using-bg {
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: -1;
    width: 435rem;
}

@media screen and (max-width: 850px) {
    .using-bg {
        display: none;
    }
}

.result {
    padding: 140rem 0 80rem;
}

@media screen and (max-width: 850px) {
    .result {
        padding: 50rem 0 32rem;
    }
}

.result-container {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 66rem;
    padding-bottom: 16rem;
    border-bottom: 1px solid #3d3d3d;
}

@media screen and (max-width: 850px) {
    .result-container {
        flex-direction: column;
        align-items: flex-start;
        gap: 28rem;
    }
}

.result h2 {
    width: 569rem;
    flex-shrink: 0;
    text-align: left;
}

.result h2 span {
    display: block;
}

.result ul {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 28rem;
    width: 100%;
}

@media screen and (max-width: 850px) {
    .result ul {
        gap: 18rem;
    }
}

.result li {
    font-family: "Gilroy", sans-serif;
    font-weight: 400;
    font-size: 28rem;
    line-height: 114%;
    letter-spacing: -0.04em;
}

@media screen and (max-width: 850px) {
    .result li {
        font-size: 18rem;
    }
}

.result li span {
    display: inline;
    font-weight: 600;
    color: #d40606;
}

.contact {
    padding-bottom: 140rem;
}

@media screen and (max-width: 850px) {
    .contact {
        padding-bottom: 60rem;
    }
}

.contact-container {
    backdrop-filter: blur(4rem);
    box-shadow: 0 4rem 4rem 0 rgba(0, 0, 0, 0.25);
    background: #d40606;
    border: 1rem solid #fff;
    border-radius: 39rem;
    padding: 60rem 40rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

@media screen and (max-width: 850px) {
    .contact-container {
        padding: 60rem 15rem;
        width: calc(100% - 10rem);
    }
}

.contact h2 {
    font-weight: 600;
    font-size: 40rem;
    line-height: 130%;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    color: #fff;
    padding-bottom: 8rem;
    border-bottom: 1rem solid rgba(255, 255, 255, 0.59);
    margin-bottom: 48rem;
}

@media screen and (max-width: 850px) {
    .contact h2 {
        width: 100%;
        text-align: center;
        font-size: 26rem;
        margin-bottom: 32rem;
    }
}

.contact .form-group {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20rem;
    margin-bottom: 36rem;
}

@media screen and (max-width: 850px) {
    .contact .form-group {
        grid-template-columns: repeat(1, 1fr);
    }
}

.contact .form-inp {
    background: rgba(255, 255, 255, 1);
    border-color: rgba(255, 255, 255, 0.45);
}

.contact .form-inp:focus {
    border-color: rgba(255, 255, 255, 0.9);
    outline: none;
}

.contact .form-inp.error {
    border-color: rgba(255, 255, 255, 0.9) !important;
    background: rgba(255, 255, 255, 1) !important;
}

@media screen and (max-width: 850px) {
    .contact .form-inp {
        height: 53rem;
        padding: 0 12rem;
        font-size: 12rem;
    }
}

.contact .form-inp::-moz-placeholder {
    opacity: 1;
    color: rgba(24, 23, 28, 0.45);
    font-weight: 400;
    font-family: "Roboto", sans-serif;
}

.contact .form-inp::placeholder {
    opacity: 1;
    color: rgba(24, 23, 28, 0.45);
    font-weight: 400;
    font-family: "Roboto", sans-serif;
}

/* intlTelInput inside contact section — dark text on white input */
.contact .iti__selected-dial-code {
    color: rgba(24, 23, 28, 0.6) !important;
}

.contact .iti__arrow {
    border-top-color: rgba(24, 23, 28, 0.5) !important;
}

.contact .iti--open .iti__arrow {
    border-bottom-color: rgba(24, 23, 28, 0.5) !important;
}

.contact .form-checkbox__icon {
    border-color: #fff;
}

.contact .form-checkbox__icon svg path {
    fill: #fff;
}

.contact .main-btn {
    background: #000;
}

.footer {
    background: #18171c;
    padding: 67rem 0 66rem;
}

.footer p {
    font-family: "Gilroy", sans-serif;
    font-weight: 400;
    font-size: 28rem;
    line-height: 114%;
    letter-spacing: -0.04em;
    text-align: center;
    color: #fff;
}

@media screen and (max-width: 850px) {
    .footer p {
        font-size: 18rem;
        line-height: 178%;
    }
}

.contact-form {
    position: fixed;
    z-index: 5;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: none;
    align-items: center;
    justify-content: center;
}

.contact-form.active {
    display: flex;
}

.contact-form__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    background: rgba(0, 0, 0, 0.76);
}

.contact-form__content {
    width: 100%;
}

.contact-form__container {
    position: relative;
    z-index: 2;
    backdrop-filter: blur(4rem);
    box-shadow: 0 4rem 4rem 0 rgba(0, 0, 0, 0.25);
    background: #d40606;
    border: 1rem solid #fff;
    border-radius: 39rem;
    padding: 60rem;
    display: flex;
    flex-direction: column;
    align-items: center;
}

@media screen and (max-width: 850px) {
    .contact-form__container {
        padding: 60rem 14rem;
        width: calc(100% - 10rem);
    }
}

.contact-form h2 {
    font-weight: 600;
    font-size: 40rem;
    line-height: 130%;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    color: #fff;
    padding-bottom: 8rem;
    border-bottom: 1rem solid rgba(255, 255, 255, 0.59);
    margin-bottom: 48rem;
}

@media screen and (max-width: 850px) {
    .contact-form h2 {
        width: 100%;
        text-align: center;
        font-size: 26rem;
        margin-bottom: 32rem;
    }
}

.contact-form__body {
    width: 771rem;
}

@media screen and (max-width: 850px) {
    .contact-form__body {
        width: 100%;
    }
}

.contact-form .form-group {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 20rem;
    margin-bottom: 20rem;
}

.contact-form .form-inp {
    background: rgba(255, 255, 255, 0.48);
}

@media screen and (max-width: 850px) {
    .contact-form .form-inp {
        height: 53rem;
        padding: 0 12rem;
        font-size: 12rem;
    }
}

.contact-form .form-inp::-moz-placeholder {
    opacity: 1;
    color: #0c0c0c;
}

.contact-form .form-inp::placeholder {
    opacity: 1;
    color: #0c0c0c;
}

.contact-form .form-checkbox {
    max-width: 559rem;
}

.contact-form .form-checkbox__icon {
    border-color: #fff;
}

.contact-form .form-checkbox__icon svg path {
    fill: #fff;
}

.contact-form .main-btn {
    background: #000;
}

/*# sourceMappingURL=style.css.map */

.iti__selected-dial-code {
    font-size: 24px;
}

input.form-inp[type="tel"] {
    padding-left: 56px !important;
}

span.iti__dial-code {
    font-size: 16px;
}

/* ===== SMS FORM INTEGRATION ===== */

/* Preloader */
#preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.75);
    z-index: 10000;
    display: none;
    justify-content: center;
    align-items: center;
}
#preloader[style*="block"] {
    display: flex !important;
}

/* SMS & Phone Change Popups overlay */
.popup {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    z-index: 9999;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Popup content card */
.popup_content {
    background: #18171c !important;
    border-radius: 24px;
    padding: 40px 32px 32px;
    max-width: 440px;
    width: 90%;
    position: relative;
}

.popup_content h3 {
    font-family: "Nunito Sans", sans-serif !important;
    font-weight: 600;
    font-size: 24px;
    color: #fff !important;
    text-align: center;
    margin-bottom: 10px;
}

.popup_content p {
    font-family: "Gilroy", sans-serif !important;
    font-weight: 300;
    font-size: 16px;
    color: rgba(255, 255, 255, 0.7) !important;
    text-align: center;
    margin-bottom: 24px;
    line-height: 1.4;
}

.popup_content p span {
    color: #D40606 !important;
    font-weight: 600;
    display: inline;
}

/* Close button inside popup_content */
.popup_content .close_popup {
    position: absolute;
    top: 14px;
    right: 14px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 6px;
    line-height: 0;
    display: block;
}

.popup_content .close_popup svg rect {
    fill: rgba(255, 255, 255, 0.5);
    transition: fill 0.2s;
}

.popup_content .close_popup:hover svg rect {
    fill: #fff;
}

/* Popup label wrapper */
.popup_content .jhuy {
    display: block;
    position: relative;
    margin-bottom: 16px;
}

/* Popup inputs — !important нужен против addelements.css и modal.css */
.popup_content .t-input {
    display: block;
    width: 100%;
    height: 52px;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 14px !important;
    padding: 0 18px !important;
    background: rgba(255, 255, 255, 0.07) !important;
    font-family: "Roboto", sans-serif !important;
    font-weight: 400;
    font-size: 16px !important;
    color: #fff !important;
    outline: none;
    transition: border-color 0.2s;
}

.popup_content .t-input::placeholder {
    color: rgba(255, 255, 255, 0.35);
    font-weight: 300;
}

.popup_content .t-input:focus {
    border-color: rgba(255, 255, 255, 0.4);
}

.popup_content input.error.t-input {
    border-color: #D40606;
    background: rgba(212, 6, 6, 0.08);
}

/* Error placeholder on dark inputs */
input.error::placeholder {
    color: #d85030;
    opacity: 0.6;
}

/* Popup submit button */
.popup_content .t-submit {
    display: block;
    width: 100%;
    height: 52px;
    border-radius: 14px;
    background: #D40606;
    font-family: "Roboto", sans-serif;
    font-weight: 700;
    font-size: 16px;
    text-transform: uppercase;
    color: #fff;
    border: none;
    cursor: pointer;
    transition: opacity 0.2s;
    letter-spacing: 0.02em;
}

.popup_content .t-submit:hover {
    opacity: 0.88;
}

/* Button + link row */
.popup_content .flex_uh {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
}

/* "Change number" link */
.popup_content .change_phone {
    font-family: "Gilroy", sans-serif;
    font-weight: 300;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.45);
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 3px;
    display: inline-block;
}

.popup_content .change_phone:hover {
    color: rgba(255, 255, 255, 0.75);
}

/* SMS code error message */
#codeError {
    display: none;
    color: #D40606;
    font-size: 13px;
    font-family: "Gilroy", sans-serif;
    font-weight: 300;
    margin-top: 6px;
    text-align: left;
}

/* intlTelInput — block layout inside popups */
.popup_content .iti {
    display: block !important;
    width: 100%;
}

.popup_content .iti input[type=tel] {
    width: 100%;
    padding-left: 64px !important;
}

/* intlTelInput — country list dark theme */
/* font-size: 14px обязателен — html имеет font-size: 1px (rem-вёрстка), без явного px текст невидим */
.iti__country-list {
    background-color: #1e1d23 !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: #fff !important;
    z-index: 10001 !important;
    min-width: 300px;
    max-height: 280px;
    font-size: 14px !important;
}

.iti__country.iti__highlight {
    background-color: rgba(255, 255, 255, 0.07) !important;
}

.iti__dial-code {
    color: rgba(255, 255, 255, 0.45) !important;
}

.iti__country-list .iti__country-name {
    color: #fff !important;
}

.iti__arrow {
    border-top-color: rgba(255, 255, 255, 0.45);
}

.iti--allow-dropdown .iti__flag-container:hover .iti__selected-flag {
    background-color: rgba(255, 255, 255, 0.05);
}

/* Validation error labels inside .iti must be absolute to not shift flag */
.iti #phone-error,
.iti #phoneConfirm-error {
    position: absolute !important;
    left: 0;
    top: 100%;
    margin: 3px 0 0 !important;
    font-size: 12px;
    color: #D40606;
    background: transparent !important;
    font-family: "Gilroy", sans-serif;
    font-weight: 300;
    white-space: nowrap;
}

/* Extra bottom space on phone label so absolute error doesn't overlap next element */
.popup_content .jhuy:has(#phone),
.popup_content .jhuy:has(#phoneConfirm) {
    margin-bottom: 28px;
}

/* Validation error labels for name/email (relative flow) */
.popup_sms #codeError,
.popup_sms_change #phoneConfirm-error {
    position: relative !important;
    display: none;
    margin: 4px 0 0 !important;
    font-size: 12px;
    color: #D40606;
    background: transparent !important;
    font-family: "Gilroy", sans-serif;
    font-weight: 300;
}

/* Contact-form popup — intlTelInput for #phone field */
.contact-form .iti {
    display: block !important;
    width: 100%;
}

.contact-form .iti input[type=tel].form-inp {
    padding-left: 68px !important;
    width: 100%;
}

.contact-form .iti__country-list {
    z-index: 10001 !important;
}

/* Validation errors inside contact-form popup */
.contact-form #name-error,
.contact-form #email-error {
    position: relative !important;
    display: block !important;
    margin: 4px 0 0 !important;
    font-size: 12px;
    color: #D40606;
    background: transparent !important;
    font-family: "Gilroy", sans-serif;
    font-weight: 300;
}

.contact-form .iti #phone-error {
    position: absolute !important;
    left: 0;
    top: 100%;
    margin: 3px 0 0 !important;
    font-size: 12px;
    color: #D40606;
    background: transparent !important;
    font-family: "Gilroy", sans-serif;
    font-weight: 300;
    white-space: nowrap;
}

/* Error state on .form-inp */
.form-inp.error {
    border-color: #D40606 !important;
}

.form-inp.error::placeholder {
    font-weight: 400;
    font-family: "Roboto", sans-serif;
    color: #d85030;
    opacity: 0.6;
}

/* Contact form body: stack all fields vertically */
.contact-form .contact-form__body .form-group {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    margin-bottom: 20px;
}

/* Phone label needs room for absolute error below */
.contact-form .contact-form__body .form-group .iti {
    margin-bottom: 10px;
}

@media (max-width: 850px) {
    .popup_content {
        padding: 32px 20px 24px;
    }
    .popup_content h3 {
        font-size: 20px;
    }
    .popup_content p {
        font-size: 14px;
    }
    .popup_content .t-input,
    .popup_content .t-submit {
        height: 48px;
        font-size: 14px;
    }
}