﻿/*
:root {
    --color1: white;
    --color2: ghostwhite;
    --color3: #CAF0F8;
    --color4: #90E0EF;
    --color5: #00B4D8;
    --color6: #0077B6;
    --color7: #03045E;
}
*/

html {
    font-family: system-ui, sans-serif;
}

* {
    margin: 0;
    padding: 0;
    font: inherit;
}

/* css reset */
h1, h2, h3, h4, h5, h6 {
    text-wrap: balance;
}

p {
    margin-bottom: 2rem;
    text-wrap: pretty;
}

@media (prefers-reduced-motion: no-preference) {
    :has(:target) {
        scroll-behavior: smooth;
        scroll-padding-top: 3rem;
    }
}

*, ::before, *::after {
    box-sizing: border-box;
}

title {
    display: none;
}


/* end of css reset */

.item1a {
    background-color: #0077B6;
    background-image: url("../images/abacus_blue.jpg");
    background-repeat: no-repeat;
    background-blend-mode: darken;
    background-size: 100%;
    background-position: top left;
    color: white;
    font-size: 3rem;
    font-weight: 700;
    text-align: center;
    padding-top: 0px;
    padding-bottom: 45px;
}

.item1b {
    background-color: #0077B6;
    vertical-align: middle; 
    color: white;
    font-size: 3rem;
    font-weight: 700;
    text-align: center;
    padding-top: 45px;
    padding-bottom: 45px;
}

/*used on login page from the Excel addin */
.item1c {
    background-color: #0077B6;
    vertical-align: middle;
    color: white;
    font-size: 1rem;
    font-weight: 400;
    text-align: center;
    padding-top: 25px;
    padding-bottom: 25px;
}

.item3 {
    background-color: ghostwhite;
    grid-row: span 2;
    grid-column: span 2;
    margin: 2rem;
    cursor: zoom-in;
    justify-self: center;
}

.item4 {
    background-color: ghostwhite;
    grid-column: span 3;
    color: #0077B6;
    font-weight: 600;
    font-size: 1.2rem;
    text-align: left;
    vertical-align: middle;
}

.item6 {
    background-color: #0077B6;
    grid-row: span 1;
    grid-column: span 3;
    color: white;
    font-weight: 600;
    font-size: 22px;
    text-align: center;
    padding-top: 1.0em;
}

.item9 {
    background-color: #0077B6;
    align-items: center;
    justify-content: space-evenly;
}

.item10b {
    background-color: ghostwhite;
    color: #0077B6;
    font-weight: 500;
    font-size: 1.2rem;
    text-align: left;
    vertical-align: middle;
    padding: 2rem;
    grid-row: span 1;
    grid-column: span 7;
}

.item11a {
    background-color: #90E0EF;
    color: #03045E;
    /*grid-row: span 1;*/
    /*grid-column: span 3;*/
    font-weight: 700;
    font-size: 3rem;
    text-align: left;
    vertical-align: middle;
    padding-bottom: 0rem;
    padding-top: 2rem;
    padding-right: 2rem;
    padding-left: 2rem;
}

.item11Bleft {
    background-color: #90E0EF;
    color: #0077B6;
    grid-column: span 1;
    font-weight: 600;
    font-size: 1.2rem;
    text-align: left;
    vertical-align: middle;
    padding: 2rem;
}

.item11Bright {
    background-color: #90E0EF;
    color: #0077B6;
    grid-column: span 1;
    font-weight: 600;
    font-size: 1.2rem;
    text-align: left;
    vertical-align: middle;
    padding: 2rem;
}


.item12 {
    background-color: #90E0EF;
    color: #0077B6;
    /*grid-row: span 2;*/
    /*grid-column: span 3;*/
    font-weight: 600;
    text-align: center;
    padding: 2rem;
    overflow: hidden;
}

/*
.item12a {
    background-color: ghostwhite;
    background-image: url("../images/AdvancedOptions.png");
    background-repeat: no-repeat;
    background-size: contain;*/
    /*grid-row: span 2;*/
    /*grid-column: span 2;
    margin-top: 30px;
    margin-bottom: 1rem;
    margin-left: 2rem;
    cursor: zoom-in;
}*/

.item12b {
    background-color: ghostwhite;
    color: #0077B6;
    font-weight: 500;
    font-size: 1.2rem;
    text-align: justify;
    vertical-align: middle;
    padding: 2rem;
    /*grid-row: span 1;*/
    grid-column: span 3;
    margin-top: 25px;
    margin-bottom: 1rem;
    margin-right: 30px;
}

.item13 {
    background-color: #03045E;
    color: white;
    grid-row: span 2;
    /*grid-column: span 1;*/
    padding: 2rem;
}

.item14 {
    background-color: #03045E;
    color: white;
    /*grid-row: span 2;*/
    grid-column: span 3;
    padding: 2rem;
}

.item17 {
    background-color: #03045E;
    color: white;
    grid-row: span 2;
    grid-column: span 3;
    padding: 2rem;
}

.figcap {
    background-color: ghostwhite;
    /*grid-column: span 3;*/
    color: #0077B6;
    font-weight: 600;
    font-size: 1.2rem;
    text-align: center;
    cursor: default;
}

.pageHeading {

}

#suggest {
    box-sizing: border-box;
    color: #0077B6;
    resize: none;
    border: 2px solid #ccc;
    border-radius: 4px;
    font-weight: 400;
    background-color: #f8f8f8;
    font-size: 1rem;
    font-weight: 400;
    padding: 5px;
    margin: 5px;
    width: 80%;
    visibility: visible; /* Ensures the textarea itself is visible */
}

/* image overlay effect */
#overlayLarge {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0,0,0,0.5);
    z-index: 11;
    cursor: zoom-out;
}

#imageoverlay {
    position: absolute;    
}

.partial-container {
    font-size: 0.85rem; /* Adjust this value to scale everything up or down */
}

.partial-container h2,
.partial-container h3,
.partial-container h4 {
    font-size: 1.2em; /* This is now 1.2x the smaller base size */
}

/* pricing */
#pricing {
    display: flex;
    flex-wrap: wrap;
    width: 90%;
    align-items: center;
    justify-content: center;
    position: relative;
    left: 50%;
    transform: translate(-50%,0);
}

.price_card {
    width: 300px;
    background: rgb(255, 255, 255);
    display: inline-table;
    top: 0;
    border-radius: 5%;
    margin: 40px;
}

/*    .price_card:not(:last-child) {
        margin-right: 40px;
    }

    .price_card:first-child {
        margin-left: 0px;
    }
*/

.header {
    color: rgb(255, 255, 255);
    border-radius: 5% 5% 0% 0%;
    background: #03045E;
}

.test .header {
    background: #03045E;
}

.price {
    width: 100%;
    font-size: 4rem;
    font-weight: 400;
    display: block;
    text-align: center;
}

    .price::after {
        content: "/mo";
        right: -33px;
        bottom: 5px;
        font-size: 1.5rem;
    }

.name {
    width: 100%;
    font-size: 15px;
    font-weight: 700;
    display: block;
    text-align: center;
    padding: 0 0 30px;
}

.features {
    list-style: none;
    text-align: center;
    color: rgb(138, 138, 138);
    margin: 0;
    padding: 0;
}

    .features li {
        margin: 0 auto;
        padding: 20px 10px;
        width: 200px;
    }

/*        .features li:not(:last-child) {
            border: 1px solid rgb(242, 242, 242);
            border-top: 0;
            border-left: 0;
            border-right: 0;
        }*/

.buttonOnCard {
    color: rgb(255, 255, 255);
    border: 0;
    border-radius: 5px;
    height: 40px;
    width: 200px;
    display: block;
    font-weight: 700;
    font-size: 15px;
    text-transform: uppercase;
    margin: 20px auto 35px;
}

.alpha .buttonOnCard,
.bravo .buttonOnCard,
.charlie .buttonOnCard {
    background: #03045E;
}

    .alpha .buttonOnCard:hover,
    .bravo .buttonOnCard:hover,
    .charlie .buttonOnCard:hover,
    .test .buttonOnCard {
        background-color: #90E0EF;
        color: #03045E;
    }

/*end of pricing*/

/* components youtube player standard */
.player {
    aspect-ratio: 16 / 9;
    width: 400px;
    background: red;
}

/*----------------  youtube    -------*/

.youtube {
    background-color: #000;
    margin-bottom: 10px;
    position: relative;
    padding-top: 56.25%;
    overflow: hidden;
    cursor: pointer;
}

    .youtube img {
        width: 100%;
        top: -16.82%;
        left: 0;
        opacity: 0.9;
    }

    .youtube .play-button {
        width: 90px;
        height: 60px;
        background-color: #333;
        box-shadow: 0 0 30px rgba( 0,0,0,0.6 );
        z-index: 1;
        opacity: 0.8;
        border-radius: 6px;
    }

        .youtube .play-button:before {
            content: "";
            border-style: solid;
            border-width: 15px 0 15px 26.0px;
            border-color: transparent transparent transparent #fff;
        }

    .youtube img,
    .youtube .play-button {
        cursor: pointer;
    }

        .youtube img,
        .youtube iframe,
        .youtube .play-button,
        .youtube .play-button:before {
            position: absolute;
        }

            .youtube .play-button,
            .youtube .play-button:before {
                top: 50%;
                left: 50%;
                transform: translate3d( -50%, -50%, 0 );
            }

    .youtube iframe {
        height: 100%;
        width: 100%;
        top: 0;
        left: 0;
    }

/*-----------------------------------------*/

.footTitle {
    font-weight: 600;
    font-size: large;
    text-decoration: underline;
    margin-bottom: 0.5rem;
}

.css-grid {
    background-color: ghostwhite;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
}

.css-grid2 {
    background-color: ghostwhite;
    display: grid;
    grid-template-columns: repeat(1, 1fr);
}

@media (min-width: 40em) {
    .css-grid {
        grid-template-columns: repeat(7, 1fr);
    }

    .css-grid2 {
        grid-template-columns: repeat(2, 1fr);
    }

    .item6 {
        grid-column: span 7;
    }

    .item11b {
        /*grid-column: span 4;*/
        grid-column: span 3;
    }

    .item12 {
        grid-column: span 3;
    }

    .item12b {
        grid-column: span 5;
    }
}
