/**
Theme Name: Astra Child
Author: Brainstorm Force
Author URI: http://wpastra.com/about/
Description: Astra is the fastest, fully customizable & beautiful theme suitable for blogs, personal portfolios and business websites. It is very lightweight (less than 50KB on frontend) and offers unparalleled speed. Built with SEO in mind, Astra comes with schema.org code integrated so search engines will love your site. Astra offers plenty of sidebar options and widget areas giving you a full control for customizations. Furthermore, we have included special features and templates so feel free to choose any of your favorite page builder plugin to create pages flexibly. Some of the other features: # WooCommerce Ready # Responsive # Compatible with major plugins # Translation Ready # Extendible with premium addons # Regularly updated # Designed, Developed, Maintained & Supported by Brainstorm Force. Looking for a perfect base theme? Look no further. Astra is fast, fully customizable and beautiful theme!
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: astra-child
Template: astra
*/

:root {
    --white: #fff;
    --black: #13110C;
    --gray-700: #414651;
    --gray-300: #D5D7DA;
    --gray-title: #868C98;
    --gray-text: #717680;
    --gray: #535862;
    --brand-color-1: #1451EF;
    --brand-color-2: #08A9F9;
    --bg-light: #F5F5F5;
    --bg-dark: #101828;
}

html {
    scroll-behavior: smooth;
}

.ast-separate-container {
    background-color: var(--white);
}

/* reset astra styles */
.ast-separate-container #primary,
.ast-separate-container.ast-left-sidebar #primary,
.ast-separate-container.ast-right-sidebar #primary,
.ast-plain-container.ast-no-sidebar #primary {
    margin-top: 0;
    margin-bottom: 0;
    padding: 0;
}

.ast-container {
    display: block !important;
}

h1 {
    margin-bottom: 24px;
    font-family: 'Montserrat', sans-serif, Arial;
    font-weight: 600;
    font-size: 48px;
    line-height: 120%;
    letter-spacing: 0;
    color: var(--black);
}

h2 {
    margin-bottom: 24px;
    font-family: 'Montserrat', sans-serif, Arial;
    font-weight: 600;
    font-size: 40px;
    line-height: 120%;
    letter-spacing: 0;
    color: var(--black);
}

h3 {
    font-family: 'Montserrat', sans-serif, Arial;
    font-weight: 600;
    font-size: 24px;
    line-height: 120%;
    letter-spacing: 0;
    color: var(--black);
}

h4 {
    font-family: 'Montserrat', sans-serif, Arial;
    font-weight: 600;
    font-size: 20px;
    line-height: 130%;
    letter-spacing: 0;
    color: var(--black);
}

@media (max-width: 1025px) {
    h1 {
        font-size: 40px;
    }

    h2 {
        font-size: 32px;
    }

    h3 {
        font-size: 20px
    }
}

@media (max-width: 768px) {
    h1 {
        font-size: 32px;
    }

    h2 {
        font-size: 30px;
    }
}

.ast-primary-header-bar {
    box-shadow: 0px 4px 8px 0px #00000014;
    border: none;
}

.btn-contact {
    margin-left: 48px;
}

@media(max-width: 1230px) {
    .site-logo-img img {
        max-width: 280px;
    }

    .btn-contact {
        margin-left: 0;
    }
}

@media(max-width: 1200px) {
    .btn-contact {
        width: auto !important;
        margin: 24px auto;
    }
}

@media(max-width: 1025px) {
    .site-logo-img img {
        max-width: 240px;
    }
}

.site-header .main-header-menu .menu-link,
.site-header .main-header-menu>a,
.ast-builder-menu-1 .menu-item.current-menu-item>.menu-link {
    font-family: 'Inter', sans-serif, Arial;
    font-weight: 600;
    font-size: 15px;
    line-height: 100%;
    letter-spacing: 0;
    color: var(--black);
    padding: 0 20px;
    background-color: transparent !important;
    transition: 0.3s;
}

.site-header .main-header-menu .menu-link:hover,
.site-header .main-header-menu>a:hover,
.ast-builder-menu-1 .menu-item.current-menu-item>.menu-link:hover {
    color: var(--brand-color-2);
    transition: 0.3s;
}

#ast-hf-mobile-menu {
    padding: 32px 0;
}

#ast-hf-mobile-menu .menu-item {
    padding: 16px !important;
    display: inline-grid;
}

#ast-hf-mobile-menu .menu-link {
    color: var(--dark);
}

.heading-above {
    display: block;
    margin-bottom: 16px;
    font-family: 'Inter', sans-serif, Arial;
    font-weight: 600;
    font-size: 14px;
    line-height: 150%;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--gray-title);
}

.text-body-1,
.text-body-1 p,
.text-body-1 li {
    margin-bottom: 0;
    font-family: 'Inter', sans-serif, Arial;
    font-weight: 400;
    font-size: 18px;
    line-height: 150%;
    letter-spacing: -0.2px;
    color: var(--gray);
}

.text-body-1 strong,
.text-body-1 b {
    font-weight: 600;
    color: var(--black);
}

.text-body-2,
.text-body-2 p,
.text-body-1 li {
    margin-bottom: 0;
    font-family: 'Inter', sans-serif, Arial;
    font-weight: 400;
    font-size: 16px;
    line-height: 150%;
    letter-spacing: -0.2px;
    color: var(--gray);
}

.text-body-3,
.text-body-3 p {
    margin-bottom: 0;
    font-family: 'Montserrat', sans-serif, Arial;
    font-weight: 600;
    font-size: 20px;
    line-height: 120%;
    letter-spacing: 0;
}

.text-banner p {
    margin-bottom: 0;
    font-family: 'Montserrat', sans-serif, Arial;
    font-weight: 600;
    font-size: 20px;
    line-height: 150%;
    letter-spacing: 0;
    color: var(--white);
}

@media (max-width: 1025px) {

    .ast-header-break-point #masthead .ast-mobile-header-wrap .ast-primary-header-bar {
        padding-left: 16px;
        padding-right: 16px;
    }

    .text-body-1,
    .text-body-1 p {
        font-size: 16px;
    }

    .text-body-2,
    .text-body-2 p {
        font-size: 14px;
    }

    .text-body-3,
    .text-body-3 p,
    .text-banner,
    .text-banner p {
        font-size: 18px;
    }
}


.banner {
    padding: 32px;
    border-radius: 8px;
    background-color: var(--brand-color-1);
    background-image: url('./img/bg-icon.svg');
    background-repeat: no-repeat;
    background-position: right center;
    background-size: contain;
}

.btn-primary {
    display: inline-block;
    padding: 13px 24px;
    border-radius: 8px;
    background-color: var(--brand-color-1);
    font-family: 'Inter', sans-serif, Arial;
    font-weight: 600;
    font-size: 15px;
    line-height: 100%;
    letter-spacing: 0;
    color: var(--white);
    transition: 0.3s;
}

.site-header .btn-primary a {
    color: var(--white) !important;
}

.btn-primary:hover {
    color: var(--white);
    background-color: var(--brand-color-2);
    transition: 0.3s;
}

.row {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 32px;

    .col {
        flex: 1;
    }
}

@media(max-width: 1025px) {
    .row {
        flex-direction: column;
    }
}

.hero {
    background-color: var(--bg-light);

    .ast-container {
        background-repeat: no-repeat;
        background-position: right center;
        background-size: 675px;
    }

    .row {
        padding: 130px 0;
    }

    .text-body-1 {
        margin-bottom: 32px;
    }

    .col-img img {
        display: none;
    }
}

@media(max-width: 1025px) {
    .hero {
        .ast-container {
            background-image: none !important;
        }

        .row {
            padding: 96px 0;
        }

        .col-img img {
            display: block;
        }
    }
}

.about {

    .wrapper {
        max-width: 503px;
    }

    .text-body-1 {
        margin-bottom: 48px;
    }
}

@media(max-width: 1025px) {
    .about {

        .wrapper {
            max-width: 100%;
        }
    }
}

.heading-wrapper {
    max-width: 818px;
    margin: 0 auto;
    margin-bottom: 64px;
}

.heading-center {
    text-align: center;
}

.grid-goals {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: auto;
    gap: 24px;

    .box {
        padding: 40px;
        background-color: var(--bg-light);
        border-radius: 8px;

        .box-header {
            margin-bottom: 20px;
            display: flex;
            align-items: center;
            gap: 20px;
        }
    }
}

@media(max-width: 768px) {
    .grid-goals {
        grid-template-columns: repeat(1, 1fr);

        .box {
            padding: 32px;
        }
    }
}

.content-heading-boxes {
    padding: 16px 0 48px 0;
    text-align: center;
}

.activities-boxes {
    display: flex;
    flex-direction: column;
    gap: 32px;

    .box {
        display: flex;
        align-items: center;
        gap: 24px;

        .box-text {
            flex: 1;
            display: block;
            padding: 26.5px 32px;
            background-color: var(--bg-light);
            border-radius: 8px;
        }
    }

    .box:nth-child(even) {
        flex-direction: row-reverse;

        .box-text {
            text-align: right;
        }
    }
}

.activities-boxes {
    display: flex;
    flex-direction: column;
    gap: 32px;

    .box {
        display: flex;
        align-items: center;
        gap: 24px;

        .box-text {
            flex: 1;
            display: block;
            padding: 26.5px 32px;
            background-color: var(--bg-light);
            border-radius: 8px;
        }
    }

    .box:nth-child(even) {
        flex-direction: row-reverse;

        .box-text {
            text-align: right;
        }
    }
}

.row-container .col {
    flex: 1;
    align-self: stretch;
}

.cf-container {
    padding: 40px 40px 16px 40px;
    background-color: var(--bg-light);
    border-radius: 8px;
}

.address-container {
    padding: 40px;
    background-color: var(--bg-dark);
    border-radius: 8px;

    h6 {
        margin-bottom: 8px;
    }

    h3,
    h6,
    .box-text {
        color: var(--white);
    }

    .content-box {
        margin: 32px 0 48px 0;
        display: flex;
        flex-direction: column;
        gap: 32px;
    }

    .box {
        display: flex;
        align-items: center;
        gap: 16px;
    }

    .social-icons {
        padding-top: 24px;
        display: flex;
        align-items: center;
        gap: 24px;
    }
}

@media(max-width: 768px) {
    .cf-container {
        padding: 32px 32px 8px 32px;
    }

    .address-container {
        padding: 32px;
    }
}

/* formularz */
.data-flex {
    display: flex;
    align-items: start;
    justify-content: space-between;
    flex-direction: row;
    gap: 32px;
    flex-wrap: wrap;

    .data-column {
        flex: 0 0 calc((100% - 32px) / 2);
    }
}

.data-row {
    margin-bottom: 24px;
}

.data-checkbox {
    margin-bottom: 24px;
}

@media only screen and (max-width: 1024px) {
    .data-row {
        .data-column {
            flex: 0 0 100%;
        }
    }
}

#contact-form {
    margin: 32px 0 0 0;
}

#contact-form p {
    margin: 0;
    line-height: normal;
}

.wpcf7 #contact-form label {
    font-family: 'Inter', sans-serif, Arial;
    font-weight: 500;
    font-size: 14px;
    line-height: 20px;
    letter-spacing: 0%;
    color: var(--gray-700);
}

.wpcf7 #contact-form input.wpcf7-form-control:not([type=submit]),
.wpcf7 #contact-form textarea.wpcf7-form-control {
    margin-top: 6px;
    border-radius: 8px;
    background-color: var(--white);
    padding: 12px 16px;
    border-color: transparent;
    border: 1px solid var(--gray-300);
    box-shadow: 0px 1px 2px 0px #0A0D120D;
    font-family: 'Inter', sans-serif, Arial;
    font-weight: 400;
    font-size: 16px;
    line-height: 24px;
    letter-spacing: 0;
    color: var(--gray-700);
}

.wpcf7 #contact-form input.wpcf7-form-control:not([type=submit]) {
    height: 48px;
}

.wpcf7 #contact-form textarea.wpcf7-form-control {
    height: 88px;
    resize: vertical;
}

.wpcf7 #contact-form input.wpcf7-form-control::placeholder,
.wpcf7 #contact-form textarea.wpcf7-form-control::placeholder {
    color: var(--gray-text);
    font-style: normal;
}

.wpcf7 #contact-form input.wpcf7-form-control::-webkit-input-placeholder,
.wpcf7 #contact-form textarea.wpcf7-form-control::-webkit-input-placeholder {
    color: var(--gray-text);
}

.wpcf7 #contact-form input.wpcf7-form-control:-ms-input-placeholder,
.wpcf7 #contact-form textarea.wpcf7-form-control:-ms-input-placeholder {
    color: var(--gray-text);
}

.wpcf7 #contact-form input.wpcf7-form-control::-ms-input-placeholder,
.wpcf7 #contact-form textarea.wpcf7-form-control::-ms-input-placeholder {
    color: var(--gray-text);
}

.wpcf7 #contact-form .btn-primary {
    width: 100%;
    border-radius: 8px;
    font-family: 'Inter', sans-serif, Arial;
    font-weight: 600;
    font-size: 15px;
    line-height: 100%;
    letter-spacing: 0;
    text-align: center;
    color: var(--white);
    height: 44px;
    padding: 13px 24px;
    background-color: var(--brand-color-1);
    transition: .3s ease-out;
}

.wpcf7 #contact-form span.wpcf7-spinner {
    display: block;
}

.wpcf7 #contact-form .btn-wrapper:hover .btn-primary {
    background-color: var(--brand-color-2);
    transition: .3s ease-out;
}

small {
    margin-bottom: 32px;
    display: block;
    font-family: 'Inter', sans-serif, Arial;
    font-weight: 400;
    font-size: 12px;
    line-height: 20px;
    letter-spacing: 0;
    color: var(--gray-text);
}

.partners {
    padding: 96px 0;
}

.splide__slide {
    display: flex;
    align-items: center;
    justify-content: center;
}

.related-articles {
    padding: 96px 16px;
    background-color: var(--bg-light);

    h2 {
        text-align: center;
    }
}

@media(max-width: 1025px) {
    .related-articles {
        padding: 48px 16px;
    }
}

.site-primary-footer-wrap,
.site-below-footer-wrap {
    border: none;
}

.site-primary-footer-wrap {
    padding: 40px 0 12px 0;
}

.site-below-footer-wrap {
    padding: 9px 0 38px 0;
}

.ast-builder-html-element,
.ast-footer-copyright {
    padding-right: 16px;
    padding-left: 16px;
}

.ast-builder-html-element,
#astra-footer-menu a,
.ast-footer-copyright {
    font-family: 'Inter', sans-serif, Arial;
    font-weight: 400;
    font-size: 16px;
    line-height: 150%;
    letter-spacing: -0.2px;
    color: var(--white);
}

#astra-footer-menu a {
    position: relative;
    gap: 8px;
    padding-right: 0;
}

@media(min-width: 1026px) {
    #astra-footer-menu li:not(:last-child) a::after {
        content: "|";
    }
}

.single-post #primary {
    background-color: var(--white);
}

.heading-post {
    padding-top: 64px;
}

.post-title {
    text-align: center;
    max-width: 700px;
    margin: auto;
}

.post-img img {
    max-width: 800px;
    margin: 48px auto;
    width: 100%;
    object-fit: cover;
    aspect-ratio: 4 / 3;
    border-radius: 8px;
    display: block;
}

.content-post {
    margin: 16px 0 48px 0;
}

.content-post .row {
    max-width: 800px;
    margin: 0 auto;
}

.content-post h1,
.content-post h2,
.content-post h3,
.content-post h4,
.content-post h5,
.content-post h6 {
    margin-top: 48px;
    margin-bottom: 32px;
}

.content-post p {
    margin-bottom: 24px;
}

@media(max-width: 1025px) {
    .heading-post {
        padding: 32px 16px 0 16px;
        margin: 0;
    }

    .content-post {
        margin: 0 16px 24px 16px;
    }

    .post-img img {
        margin: 32px auto;
    }

    .content-post h1,
    .content-post h2,
    .content-post h3,
    .content-post h4,
    .content-post h5,
    .content-post h6 {
        margin-top: 24px;
        margin-bottom: 16px;
    }

}

.three-post {
    margin-top: 48px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 48px 24px;
}

@media(max-width: 768px) {
    .three-post {
        margin-top: 24px;
        gap: 32px 24px;
        grid-template-columns: repeat(1, 1fr);
    }
}

.blog-card-image img {
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 24px;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: center;
}

.blog-section {
    padding: 96px 0;
}

.blog-grid-container {
    padding: 0 0 48px 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 48px 20px;
}

@media(max-width: 768px) {
    .blog-section {
        padding: 48px 0;
    }

    .blog-grid-container {
        padding: 0;
        grid-template-columns: repeat(1, 1fr);
    }
}

.navigation.pagination {
    display: flex;
    justify-content: center;
    gap: 8px;
}

.navigation.pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    width: 52px;
    height: 52px;
    border: 1px solid #D4D4D4;
    color: var(--bg-dark);
    font-family: 'Inter', sans-serif, Arial;
    font-weight: 600;
    font-size: 18px;
    line-height: 100%;
    letter-spacing: 0;
}

.navigation.pagination .page-numbers.current,
.navigation.pagination .page-numbers:hover {
    background-color: var(--bg-dark);
    color: var(--white);
    border-color: var(--bg-dark);
}

.navigation.pagination .page-numbers:hover svg path {
    fill: var(--white);
}

.about,
.our-goals,
.our-activities,
.news,
.for_media {
    margin: 128px 0;
}

@media(max-width: 1025px) {

    .about {
        margin: 80px 0;
    }
}

@media(max-width: 768px) {

    .hero {
        .row {
            padding: 64px 0;
        }
    }

    .about,
    .our-goals,
    .our-activities,
    .news,
    .for_media {
        margin: 64px 0;
    }
}

h1.entry-title {
    display: none;
}

.privacy-policy #primary,
.page-id-115 #primary,
.page-id-117 #primary {
    padding: 64px 16px !important;
}

/* page error 404 */
.error404,
.error404 .ast-primary-header-bar {
    background-color: var(--bg-light);
    border: none
}

#error-banner {
    padding: 112px 0 100px 0;
    text-align: center;
}

#error-banner p.error-main-title {
    font-family: 'Montserrat', sans-serif, Arial;
    font-weight: 400;
    font-size: 270px;
    line-height: 110%;
    letter-spacing: 0;
    color: var(--black) !important;
}

#error-banner .row {
    max-width: 325px;
    margin: 0 auto;
    flex-direction: column;
    gap: 0;
}

#error-banner p {
    margin: 0;
}

#error-banner .btn-primary {
    margin-top: 32px;
    display: inline-block;
    position: relative;
    font-family: Bebas Neue, sans-serif, Arial;
    font-weight: 400;
    font-size: 18px;
    line-height: 120%;
    letter-spacing: 1px;
}

.news,
.for_media {
    .btn-wrapper {
        text-align: center;
    }

    .btn-primary {
        margin-top: 48px;
    }
}

.heading-container {
    background-color: var(--bg-light);
    padding: 106px 0;
}

@media(max-width: 768px) {
    .heading-container {
        padding: 48px 0;
    }
}

.heading-title {
    position: relative;
    padding-top: 24px;
}

.heading-title::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 96px;
    height: 6px;
    background-color: var(--brand-color-1);
}

.social-media {
    display: none;
}