/* bannerarea
---------------------------------------------------------- */
/* css for this is in the /css/patterns/banner-and-stats.css file */
.banner-half-holder {
    justify-content: space-around;
    gap: 40px;
}
.banner-left {
    max-width: min(50%, 795px);
}
.banner-content-holder h1 {
    max-width: 100%;
}

@media (max-width: 1025px) {
    .banner-half-holder {
        justify-content: center;
        gap: 0;
    }
    .banner-left {
        max-width: 100%;
    }
    .banner-right {
        margin-bottom: 120px;
    }
}


/* package-section General CSS
---------------------------------------------------------- */
.package-section {
    position: relative;
    z-index: 0;
    padding: 100px 40px 50px;
}
.package-section::before {
    content: '';
    position: absolute;
    z-index: -1;
    top: -1px;
    left: 0;
    right: 0;
    bottom: -1px;
    background: transparent;
}
.package-section .package-content-holder {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 31px;
}
.package-section h2 {
    font-size: var(--h1-font-size);
    line-height: var(--h1-line-height);
    color: var(--main-color);
}
.package-section .package-content-holder p {
    max-width: 968px;
    text-align: center;
    margin: 0;
}
.package-column-holder {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 20px;
    width: 100%;
}
.package-section .package-item-holder {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    max-width: 628px;
    gap: 20px;
}
.package-section .package-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 31px;
}
.package-section .package-item {
    flex-basis: calc(50% - 10px);
    width: 100%;
    padding: 40px 48px;
    background: linear-gradient(90deg, var(--secondary-color), var(--main-color));
    display: flex;
    align-items: center;
    border: 1px solid var(--accent-green);
}
.package-section .package-item .package-item-content {
    display: flex;
    flex-direction: column;
    gap: 0px;
    transition: all .2s ease-in-out;
}
.package-section .package-item h3 {
    color: var(--white);
    line-height: var(--h3-line-height);
    font-size: var(--h2-font-size);
    transition: all .2s ease-in-out;
}
.package-section .package-item p {
    letter-spacing: 1px;
    opacity: 0;
    line-height: 0;
    margin: 0;
    transition: all .2s ease-in-out;
}
.package-section .package-item.active,
.package-section .package-item:hover {
    border: 1px solid var(--med-blue);
    background: linear-gradient(90deg, var(--white), var(--white));
}
.package-section .package-item.active h3,
.package-section .package-item:hover h3 {
    color: var(--main-color);
}
.package-section .package-item.active .package-item-content,
.package-section .package-item:hover .package-item-content {
    gap: 24px;
}
.package-section .package-item.active p,
.package-section .package-item:hover p {
    opacity: 1;
    line-height: 1.5;
}
.package-section .package-inner a.main-btn,
.package-section .package-inner button.main-btn {
    margin-top: 70px;
}


@media (max-width: 1025px) {
    .package-column-holder {
        flex-direction: column;
    }
    .package-section .package-item {
        flex-basis: 100%;
        padding: 30px 25px;
    }
}
@media (max-width: 700px) {
    .package-section {
        padding: 0 25px;
    }
}


/* package-section - Elite
---------------------------------------------------------- */



/* package-section - Elite + Media
---------------------------------------------------------- */
.package-section.media-package::before {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.00) 0%, var(--light-blue) 100%);
}

.gradient-smudge.package-smudge .smudge {
    border-radius: 1090px;
    width: 1090px;
    height: 832px;
    transform: translate(-50%, -30%);
    left: 100%;
    top: 0%;
}
.gradient-smudge.package-smudge .smudge::before {
    transform: rotate(113deg);
}

/* package-section - PPC Custom
---------------------------------------------------------- */
.package-section.ppc-custom-package::before {
    background: var(--light-blue);
}

/* dental-marketing-section
---------------------------------------------------------- */
/* css for this is in the /css/patterns/half-section.css file */
.dental-marketing-section {
    z-index: 1;
}
.dental-marketing-section::before {
    content: '';
    position: absolute;
    z-index: -1;
    top: -1px;
    left: 0;
    right: 0;
    bottom: -1px;
    background: var(--light-blue);
}

/* package-breakdown-section
---------------------------------------------------------- */
.package-breakdown-section {
    position: relative;
    z-index: 0;
    padding: 64px 40px;
}
.package-breakdown-section::before {
    content: '';
    position: absolute;
    z-index: -1;
    top: -1px;
    left: 0;
    right: 0;
    bottom: -1px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.00) 0%, var(--light-blue) 100%)
}
.package-breakdown-inner {
    max-width: 1000px;
    width: 100%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 40px;
}
.package-breakdown-inner h2 {
    font-size: var(--h1-font-size);
    color: var(--main-color);
}
.package-breakdown-table-holder table {
    border-collapse: collapse;
    width: 100%;
    color: var(--main-color);
}
.package-breakdown-table-holder th,
.package-breakdown-table-holder td {
    border: 1px solid var(--tertiary-color);
    border-collapse: collapse;
    padding: 10px 20px;
    font-weight: 700;
    background-color: var(--white);
}
.package-breakdown-table-holder th:empty {
    opacity: 0;
    border: none;
}
.package-breakdown-table-holder th ~ th, 
.package-breakdown-table-holder td ~ td {
    text-align: center;
}
.package-breakdown-table-holder th:nth-child(3), 
.package-breakdown-table-holder td:nth-child(3) {
    background-color: var(--light-blue);
}
.package-breakdown-table-holder td span {
    font-weight: 400;
    margin-left: 1em;
    display: block;
}

@media (max-width: 700px) {
    .package-breakdown-section {
        padding: 50px 25px;
    }
}
@media (max-width: 500px) {
    .package-breakdown-section {
        padding: 50px 5px;
    }
    .package-breakdown-inner h2 {
        padding: 0 20px;
    }
}

/* add-on-packages-section
---------------------------------------------------------- */
/* css for this is in the /css/patterns/half-section.css file */
.add-on-packages-holder {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 40px;
}
.add-on-package-item {
    transition: all .2s ease-in-out;
    cursor: pointer;
}
.add-on-package-item h3 {
    font-size: var(--h2-font-size);
    line-height: 1.5;
    color: var(--main-color);
    transition: all .2s ease-in-out;
}
.add-on-package-item.active h3,
.add-on-package-item:hover h3 {
    color: var(--tertiary-color);
}
.add-on-package-item p {
    letter-spacing: 1px;
    line-height: 0px;
    opacity: 0;
    transition: all .2s ease-in-out;
    overflow: hidden;
}
.add-on-package-item.active p,
.add-on-package-item:hover p {
    opacity: 1;
    line-height: 1.5;
    overflow: visible;
}
    