/* overides for other common style sheets */

body.product-page .hero-bkg, body.product-page-reverse .hero-bkg {
    overflow: visible;
    top: -20%;
}

body.product-page .hero-content img.icon {
    border-radius: none;
    -webkit-box-shadow: none;
    box-shadow: none;
}

body.family-page .hero-content {
    padding: 10% 15px;
}

body.product-page .hero-content h1 {
    color: #78be20;
    font-size: 24px;
    font-weight: bold;
    line-height: normal;
    margin: 0;
    padding: 20px 0 0 0;
    width: auto;
}

body.product-page .hero-content p.price {
    clear: none;
    margin: 0;
    line-height: normal;
    color: #69819a;
    font-size: 48px;
    font-weight: 600;
    letter-spacing: 1px;
}

body.product-page .hero-content p.price sup {
    font-size: 50%;
    top: -.8em;
}

body.product-page .hero-content p.price span.per-year {
    font-size: 15px;
    font-weight: normal;
    position: relative;
    top: -10px;
}

body.product-page .hero-content h2 {
    clear: left;
    font-size: 28px;
    line-height: normal;
    color: #1c4ca4;
    margin: 0 0 4% 0;
}

body.product-page .hero-content p {
    margin-bottom: 6%;
    line-height: 1.35em;
}

body.product-page .hero-bkg .hero-bkg-image img.hero-illustration {
    top: revert;
    left: -60px;
    bottom: -50px;
    min-width: 1100px;
    width: 100%;
    max-width: 1300px;
}

section.family-apps {
    position: relative;
    margin-top: 60px;
    margin-bottom: 0;
    text-align: center;
}

section.family-apps h2,
body.product-page section.app-features .feature-description h2 {
    text-align: left;
    font-size: 28px;
    line-height: normal;
    color: #1c4ca4;
}

body.product-page section.app-features .feature-description h2 {
    text-transform: none;
    opacity: 1;
    margin: 2.5% 0;
    padding: 0;
}

section.family-apps p,
body.product-page section.app-features .feature-description p {
    text-align: left;
    color: #526f8a;
}

body.product-page section.app-features .feature-description p {
    margin: 0 0 1.5rem 0;
    width: 85%;
}

body.product-page section.app-features .feature-description>h3 {
    letter-spacing: .5px;
    line-height: normal;
    text-transform: none;
    font-size: .875em;
    font-weight: 600;
    text-transform: uppercase;
    color: #78be20;
    margin: 0;
}

body.product-page section.app-features .feature-row {
    display: flex;
    flex: 1 0 auto;
    height: 100%;
    flex-direction: row;
    align-content: center;
    justify-content: center;
    position: relative;
    padding: 35px 30px;
    border: 2px solid #78be20;
    background-color: #fff;
    border-radius: 6px;
    z-index: 1;
}

body.family-page section.family-app-detail .feature-description {
    padding: 0 0 0 .5em;
}

body.family-page section.family-app-detail .feature-table {
    margin-top: 35px;
    margin-bottom: 35px;
}

.learn-more-cta .btn {
    border: 1px solid #69819a;
    color: #69819a;
    font-weight: 600;
}

section.family-app-detail img.icon {
    width: 100px;
    height: 100px;
    float: left;
    margin: 0 20px 0 0;
    -webkit-box-shadow: none;
    box-shadow: none;
    border-radius: none;
}

.circle {
    position: absolute;
    background-color: #fff;
    border: 1px solid #78be20;
    height: 22px;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    width: 22px;
}

.circle.filled {
    background-color: #78be20;
    width: 15px;
    height: 15px;
}

.circle.right {
    top: 50%;
    right: -11px;
}

.circle.filled.right {
    top: calc(50% + 4px);
    right: calc(-20.833333335% - 35px);
}

.circle.left {
    top: 50%;
    left: -11px;
}

.circle.top {
    top: -11px;
    left: calc(50% - 11px);
}

.circle.filled.left {
    top: calc(50% + 4px);
    left: calc(-20.833333335% - 35px);
}

.line-horizontal {
    position: absolute;
    display: block;
    height: 1px;
    border: 0;
    border-top: 2px solid #78be20;
    padding: 0;
    z-index: -1;
}

.line-horizontal.right {
    top: calc(50% + 11px);
    right: calc(-20.833333335% - 35px);
    width: calc(20.833333335% + 35px);
}

.line-horizontal.left {
    top: calc(50% + 11px);
    left: calc(-20.833333335% - 35px);
    width: calc(20.833333335% + 35px);
}

.line-vertical {
    position: absolute;
    display: block;
    width: 1px;
    height: 100%;
    border: 0;
    border-right: 2px solid #78be20;
    padding: 0;
    z-index: -1;
}

.line-vertical.right {
    top: calc(50% + 4px);
    right: calc(-20.833333335% - 29px);
}

.line-vertical.left {
    top: calc(50% + 4px);
    left: calc(-20.833333335% - 29px);
}

.float-right {
    float: right;
}

body.product-page section.better-together {
    padding-top: 60px;
}

section.cta-footer .cta-content h2 {
    font-weight: 600;
}

section.cta-footer .cta-content .btn {
    padding: 13px 60px;
}

@media (max-width:1600px) {
    body.product-page .hero-bkg .hero-bkg-image img.hero-illustration {
        top: 300px;
    }
}

@media (max-width:1199px) {
    .circle,
    .line-horizontal,
    .line-vertical {
        display: none;
    }

    body.product-page .hero-bkg .hero-bkg-image img.hero-illustration {
        width: 900px !important;
        min-width: 900px;
        bottom: -40px;
        top: revert;
        left: 150px !important;
    }
}

@media (max-width: 991px) {
    body.product-page .hero-content {
        padding-top: 160px;
        text-align: center;
    }

    body.product-page.family-compliance section.hero, body.product-page.family-hiring section.hero, body.product-page.family-onboarding section.hero, body.product-page.family-attendance section.hero, body.product-page.family-performance section.hero {
        padding-bottom: 120px;
    }

    body.product-page .hero-bkg .hero-bkg-image img.hero-illustration {
        display: none;
    }

    section.family-apps {
        margin-top: 0;
    }

    body.product-page section.app-features {
        padding: 60px 0;

    }
    body.product-page section.better-together {
        padding: 60px 0;
    }
}

@media (max-width: 767px) {
    body.family-page section.family-app-detail .container .row:last-child .feature-description {
        margin-top: 0;
    }

    body.product-page section.app-features .feature-row {
        flex-direction: column;
        text-align: center;
    }

    section.family-app-detail img.icon {
        margin-bottom: 25px;
    }
}