/*
Theme Name: Avada Child
Description: Child theme for Avada theme
Author: ThemeFusion
Author URI: https://theme-fusion.com
Template: Avada
Version: 1.0.0
Text Domain:  Avada
*/



:root {
    --navy: #0D1B2A;
    --navy-mid: #152337;
    --blue: #1A56DB;
    --blue-light: #2563EB;
    --accent: #38BDF8;
    --accent-soft: #BAE6FD;
    --white: #FFFFFF;
    --off-white: #F8FAFC;
    --gray-100: #F1F5F9;
    --gray-200: #E2E8F0;
    --gray-400: #94A3B8;
    --gray-600: #475569;
    --gray-800: #1E293B;
    --text: #0F172A;
    --radius: 16px;
    --radius-sm: 10px;
}


.fusion-header {
    border-bottom: 1px solid var(--awb-custom_color_9) !important;
}

header .menu-item .button-large,
header .fusion-main-menu>ul>li.current-menu-item>a {
    font-weight: 600;
}

header .menu-item .fusion-button {
    transform: none;
    padding: 10px 22px;
}

.hero-badge p {
    display: inline-flex;
    align-items: center;
    background: var(--awb-custom_color_8);
    border: 1px solid var(--awb-custom_color_9);
    border-radius: 100px;
    gap: 8px;
    padding: 6px 16px 6px 10px;
    margin-bottom; 0;
}

.hero-badge p:before {
    content: '';
    width: 8px;
    height: 8px;
    background: var(--awb-custom_color_4);
    border-radius: 50%;
    display: block;
}

.fusion-title-heading strong {
    color: var(--awb-custom_color_4);   
}

.fusion-button {
    transition: background 0.2s, transform 0.15s;
}

.fusion-button:hover {
    transform: translateY(-1px);
}

.fusion-button.button-default > span {
    font-weight: 600;
}


/* COUNTER BOXES */
#content .fusion-counters-box .fusion-counter-box {
    padding: 0 48px 0 0;
    width: auto;
}

#content .fusion-counters-box .content-box-counter {
    font-family: 'Sora', sans-serif;
    font-weight: 700;
}

#content .fusion-counters-box .fusion-counter-box .counter-box-container {
    text-align: left;
    padding: 0;
    border: none;
}


#content .fusion-counters-box .content-box-counter span.display-counter {
    letter-spacing: -1px;
}

#content .fusion-counters-box .content-box-counter span.unit {
    color: var(--awb-custom_color_4);
    font-size: 20px;
    margin-left: 5px;
}

/* MISSIE ICON, USE CASE ICON */

.missie-icon, 
.use-icon {
    width: 44px !important;
    height: 44px;
    border-radius: 8px;
    background: rgba(37, 99, 235, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px !important;
    font-size: 20px !important;
}

.missie-icon p,
.use-icon p {
    margin-bottom: 0 !important;
}

.use-icon {
    background: #F0FDF4 !important;
}



/* USP ICON */

.usp-icon p {
    width: 40px;
    height: 40px;
    flex-shrink: 0;
    border-radius: 10px;
    background: var(--gray-100);
    border: 1px solid var(--gray-200);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    margin-bottom: 0 !important;
}




/* WERKWIJZE GRID */

.werkwijze-grid .fusion-builder-row {
    align-items: normal !important;
    gap: 2px;
    background: var(--awb-custom_color_9);
}

.werkwijze-grid .fusion-builder-row .fusion-flex-column {
    width: calc(50% - 1px);
}

@media (max-width: 768px) {

.werkwijze-grid .fusion-builder-row .fusion-flex-column {
    width: calc(100%);
}   
    
}



/* TESTIMONIAL AVATAR & STEP NUMBER */

.testimonial-avatar,
.step-num p {
    min-width: 48px !important;
    width: 48px !important;
    height: 48px;
    border-radius: 50%;
    background: var(--awb-custom_color_1);
    display: flex;
    align-items: center;
    justify-content: center;
}


.testimonial-avatar *,
.step-num * {
    margin-bottom: 0 !important;
}

.step-num {
    position: relative;
    height: 100%;
}

.step-num p {
    position: relative;
    border: 3px solid var(--awb-color1);
    box-shadow: 0 0 0 2px var(--awb-custom_color_4);
}

.step-num:before {
    content: '';
    position: absolute;
    left: 22.5px;
    top: 47px;
    width: 2px;
    background: var(--awb-custom_color_4);
    opacity: 0.5;
    height: calc(100% - 47px);
}


.process-steps .step-num {
    display: flex;
    justify-content: center;
}

.process-steps .step-num p {
    min-width: 40px !important;
    width: 40px !important;
    height: 40px;
    box-shadow: 0 0 0 1.5px var(--gray-200);
}


.process-steps .step-num:before {
    content: '';
    position: absolute;
    left: calc(50% + 15px);
    top: 21.5px;
    height: 2px;
    background: var(--blue);
    opacity: 0.5;
    width: 100%;
}

.process-steps  .fusion-layout-column:nth-last-child(1) .step-num:before {
    display: none !important;
}


/* CHECKLIST */

.fusion-checklist.fusion-checklist-divider .fusion-li-item:nth-last-child(1) {
    border: none !important;
}

.cta-list .fusion-li-icon {
    font-size: 7px !important;
}





/* TAG LIST */

.tag-list {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.tag-list .fusion-li-item {
    padding: 0 !important;
}

.tag-list .fusion-li-item-content {
    background: var(--gray-100);
    border: 1px solid var(--gray-200);
    color: var(--gray-600);
    font-size: 13px;
    font-weight: 500;
    padding: 6px 16px;
    border-radius: 100px;
    margin: 0 !important;
}

.tag-list.fusion-checklist .icon-wrapper {
    display: none !important;
}



/* TABLE */

.table-1, .table-2, .table-3, .table-4 {
    border-radius: 16px !important;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
    border: none !important;
    box-shadow: none !important;
}

table,
thead th,
tbody tr {
    background: none !important;
}

thead th {
    padding: 20px 24px !important;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 700;
    letter-spacing: 0.3px !important;
    border: none !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

thead th:nth-child(2) {
    color: white !important;
    border-radius: 12px 12px 0 0;
    background: #2563EB !important;
}

tbody tr {
    border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
    transition: background 0.15s;
}

tbody td {
    padding: 18px 24px !important;
    color: rgba(255, 255, 255, 0.3) !important;
    font-size: 13px;
    vertical-align: middle;
    border: none !important;
}

tbody td:first-child {
    font-weight: 500;
    color: white !important;
    font-size: 14px !important;
}

tbody td:nth-child(2) {
    background: rgba(37, 99, 235, 0.15);
    color: #4ADE80 !important;
    font-weight: 600;
}

tbody td strong {
    color: #FCD34D;
}




/* CONTACT BLOCK */

.contact-block {
    padding: 16px 20px;
    background: var(--gray-100);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-sm);
    font-size: 14px;
    margin-bottom: 14px !important;
}

.contact-block .usp-icon p {
    background: #fff !important;
}



/* FORM CARD */

.form-card {
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: 20px;
    padding: 40px;
    box-shadow: 0 4px 32px rgba(13, 27, 42, 0.06), 0 1px 4px rgba(13, 27, 42, 0.04);
    position: relative;
    overflow: hidden;
    animation: fadeUp 0.6s ease 0.3s both;
    margin-left: 48px;
}

.fusion-layout-column.form-card {

}

.form-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--blue-light), var(--accent));
}




/* GRAV FORM */

.gform_wrapper {
    margin-bottom: 0 !important;
}

.gform_wrapper form .top_label .gfield_label {
    margin-bottom: 6px !important;
    font-size: 13px !important;
}

p.gform_required_legend {
    display: none !important;
}

.gform_wrapper .gfield .gravity-select-parent select {
    line-height: 44px;
}

.gform_wrapper input::placeholder, 
.gform_wrapper textarea::placeholder { 
    color: var(--gray-400); 
}

.gform_wrapper .gform_footer {
    width: 100%;
}

.gform_wrapper .gform_button.button {
    width: 100%;
    margin-top: 8px;
    padding: 14px 24px;
    background: var(--blue-light) !important;
    color: white;
    font-family: 'Sora', sans-serif;
    font-size: 15px;
    font-weight: 600;
    border: none;
    border-radius: var(--radius-sm) !important;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
}

.gform_wrapper .gform_button.button:hover {
    transform: translateY(-1px);
}

#gfield_description_1_8 {
    color: var(--gray-400);
    font-weight: 300;
    font-size: 12px;
}

/*
.gform_wrapper input, 
.gform_wrapper select, 
.gform_wrapper textarea {
    width: 100%;
    background: var(--off-white);
    border: 1.5px solid var(--gray-200);
    border-radius: var(--radius-sm);
    padding: 11px 14px;
    color: var(--text);
    font-size: 15px;
    font-weight: 400;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
    resize: vertical;
}

*/


@media only screen and (max-width: 1024px) {

.form-card {
    margin-top: 48px !important;
    margin-left: 0;
}

}

@media only screen and (max-width: 1000px) {

.fusion-tb-footer.fusion-footer .fusion-flex-justify-content-space-between {
    flex-direction: column !important;
    gap: 16px;
}

.fusion-tb-footer.fusion-footer .fusion-flex-justify-content-space-between img {
    margin-bottom: 5px;
}

}



@media only screen and (max-width: 800px) {

body .fusion-mobile-menu-design-modern.fusion-header-v1 .fusion-header {
    padding-bottom: 10px;
}

.fusion-mobile-menu-design-modern .fusion-header>.fusion-row {
    padding: 0;
}

body .fusion-mobile-menu-design-modern.fusion-header-v1 .fusion-logo {
    margin-top: 4px !important;
}

}


@media only screen and (max-width: 800px) { 

.process-steps .step-num:before {
    display: none !important;
}


}