/* Typography */
body {
    font-family: 'Roboto', 'Open Sans', sans-serif !important;
    font-size: 1.25rem !important;
    font-weight: 400 !important;
    line-height: 28px !important;
    color: #454545;
}

h1, h2, h3, h4, h5, h6,
p, ul, ol, li, a {
    font-family: 'Roboto', 'Open Sans', sans-serif !important;
    color: #454545;
}

.white-text,
.white-text p {
    color: #ffffff !important;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Roboto', 'Open Sans', sans-serif !important;
    font-weight: 700 !important;
}

/* Headings - Desktop */
h1 {
    font-size: 4rem !important;
    line-height: 72px !important;
}

h2 {
    font-size: 3rem !important;
    line-height: 56px !important;
}

h3 {
    font-size: 2.5rem !important;
    line-height: 48px !important;
}

h4 {
    font-size: 2rem !important;
    line-height: 40px !important;
}

h5 {
    font-size: 1.5rem !important;
    line-height: 28px !important;
}

h6 {
    font-size: 1.25rem !important;
    line-height: 24px !important;
}

/* Links */
a {
    color: #6c943e;
    text-decoration: none !important;
}

a:not(.elementor-button):hover {
    text-decoration: underline !important;
}

/* Layout */
.container {
    max-width: 1440px !important;
    margin: 0 auto !important;
    padding: 0 15px !important;
}

/* Buttons */
button,
.button,
.elementor-button {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    padding: 12px 24px !important;
    border-radius: 5px !important;
    border: none !important;
    background-color: #b7cf3b !important;
    cursor: pointer !important;
    text-transform: capitalize !important;
}

button:hover,
.button:hover,
.elementor-button:hover {
    background-color: #6c943e !important;
}

/* Tablet Typography */
@media (max-width: 1024px) {
    body {
        font-size: 1rem !important;
        line-height: 24px !important;
    }

    h1 {
        font-size: 3rem !important;
        line-height: 56px !important;
    }

    h2 {
        font-size: 2.5rem !important;
        line-height: 48px !important;
    }

    h3 {
        font-size: 2rem !important;
        line-height: 40px !important;
    }

    h4 {
        font-size: 1.5rem !important;
        line-height: 28px !important;
    }

    h5 {
        font-size: 1.25rem !important;
        line-height: 24px !important;
    }

    h6 {
        font-size: 1rem !important;
        line-height: 20px !important;
    }
}

/* Mobile Typography */
@media (max-width: 768px) {
    body {
        font-size: 1rem !important;
        line-height: 24px !important;
    }

    h1 {
        font-size: 2rem !important;
        line-height: 40px !important;
    }

    h2 {
        font-size: 1.5rem !important;
        line-height: 28px !important;
    }

    h3 {
        font-size: 1.25rem !important;
        line-height: 24px !important;
    }

    h4 {
        font-size: 1rem !important;
        line-height: 20px !important;
    }

    h5 {
        font-size: 1rem !important;
        line-height: 20px !important;
    }

    h6 {
        font-size: 1rem !important;
        line-height: 20px !important;
    }
}
