/* ------------------------ */
/* HERO SECTION             */
/* ------------------------ */

.hero-section {
    background: var(--hero-background-gradient);
}
.hero-background {
    width: 100%;
    height: 100%;
    background-image: url("/images/background_mesh_01.svg"), url("/images/hero_circle.webp");
    background-position: top center, center 120%;
    background-repeat: repeat-x, no-repeat;
    background-size: auto;
    padding-bottom: 25px;
}

.hero-container {
    max-width: 1040px;
    margin: auto;
}

.hero-title {
    color: var(--clr-neutral-100);
    font-size: 4em;
    font-weight: bold;
    text-align: center;
    
    padding-top: 30px;

    display: inline-block;
    margin: auto;
    max-width: 850px;
}

.hero-paragraph {
    text-align: center;
    font-size: 1.2em;
    display: inline-block;
    margin: auto;
    max-width: 620px;
}

.hero-text-under-button {
    text-align: center;
    padding: 20px;
}

.hero-clients {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 15px;
    color: var(--clr-neutral-100);
    margin: auto;
    margin-block: 50px 0px;
}

.hero-cards {
    margin-top: 70px;
}

.hero-cards .row{
    padding-bottom: 20px;
    gap: 20px;
}

.hero-card {
    max-width: 450px;
    background-color: var(--clr-dark-700);
    padding: 10px 20px;
    color: var(--clr-neutral-100);
    margin: auto;
    border-radius: 13px;
    border: 2px solid var(--clr-dark-400);
    text-align: center;
}

.hero-card h2 {
    font-size: 2.5em;
    font-weight: bold;
}

.hero-card .accent-text {
    margin-top: -15px;
}

.hero-card-text {
    font-size: 1.1em;
    max-width: 80%;
}

.hc-01 {
    margin: auto;
    margin-block: 10px;
}
.tc-01 {
    margin: auto;
    padding-bottom: 10px;
}
.hc-02 {
    margin-right: -50px;
}
.tc-02 {
    text-align: left;
}
.hc-03 {
    margin-left: -50px;
}
.tc-03 {
    text-align: right;
}
.hc-row {
    padding-top: 20px;
    justify-content: space-around !important;
    align-items: normal !important;
}

.hero-secure {
    color: var(--clr-neutral-100);
    justify-content: space-around;
    margin: auto;
    opacity: 0.8;
}

.hero-secure svg{
    display: inline;
    padding-top: 5px;
    transform: translateY(2px);
}

.hero-secure p{
    display: inline;
}

/* ------------------------ */
/* HWH SECTION              */
/* ------------------------ */

.hwh-section {
    background-color: var(--clr-primary-100);
    padding-block: 100px;
    /*
    background-image: url("/images/hwh_circle.webp"), url("/images/hwh_circle.webp");
    background-repeat: no-repeat, no-repeat;
    background-position: 90% 70%, 12% 97%;
    background-size: auto, 20%;
    */
}

.hwh-block {
    background-color: var(--clr-neutral-100);
    border-radius: 20px;
    padding: 40px 40px;
    border: 1px 0 0 0 solid var(--clr-primary-200);
    box-shadow: 0 0 5px 0 var(--clr-primary-200);
    transition: all 300ms ease;
}

.hwh-block:hover {
    border-radius: 10px;
    transform: translateX(5px);
}

.hwh-block-accent {
    text-align: center;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex-wrap: wrap;
}

.hwh-block-accent:hover {
    transform: translateY(-5px);
}

.hwh-block-accent .hwh-block-text {
    margin: auto;
    width: 90%;
    text-align: center;
    margin-top: 100px;
}

.hwh-block h3 {
    font-size: 2.5em;
    font-weight: bold;
    margin-top: -10px;
    cursor: default;
}

.hwh-block-text {
    font-size: 1.2em;
    text-align: justify;
    margin-block: 20px;
    color: var(--clr-dark-500);
}

.hwh-container {  display: grid;
  grid-template-columns: 1.5fr 1fr;
  grid-template-rows: auto auto auto;
  gap: 30px 30px;
  grid-auto-flow: row;
  grid-template-areas:
    "ar1 ar4"
    "ar2 ar4"
    "ar3 ar4";
}

.ar1 { grid-area: ar1; }

.ar2 { grid-area: ar2; }

.ar3 { grid-area: ar3; }

.ar4 { grid-area: ar4; }

.hwh-img {
    margin: auto;
    margin-top: -10px;
    margin-bottom: 20px;
}

.hwh-h {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 15px;
}
.hwh-h svg{
    margin-top: 5px;
}


/* ------------------------ */
/* TEAM SECTION             */
/* ------------------------ */

.team-section {
    background-color: var(--clr-primary-100);
    padding-block: 100px;
}

.founder {
    background: var(--team-background-gradient);
    border: 1px solid var(--clr-primary-500);
    border-left: 0;
    border-right: 0;
}

.founder-background {
    background-image: url("/images/background_mesh_02.svg"), url("/images/background_mesh_02.svg");
    background-position: center right, center left;
    background-repeat: no-repeat;
    background-size: contain;
}

.founder-data {
    max-width: 600px;
}

.founder-data p{
    color: var(--clr-dark-600);
    font-size: 1.1em;
}

.founder-image {
    max-width: 600px;
    position: relative;
}

.founder-01 .founder-image::before {
    content: "LEAD DEVELOPER \A & LEAD STRATEGIST";
    white-space: pre;
    font-family: var(--ff-accent);
    color: var(--clr-primary-600);
    font-size: 0.8em;
    position: absolute;
    text-align: center;
    top: 50%;
    left: 17%;
}

.founder-01 .founder-image::after {
    content: "FOUNDER OF \A HELIANAGENCY.COM";
    white-space: pre;
    font-family: var(--ff-accent);
    color: var(--clr-primary-600);
    font-size: 0.8em;
    position: absolute;
    text-align: center;
    top: 33%;
    left: 62%;
}

.founder-02 .founder-image::before {
    content: "MARKETING DIRECTOR \A & FUNNEL ENGINEER";
    white-space: pre;
    font-family: var(--ff-accent);
    color: var(--clr-primary-600);
    font-size: 0.8em;
    position: absolute;
    text-align: center;
    top: 50%;
    left: 17%;
}

.founder-02 .founder-image::after {
    content: "FOUNDER OF \A HELIANAGENCY.COM";
    white-space: pre;
    font-family: var(--ff-accent);
    color: var(--clr-primary-600);
    font-size: 0.8em;
    position: absolute;
    text-align: center;
    top: 33%;
    left: 62%;
}

.founder h3{
    font-size: 3em;
    font-weight: bold;
    color: var(--clr-dark-600);
}

/* Separator */

.founder-separator {
    width: auto;
    overflow: hidden;
    height: 75px;
}
.founder-separator-block {
    flex-wrap: nowrap !important;
    gap: 50px;
    animation: moveLeft 60s linear infinite;
}
.fs-b {
    display: inline-block;
    flex-shrink: 0;
}
@keyframes moveLeft {
  0% {
    transform: translateX(0);
  }
  50% {
    transform: translateX(-50%);
  }
  100% {
    transform: translateX(0);
  }
}


.team-container {
    padding-top: 50px;
}

.team-block {
    padding-top: 20px;
    max-width: 32%;
    background-image: url("/images/team_circle.webp");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 60%;
    padding-bottom: 50px;
}

.team-block h3 {
    font-size: 2em;
    font-weight: bold;
    text-align: center;
    margin-bottom: 10px;
}

.team-block-text {
    text-align: center;
    color: var(--clr-dark-600);
}

.team-block-w {
    background-color: var(--clr-neutral-100);
    padding: 5px 25px 15px 25px;
    border-radius: 13px;
    box-shadow: 0 0 10px 0 var(--clr-primary-200);
    border: 1px solid var(--clr-neutral-100);
    transition: all 200ms ease;
    cursor: default;
}

.team-block-w:hover{
    border-color: var(--clr-primary-400);
}

.team-block-w-accent {
    border: 1px solid var(--clr-primary-500);
}


/* ------------------------ */
/* MISSION SECTION          */
/* ------------------------ */

.mission-section {
    background: var(--mission-background-gradient);
}

.mission-background {
    width: 100%;
    height: 100%;
    background-image: url("/images/flow_01.webp"), url("/images/flow_02.webp"), url("/images/background_mesh_01.svg");
    background-position: top center, bottom center, top center;
    background-repeat: no-repeat, no-repeat, repeat-x;
    background-size: contain, contain, auto;
    padding-top: 200px;
    padding-bottom: 200px;
}

.mission-row {
    display: flex;
    align-items: stretch;
}

.mission-block {
    border-radius: 13px;
    background-color: var(--clr-dark-700);
    border: 2px solid var(--clr-dark-500);
    color: var(--clr-neutral-100);
    padding: 20px 20px 50px 20px;
    max-width: 33%;
}
.mission-block h3 {
    font-size: 2.5em;
    font-weight: bold;
    text-align: center;
}

.mission-block p {
    text-align: center;
}

.mission-subtext {
    max-width: 40%;
    margin: auto;
    color: var(--clr-neutral-100);
    text-align: center;
    margin-top: 80px;
}

/* -------------------------*/
/* Newsletter               */
/* -------------------------*/

.newsletter-section {
    background-color: var(--clr-primary-100);
    padding-top: 100px;
}

.newsletter-info-text {
    text-align: center;
    margin-top: 20px;
}

.newsletter-email {
    font-family: var(--ff-primary);
    margin: auto;
}
.newsletter-email input{
    display: block;
    color: var(--clr-dark-800);
    width: 400px;
    font-size: 1.2em;
    background-color: var(--clr-neutral-100);
    padding-inline: 10px;
    padding-block: 5px;
    border: 1px solid var(--clr-primary-600);
    border-radius: 5px;
    outline: none !important;
}
.newsletter-email input:focus {
    outline: none !important;
}
.newsletter-email button{
    color: var(--clr-primary-800);
    font-family: var(--ff-primary);
    font-weight: bold;
    font-size: 1.5em;
    padding-inline: 30px;
    background-color: var(--clr-primary-500);
    border: none;
    transition: all 200ms ease;
    border-radius: 5px;
    cursor: pointer;
    display: block;
    margin: auto;
    margin-top: 10px;
}
.newsletter-email button:hover {
    background-color: var(--clr-primary-400);
}

/* ------------------------ */
/* FAQ                      */
/* ------------------------ */
.faq-section {
    padding-top: 100px;
    background-color: var(--clr-primary-100);
}

.faq {
    max-width: 700px;
    margin: auto;
}

.faq-b {
    background-color: var(--clr-neutral-100);
    padding: 10px 30px;
    border-radius: 13px;
    margin-bottom: 20px;
    box-shadow: 0 0 10px 0 var(--clr-dark-100);
    border: 1px solid var(--clr-neutral-100);
}

.faq-b:hover {
    border-color: var(--clr-primary-250);
}

.faq-b:hover .plus{
    color: var(--clr-primary-400);
}

.faq-b div {
    display: flex;
    justify-content: space-between;
}

.faq-q {
    font-size: 1.5em;
    font-weight: bold;
    color: var(--clr-dark-800);
    display: inline-block;
    cursor: default;
}

.faq-a {
    display: none;
    margin-top: 10px;
    font-size: 1em;
    color: var(--clr-dark-500);
}

.faq-show-a>p{
    display: block !important;
}

.faq-b .plus {
    color: var(--clr-primary-500);
    font-weight: bold;
    font-size: 3em;
    line-height: 0.6em;
    transition: all 200ms ease;
    cursor: default;
}

.faq-b .plus::selection {
    background-color: transparent;
    color: var(--clr-primary-500);
}

/* Bot BTN */

/* DEMO bot-btn */

.bot-btn {
    font-family: var(--ff-primary);
    position: fixed;
    bottom: 20px;
    right: 20px;
    padding: 5px 20px;
    border-radius: 50vh;
    color: var(--clr-primary-850);
    background-color: var(--clr-primary-400);
    transition: all 300ms ease;
    font-weight: bold;
}

.bot-btn:hover{
    color: var(--clr-primary-200);
    background-color: var(--clr-primary-600);
}

/* ------------------------ */
/* BOOK A CALL SECTION      */
/* ------------------------ */

.bac-section {
    padding-top: 100px;
    padding-bottom: 100px;
    background-color: var(--clr-primary-100);
}

.bac-section svg {
    margin: auto;
}

/* --------------------------------- */
/* --------------------------------- */
/* --------------------------------- */

@media only screen and (max-width: 1300px) {
    .founder-data {
        max-width: 420px;
    }
}

@media only screen and (max-width: 1130px) {
    .founder-data {
        max-width: 80%;
        text-align: justify;
        margin: auto;
        padding-top: 30px;
        padding-bottom: 50px;
    }
    .founder-image {
        margin: auto;
    }
    .founder-02 .row {
        flex-direction: column-reverse !important;
    }

    .founder-background {
        background-image: url("/images/background_mesh_02.svg");
        background-position: right center;
        background-repeat: no-repeat;
        background-size: contain;
    }
}

@media only screen and (max-width: 1040px) {
    .team-block {
        max-width: 70%;
        padding-top: 10px;
        padding-bottom: 10px;
    }
    .team-block-row{
        flex-direction: column !important;
    }

    .mission-block {
        max-width: 70%;
        margin-top: 10px;
        margin-bottom: 10px;
    }
    .mission-row {
        flex-direction: column !important;
    }
}

@media only screen and (max-width: 960px) {
    .hwh-container {  
        display: grid;
        grid-template-columns: 1fr;
        grid-template-rows: auto;
        gap: 30px 30px;
        grid-auto-flow: row;
        grid-template-areas:
        "ar1"
        "ar2"
        "ar3"
        "ar4";
    }
    .hwh-block-text {
        margin-top: 10px !important;
        margin-bottom: 50px !important;
    }

    .mission-subtext {
        max-width: 60%;
    }
}

@media only screen and (max-width: 939px) {
    .hc-02, .hc-03 {
        display: none;
    }
    .tc-02, .tc-03 {
        text-align: center;
    }
}

@media only screen and (max-width: 669px) {
    .bac-section svg {
        margin-block: 50px;
    }
}

@media only screen and (max-width: 630px) {
    .team-block {
        max-width: 100%;
    }

    .founder-data {
        max-width: 100%;
    }

    .founder-01 .founder-image::before {
        font-size: 0.7em;
        top: 50%;
        left: 15%;
    }
    .founder-01 .founder-image::after {
        font-size: 0.7em;
        top: 33%;
        left: 62%;
    }
    .founder-02 .founder-image::before {
        font-size: 0.7em;
        top: 50%;
        left: 15%;
    }
    .founder-02 .founder-image::after {
        font-size: 0.7em;
        top: 33%;
        left: 62%;
    }

    .mission-block {
        max-width: 100%;
    }

    .mission-subtext {
        padding-inline: 20px;
        max-width: 100%;
    }

}

@media only screen and (max-width: 510px) {
    .hero-title {
        font-size: 3.5em;
    }

    .newsletter-email form {
        width: 300px;
    }
    .newsletter-email input{
        width: 100%;
    }
    .newsletter-email button{
        width: 100%;
    }
}

@media only screen and (max-width: 460px) {

    .founder-image {
        transform: scale(1.15) translateY(-17px);
    }

}

@media only screen and (max-width: 420px) {

    .founder-image {
        transform: scale(1.15) translateY(-14px);
    }

    .founder-01 .founder-image::before {
        font-size: 0.6em;
        top: 50%;
        left: 10%;
    }
    .founder-01 .founder-image::after {
        font-size: 0.6em;
        top: 33%;
        left: 62%;
    }
    .founder-02 .founder-image::before {
        font-size: 0.6em;
        top: 50%;
        left: 10%;
    }
    .founder-02 .founder-image::after {
        font-size: 0.6em;
        top: 33%;
        left: 62%;
    }

}

@media only screen and (max-width: 370px) {

    .founder-image {
        transform: scale(1.15) translateY(-13px);
    }

    .newsletter-email form {
        width: 250px;
    }

}


/* ANIMATIONS */

/* Initial state */
.animation-ap1 {
  opacity: 0;
  transform: translateY(60px);
  transition: opacity 1s cubic-bezier(0.4,0,0.2,1), transform 0.8s cubic-bezier(0.4,0,0.2,1);
}

/* Animated state */
.animation-ap1.visible {
  opacity: 1;
  transform: translateY(0);
}

