/*** ---------- Buttons ---------- ***/
a { color: var(--clr-text); }

.btn, .gform_button, .gform_next_button, .gform_previous_button, .button { 
    --fs: 1.3rem; 
    --lh: 1; 
    --p: 0 1.4rem; 
    --br: 5rem; 
    --gap: 1rem;

    --clr: #fff; --bg-clr: var(--clr-primary); --border: 1px solid var(--clr-primary); --box-shadow: none; 
    --hover-clr: var(--clr); --hover-bg-clr: var(--bg-clr); --hover-border: var(--border); --hover-box-shadow: var(--box-shadow); 
    --focus-clr: var(--hover-clr); --focus-bg-clr: var(--hover-bg-clr); --focus-border: var(--hover-border); --focus-box-shadow: 0 0 0 .5rem var(--clr-primary-20); 
    --active-clr: var(--focus-clr); --active-bg-clr: var(--focus-bg-clr); --active-border: var(--focus-border); --active-box-shadow: var(--focus-box-shadow); 

    display: inline-flex; justify-content: center; align-items: center; min-height: 3.3rem; gap: var(--gap); font-size: var(--fs); line-height: var(--lh); padding: var(--p); color: var(--clr); background-color: var(--bg-clr); 
    border-radius: var(--br); border: var(--border); box-shadow: var(--box-shadow); font-weight: 700; text-align: center; text-decoration: none; vertical-align: middle; cursor: pointer; user-select: none; 
    
    transition-duration: var(--ts-duration);
    transition-timing-function: var(--ts-function);

    font-family: var(--font-primary); transition-property: color, background-color, border-color, box-shadow, -webkit-box-shadow;
}
.btn span, .gform_button span, .gform_next_button span, .gform_previous_button span, .button span { font: inherit; color: inherit; }
.btn i, .gform_button i, .gform_next_button i, .gform_previous_button i { --clr: inherit; }
.btn:hover, .gform_button:hover, .gform_next_button:hover, .gform_previous_button:hover, .button:hover { color: var(--hover-clr)!important; background-color: var(--hover-bg-clr)!important; border: var(--hover-border)!important; box-shadow: var(--hover-box-shadow)!important; }
.btn:hover i, .gform_button:hover i, .gform_next_button:hover i, .gform_previous_button:hover i { --clr: var(--hover-clr); }
.btn:focus, .gform_button:focus, .gform_next_button:focus, .gform_previous_button:focus, .gform_button:focus { color: var(--focus-clr)!important; background-color: var(--focus-bg-clr)!important; border: var(--focus-border)!important; box-shadow: var(--focus-box-shadow)!important; }
.btn:focus i, .gform_button:focus i, .gform_next_button:focus i, .gform_previous_button:focus i, .gform_button:focus i { --clr: var(--focus-clr); }
.btn:active, .gform_next_button:active, .gform_previous_button:active, .button:active { color: var(--active-clr)!important; background-color: var(--active-bg-clr)!important; border: var(--active-border)!important; box-shadow: var(--active-box-shadow)!important; }
.btn:active i, .gform_next_button:active i, .gform_previous_button:active i { --clr: var(--active-clr); }

.btn.btn--small { --p: 0 1.5rem; --fs: 1.4rem; min-height: 3.6rem; }
.btn.btn--large { --p: 0 2.6rem; --fs: 1.8rem; min-height: 5.3rem; }

.btn.btn--square { --p: 0; aspect-ratio: 1/1; }

.btn.btn--primary, .button { --clr: rgb(255,255,255); --bg-clr: var(--clr-primary); --border: 1px solid transparent; --hover-bg-clr: var(--clr-blue); }
.btn.btn--secondary { --clr: var(--clr-primary); --bg-clr: var(--clr-secondary); --border: 1px solid transparent; --hover-clr: var(--clr-secondary); --hover-bg-clr: var(--clr-primary); }
.btn.btn--outline { --clr: var(--clr-secondary); --bg-clr: transparent; --border: 2px solid var(--clr-border); --box-shadow: none; --hover-clr: #fff; --hover-bg-clr: var(--clr-primary); --hover-border: 2px solid transparent; }
.btn.btn--light { --clr: var(--clr-secondary); --bg-clr: var(--clr-moss); --border: none; --box-shadow: none; --hover-clr: #fff; --hover-bg-clr: var(--clr-primary); --hover-border: none; }

.btn.btn--white { --clr: var(--clr-secondary); --bg-clr: #fff; --border: 1px solid #fff; --box-shadow: none; --hover-clr: #fff; --hover-bg-clr: var(--clr-dark); --hover-border: 1px solid var(--clr-dark); }
.btn.btn--link { --clr: var(--clr-dark); --bg-clr: transparent; --border: 1px solid transparent; --box-shadow: none; }

/* Special color buttons */
.btn.btn--blue { --clr: rgb(255,255,255); --bg-clr: var(--clr-blue); --border: 1px solid transparent; --hover-bg-clr: var(--clr-purple); }
.btn.btn--purple { --clr: rgb(255,255,255); --bg-clr: var(--clr-purple); --border: 1px solid transparent; --hover-bg-clr: var(--clr-orange); }
.btn.btn--orange { --clr: rgb(255,255,255); --bg-clr: var(--clr-orange); --border: 1px solid transparent; --hover-bg-clr: var(--clr-blue); }

.btn.btn--blur { --clr: rgb(255,255,255); --bg-clr: rgba(255, 255, 255, 0.2); --border: 1px solid transparent; --hover-bg-clr: var(--clr-primary); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
.btn.btn--rotated{ --br: .5rem; transform: rotate(var(--glob-rotation)); min-height: 4.4rem; }
.btn.btn--rotated *{ transform: rotate(calc(-1 * var(--glob-rotation))); }
.btn.btn--filter::before{ content: ''; position: absolute; top: .6rem; right: -.6rem; width: .9rem; height: .9rem; border-radius: 50%; background-color: var(--clr-primary); transition: background var(--ts-duration) ease; }
.btn.btn--filter:hover::before{ background-color: var(--clr-secondary-60); }


.btn-group { --gap: 1rem; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-align: center; -ms-flex-align: center; align-items: center; gap: var(--gap); }  

:is(.wpb-bg-clr--primary, .wpb-bg-clr--dark, .has-background-image) .btn.btn--outline{ --clr: #fff; --border: 2px solid rgba(255, 255, 255, 0.3); }



@media (min-width: 768px){
    .btn, .gform_button, .gform_next_button, .gform_previous_button, .button { --fs: 1.6rem; --p: 0 2.8rem; min-height: 4.7rem; }
}