/*
 * Basics
 ===================*/
*,
*::before,
*::after {
    box-sizing: border-box;
}

body {
    margin: 0;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.3;
    color: #1b1b1b;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
    margin-top: 0;
    margin-bottom: 0.5rem;
    font-weight: 500;
    line-height: 1.3;
}

h1, .h1 {
    font-size: calc(1.375rem + 1.5vw);
}

@media (min-width: 1200px) {
    h1, .h1 {
        font-size: 2.5rem;
    }
}

h2, .h2 {
    font-size: calc(1.325rem + 0.9vw);
}

@media (min-width: 1200px) {
    h2, .h2 {
        font-size: 2rem;
    }
}

h3, .h3 {
    font-size: calc(1.3rem + 0.6vw);
}

@media (min-width: 1200px) {
    h3, .h3 {
        font-size: 1.75rem;
    }
}

h4, .h4 {
    font-size: calc(1.275rem + 0.3vw);
}

@media (min-width: 1200px) {
    h4, .h4 {
        font-size: 1.5rem;
    }
}

h5, .h5 {
    font-size: 1.25rem;
}

h6, .h6 {
    font-size: 1rem;
}

p {
    margin-top: 0;
    margin-bottom: 1rem;
}

ol, ul {
    padding-left: 2rem;
}

ol, ul, dl {
    margin-top: 0;
    margin-bottom: 1rem;
}

    ol ol, ul ul, ol ul, ul ol {
        margin-bottom: 0;
    }

img, svg {
    vertical-align: middle;
}

img {
    max-width: 100%;
    height: auto;
}

/*
 * Common
 ===================*/
.container {
    width: 100%;
    padding-right: 0.75rem;
    padding-left: 0.75rem;
    margin-right: auto;
    margin-left: auto;
}

@media (min-width: 576px) {
    .container, .container-sm {
        max-width: 540px;
    }
}

@media (min-width: 768px) {
    .container, .container-sm, .container-md {
        max-width: 720px;
    }
}

@media (min-width: 992px) {
    .container, .container-sm, .container-md, .container-lg {
        max-width: 960px;
    }
}

@media (min-width: 1200px) {
    .container, .container-sm, .container-md, .container-lg, .container-xl {
        max-width: 1200px;
    }
}

.btn {
    display: inline-block;
    font-weight: 400;
    line-height: 1.3;
    text-align: center;
    text-decoration: none;
    vertical-align: middle;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background-color: transparent;
    border: 1px solid transparent;
    padding: 0.75rem 1.875rem;
    font-size: 1rem;
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0;
}

input:not([type=submit]){
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    display: block;
    width: 100%;
    padding: 0.75rem 1.875rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.3;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #e5e7eb;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.85;
    z-index: -2;
}

.overlay-fixed {
    position: fixed;
}

.divider {
    margin: 1rem 0;
    border: 0;
    border-top-width: 1px;
    border-bottom-width: 1px;
    height: 0.125rem;
    border-color: #f9fafb;
    color: #e5e7eb;
}

    .divider.divider-sm {
        max-width: 3.25rem;
    }

.text-center .divider-sm {
    margin-right: auto;
    margin-left: auto;
}

.disclaimer {
    font-size: 80%;
}

/*
 * Helpers
 ===================*/
.text-center {
    text-align: center;
}

.text-white {
    color: #fff;
}

/*
 * Template 1
 ===================*/
.one {
    font-family: "Poppins", sans-serif;
}

    .one #hero {
        position: relative;
        z-index: 1;
        background-repeat: no-repeat;
        background-size: cover;
        padding: 1rem 0 14rem;
    }

@media (min-width: 992px) {
    .one #hero {
        padding: 4rem 0 14rem;
    }
}

.one .waves-bottom-center {
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    top: auto;
    z-index: -1;
    margin: 0;
}

.one.ccdph-colors .waves-bottom-center svg {
    color: #f2f2f2;
}

.one section {
    position: relative;
    z-index: 10;
}

.one .content-box {
    background-color: #fff;
    border-radius: 0.375rem;
    margin-top: -12rem;
    margin-bottom: 2.5rem;
    border: 1px solid #e2e5e8;
    box-shadow: 0 0.2rem 1.25rem 0 rgba(55, 26, 134, 0.1);
    display: flex;
    flex-direction: column;
}

    .one .content-box > div {
        padding: 1.5rem;
    }

    .one .content-box .info {
        width: 100%;
    }

@media (min-width: 992px) {
    .one .content-box {
        flex-direction: row;
    }

        .one .content-box > div {
            padding: 3rem;
        }

        .one .content-box .info {
            width: 66.66666667%;
        }

        .one .content-box .pin-entry {
            width: 33.33333333%;
        }
}

.one .disclaimer {
    text-align: justify;
    margin-bottom: 2.5rem;
}

.one input, .one .btn {
    border-radius: 0.375rem;
}

.one fieldset {
    display: flex;
    width: auto;
}

    .one fieldset input :not([type=submit]) {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
        width: calc(8ch + 3.75rem);
    }

    .one fieldset .btn {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

@media (min-width: 992px) {
    .one fieldset {
        width: 100%;
    }

        .one fieldset input :not([type=submit]) {
            width: 100%;
        }
}

.one #hero .container > img {
    margin-bottom: 1rem;
}
/*
 * Cook County DPH
 * ====================================
 * CCDPH blue:	#1e89dc -> contrast: black;
 * Dark blue: 	#0c233f -> contrast: white;
 **************************************/
.ccdph-colors a {
    color: #0c233f;
}

    .ccdph-colors a:hover, .ccdph-colors a:focus {
        color: #000;
        text-decoration: none;
    }

.ccdph-colors .btn {
    color: #000;
    background-color: #1e89dc;
    border-color: #1e89dc;
}

    .ccdph-colors .btn:hover, .ccdph-colors .btn:focus {
        color: #0c233f;
        background-color: transparent;
        border-color: #1e89dc;
    }

.ccdph-colors input {
    border-color: #0c233f;
}

.ccdph-colors .overlay-lt {
    background-color: #1e89dc;
}

.ccdph-colors .bg-primary {
    background-color: #1e89dc;
    color: #000;
}

.ccdph-colors .bg-navy {
    background-color: #0c233f;
    color: #fff;
}

.ccdph-colors .bg-lt-blue {
    background-color: #1e89dc;
    color: #000;
}

.ccdph-colors .bg-primary a {
    color: #061e2f;
}

.ccdph-colors .bg-navy a {
    color: #fbfdfe;
}

.ccdph-colors .bg-primary a:hover, .ccdph-colors .bg-primary a:focus {
    color: #000;
}

.ccdph-colors .bg-navy a:hover, .ccdph-colors .bg-navy a:focus {
    color: #fff;
}
/* Template-specific */
.one.ccdph-colors {
    background-color: #f2f2f2;
}

    .one.ccdph-colors .content-box .pin-entry {
        background-color: #ebf5ff;
    }
