:root {
    --webvix-ink: #0f172a;
    --webvix-muted: #475569;
    --webvix-primary: #2563eb;
    --webvix-primary-dark: #1d4ed8;
    --webvix-accent: #14b8a6;
    --webvix-surface: #ffffff;
    --webvix-background: #f8fafc;
    --webvix-border: #e2e8f0;
}

body {
    background: var(--webvix-background);
    color: var(--webvix-ink);
    font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
    color: var(--webvix-ink);
    font-family: "Sora", "Inter", "Helvetica Neue", Arial, sans-serif;
    letter-spacing: -0.02em;
}

p,
li,
.lead {
    color: var(--webvix-muted);
}

a {
    color: var(--webvix-primary);
}

a:hover,
a:focus {
    color: var(--webvix-primary-dark);
}

.bg--secondary {
    background: #f1f5f9;
}

.boxed,
.pricing,
.feature.boxed--border {
    background: var(--webvix-surface);
    border-color: var(--webvix-border);
    border-radius: 18px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
}

.feature.boxed--border {
    border-width: 1px;
}

.bar--transparent .menu-horizontal > li > a,
.bar--transparent .menu-horizontal > li > span {
    color: var(--webvix-ink);
    font-weight: 600;
}

.bar--transparent .menu-horizontal > li > a:hover,
.bar--transparent .menu-horizontal > li > a:focus {
    color: var(--webvix-primary);
}

.btn.btn--primary,
.btn.btn--primary-1 {
    background: var(--webvix-primary);
    border-color: var(--webvix-primary);
    box-shadow: 0 15px 30px rgba(37, 99, 235, 0.25);
}

.btn.btn--primary:hover,
.btn.btn--primary-1:hover,
.btn.btn--primary:focus,
.btn.btn--primary-1:focus {
    background: var(--webvix-primary-dark);
    border-color: var(--webvix-primary-dark);
}

.btn.btn--secondary {
    background: var(--webvix-surface);
    border-color: var(--webvix-primary);
    color: var(--webvix-primary);
    box-shadow: 0 15px 30px rgba(37, 99, 235, 0.12);
}

.btn.btn--secondary:hover,
.btn.btn--secondary:focus {
    background: var(--webvix-primary);
    border-color: var(--webvix-primary);
    color: #fff;
}

.btn.btn--secondary .btn__text {
    color: inherit;
}

.color--primary,
.webvix-services .material-icons.icon,
.webvix-why .material-icons.icon {
    color: var(--webvix-accent);
}

.imagebg .background-image-holder::after {
    background: linear-gradient(120deg, rgba(15, 23, 42, 0.7), rgba(37, 99, 235, 0.4));
}

.imageblock__content .background-image-holder::after {
    background: linear-gradient(120deg, rgba(15, 23, 42, 0.75), rgba(20, 184, 166, 0.45));
}

.webvix-services .material-icons.icon,
.webvix-why .material-icons.icon {
    font-size: 40px;
}

.webvix-error {
    color: #b94a48;
    display: block;
    font-size: 13px;
    margin-top: 6px;
}

.webvix-contact-form .is-invalid {
    border-color: #b94a48;
    box-shadow: 0 0 0 1px rgba(185, 74, 72, 0.3);
}

.webvix-form-message {
    font-size: 14px;
    margin-bottom: 20px;
}

.webvix-honeypot {
    height: 0;
    left: -10000px;
    overflow: hidden;
    position: absolute;
    top: auto;
    width: 0;
}

.webvix-contact-form button.is-loading {
    opacity: 0.7;
    pointer-events: none;
}

.btn.btn--primary .btn__text,
.btn.btn--primary-1 .btn__text {
    color: #fff;
}

.btn.btn--primary:hover .btn__text,
.btn.btn--primary-1:hover .btn__text,
.btn.btn--primary:focus .btn__text,
.btn.btn--primary-1:focus .btn__text {
    color: #fff;
}

.webvix-pricing .pricing {
    height: 100%;
}

.webvix-pricing .pricing .btn {
    margin-top: 10px;
}

.webvix-pricing .pricing ul {
    text-align: left;
}

.webvix-hero-stats {
    border-top: 1px solid var(--webvix-border);
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    margin-top: 32px;
    padding-top: 20px;
    text-align: left;
}

.webvix-hero-stat {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.webvix-tech-list {
    background: var(--webvix-surface);
    border: 1px solid var(--webvix-border);
    border-radius: 0;
    padding: 20px 22px;
}

.webvix-tech-list__items {
    display: grid;
    gap: 10px 24px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    list-style: none;
    margin: 0;
    padding: 0;
}

.webvix-tech-list__items li {
    color: var(--webvix-muted);
    font-size: 0.95rem;
    line-height: 1.5;
    margin: 0;
}

@media (max-width: 576px) {
    .webvix-tech-list__items {
        grid-template-columns: 1fr;
    }
}

.webvix-hero-stat__value {
    color: var(--webvix-ink);
    font-size: 28px;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.webvix-hero-stat__label {
    color: var(--webvix-muted);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}
