/* 
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme/
Description: Hello Elementor Child Theme
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 1.0.1
Text Domain: hello-elementor-child
*/


/* =========================================================
   ROOT
========================================================= */

:root {

  --color-primary: #A3C1FA;
  --color-secondary: #AFB4F9;

  --color-heading: #111111;
  --color-text: #5B6475;

  --color-white: #FFFFFF;
  --color-border: #E7EAF1;

  --site-width: 1240px;

  --transition:
    240ms cubic-bezier(.4,0,.2,1);

}


/* =========================================================
   RESET
========================================================= */

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {

  margin: 0;

  overflow-x: hidden;

  background: #FDFDFD;

  color: var(--color-text);

  text-rendering: optimizeLegibility;

  -webkit-font-smoothing: antialiased;
}

img {

  display: block;

  max-width: 100%;

  height: auto;
}

a {

  color: inherit;

  text-decoration: none;
}


/* =========================================================
   HERO SECTION
========================================================= */

.hero-section {

  position: relative;

  display: flex;
  align-items: center;

  width: 100%;

  min-height: 680px;

  padding:
    110px
    0
    110px;

  overflow: hidden;

  isolation: isolate;

  background-color: #FDFDFD;
}


/* =========================================================
   HERO INNER CONTAINER
========================================================= */

.hero-section > .e-con-inner,
.hero-section > .e-con {

  width: 100%;
  max-width: 1240px;

  margin-inline: auto;

  padding-inline: 32px;

  position: relative;
  z-index: 2;
}


/* =========================================================
   HERO IMAGE
========================================================= */

.hero-section::before {

  content: '';

  position: absolute;

  inset: 0;

  z-index: 0;

  background-image:
    url('/wp-content/uploads/2026/05/webrank-hero-image-clean.webp');

  background-repeat: no-repeat;

  background-position:
    right -140px center;

  background-size:
    min(58vw, 980px);

  opacity: 1;

  pointer-events: none;
}


/* =========================================================
   BLUE BLUR
========================================================= */

.hero-section::after {

  content: '';

  position: absolute;

  right: -220px;
  top: 50%;

  width: 820px;
  height: 820px;

  transform: translateY(-50%);

  border-radius: 50%;

  background:
    radial-gradient(
      circle,
      rgba(163,193,250,0.32) 0%,
      rgba(175,180,249,0.16) 42%,
      rgba(255,255,255,0) 76%
    );

  filter: blur(80px);

  z-index: 0;

  pointer-events: none;
}


/* =========================================================
   PURPLE BLUR
========================================================= */

.hero-content::before {

  content: '';

  position: absolute;

  right: -620px;
  top: 42%;

  width: 620px;
  height: 620px;

  border-radius: 50%;

  background:
    radial-gradient(
      circle,
      rgba(170,155,255,0.22) 0%,
      rgba(196,184,255,0.12) 42%,
      rgba(255,255,255,0) 76%
    );

  filter: blur(90px);

  z-index: -1;

  pointer-events: none;
}


/* =========================================================
   HERO CONTENT
========================================================= */

.hero-content {

  position: relative;

  z-index: 2;

  display: flex;
  flex-direction: column;

  justify-content: center;

  gap: 22px;

  width: 100%;
  max-width: 560px;
}


/* =========================================================
   EYEBROW
========================================================= */

.h-alt,
.h-alt.e-heading-base {

  margin: 0;

  font-family: 'Poppins', sans-serif !important;

  font-size: 0.88rem;

  font-weight: 600;

  line-height: 1.4;

  letter-spacing: 0.12em;

  text-transform: uppercase;

  color: #8C94A8;
}


/* =========================================================
   MAIN HEADING
========================================================= */

h1.h-one.e-heading-base,
.h-one {

  margin: 0;

  max-width: 8.4ch;

  font-family: 'Antonio', sans-serif !important;

  font-size: 56px !important;

  font-weight: 700;

  line-height: 0.9;

  letter-spacing: -0.07em;

  color: var(--color-heading);

  text-wrap: balance;
}


/* =========================================================
   PARAGRAPH
========================================================= */

.paragraph-dark,
.paragraph-dark.e-text-base {

  margin: 0;

  max-width: 34ch;

  font-family: 'Poppins', sans-serif !important;

  font-size: 1.02rem;

  font-weight: 400;

  line-height: 1.85;

  letter-spacing: -0.015em;

  color: var(--color-text);

  text-wrap: pretty;
}


/* =========================================================
   BUTTON WRAP
========================================================= */

.hero-buttons {

  display: flex;
  align-items: center;

  gap: 14px;

  flex-wrap: wrap;

  margin-top: 6px;
}


/* =========================================================
   ELEMENTOR BUTTON BASE
========================================================= */

.elementor .e-button-base {

  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-height: 56px;

  padding:
    0
    28px;

  border-radius: 999px;

  font-family: 'Poppins', sans-serif !important;

  font-size: 0.96rem;

  font-weight: 600;

  line-height: 1;

  letter-spacing: -0.01em;

  transition:
    transform var(--transition),
    opacity var(--transition),
    border-color var(--transition),
    background-color var(--transition);

  will-change: transform;
}


/* =========================================================
   PRIMARY BUTTON
========================================================= */

.elementor .e-button-base.btn-main,
.btn-main .e-button-base,
.btn-main .elementor-button {

  border: 0;

  background:
    linear-gradient(
      135deg,
      #A3C1FA,
      #AFB4F9
    );

  color: #111111;

  box-shadow:
    0 14px 40px rgba(163,193,250,0.28);
}

.elementor .e-button-base.btn-main:hover,
.btn-main .e-button-base:hover,
.btn-main .elementor-button:hover {

  transform: translateY(-2px);

  opacity: 0.96;
}


/* =========================================================
   SECONDARY BUTTON
========================================================= */

.elementor .e-button-base.btn-alt,
.btn-alt .e-button-base,
.btn-alt .elementor-button {

  border:
    1px solid var(--color-border);

  background:
    rgba(255,255,255,0.88);

  backdrop-filter: blur(10px);

  color: var(--color-heading);

  box-shadow:
    0 10px 30px rgba(17,17,17,0.04);
}

.elementor .e-button-base.btn-alt:hover,
.btn-alt .e-button-base:hover,
.btn-alt .elementor-button:hover {

  transform: translateY(-2px);

  border-color: var(--color-primary);
}


/* =========================================================
   TRUST TEXT
========================================================= */

.hero-trust {

  margin-top: 4px;

  font-family: 'Poppins', sans-serif !important;

  font-size: 0.96rem;

  font-weight: 500;

  line-height: 1.5;

  color: #7A8398;
}


/* =========================================================
   LARGE DESKTOP
========================================================= */

@media (min-width: 1600px) {

  .hero-section::before {

    background-size:
      1080px;

    background-position:
      right -80px center;
  }

  .hero-section::after {

    right: -120px;
  }
}


/* =========================================================
   TABLET
========================================================= */

@media (max-width: 1024px) {

  .hero-section {

    justify-content: flex-start;

    min-height: auto;

    padding:
      110px
      0
      680px;
  }

  .hero-section > .e-con-inner,
  .hero-section > .e-con {

    padding-inline: 24px;
  }

  .hero-section::before {

    background-position:
      center bottom;

    background-size:
      820px;
  }

  .hero-section::after {

    width: 620px;
    height: 620px;

    right: 50%;

    top: auto;
    bottom: 60px;

    transform:
      translateX(50%);
  }

  .hero-content {

    align-items: center;

    max-width: 100%;

    text-align: center;
  }

  .hero-content::before {

    display: none;
  }

  h1.h-one.e-heading-base,
  .h-one {

    max-width: 10ch;

    font-size: 52px !important;
  }

  .paragraph-dark {

    max-width: 42ch;
  }

  .hero-buttons {

    justify-content: center;
  }
}


/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 767px) {

  .hero-section {

    align-items: flex-start;

    min-height: auto;

    padding:
      90px
      0
      460px;
  }

  .hero-section > .e-con-inner,
  .hero-section > .e-con {

    padding-inline: 20px;
  }

  .hero-section::before {

    background-position:
      center bottom;

    background-size:
      540px;
  }

  .hero-section::after {

    width: 380px;
    height: 380px;

    bottom: 40px;

    right: 50%;

    transform:
      translateX(50%);
  }

  .hero-content {

    gap: 18px;

    align-items: flex-start;

    text-align: left;
  }

  h1.h-one.e-heading-base,
  .h-one {

    max-width: 100%;

    font-size: 42px !important;

    line-height: 0.94;

    letter-spacing: -0.06em;
  }

  .paragraph-dark {

    max-width: 100%;

    font-size: 1rem;

    line-height: 1.75;
  }

  .hero-buttons {

    width: 100%;

    flex-direction: column;

    align-items: stretch;
  }

  .hero-buttons .e-button-base,
  .hero-buttons .elementor-button {

    width: 100%;
  }

  .hero-trust {

    max-width: 20ch;
  }
}