.modal {
    display: none;
}

.modal.is-open {
    display: block;
}

.hero__title h1 {
    margin: 0;
    font-weight: 600;
    max-width: 130rem;
}

h1 {
    font-size: 3.8rem;
    font-weight: 700;
    line-height: 1.1;
    color: #004869;
}

@media (min-width: 700px) and (max-width:899px) {
    h1 {
        font-size: 4.75rem
    }
}

@media (min-width: 900px) and (max-width:1024px) {
    h1 {
        font-size: 5.25rem
    }
}

@media (min-width: 1025px) and (max-width:1299px) {
    h1 {
        font-size: 6rem
    }
}

@media (min-width: 1300px) and (max-width:1499px) {
    h1 {
        font-size: 7rem
    }
}

@media (min-width: 1500px) {
    h1 {
        font-size: 8rem
    }
}

.hero__intro .hero__title {
    margin: 3em auto 2em auto;
    max-width: 130rem;
}

@media screen and (min-width: 700px) {

    .hero__intro .container,
    .content .container {
        padding-left: 50px;
        padding-right: 50px;
    }
}

@media screen and (min-width: 1025px) {

    .hero__intro .container,
    .content .container {
        padding-left: 50px;
        padding-right: 50px;
        max-width: 130rem;
        margin: auto;
    }
}

.hero__intro .hero__description {
    padding: 24px 0;
    font-size: 1.8rem;
    line-height: 1.45;
    background: #CDE6EB;
    font-weight: 400;
}

@media (min-width: 700px) {
    .hero__intro .hero__description {
        padding: 39px 0 40px;
        font-size: 2.4rem;
        line-height: 1.375;
    }
}

@media (min-width: 1025px) {
    .hero__intro .hero__description {
        padding: 50px 0;
        font-size: 3rem;
        line-height: 1.35;
    }
}

.cta {
    position: relative;
    -webkit-transition: background 0.3s ease-in-out, border-color 0.3s ease-in-out, color 0.3s ease-in-out;
    -o-transition: background 0.3s ease-in-out, border-color 0.3s ease-in-out, color 0.3s ease-in-out;
    transition: background 0.3s ease-in-out, border-color 0.3s ease-in-out, color 0.3s ease-in-out;
    display: inline-block;
    font-weight: 500;
    color: #000000;
    border: 2px solid #C0DF5D;
    border-radius: 5px;
    margin-bottom: .75rem;
}

@media (min-width: 700px) {
    .cta {
        padding: 9px 31px 9px 18px;
        font-size: 1.6rem;
        line-height: 1.3125;
    }
}

@media (min-width: 700px) {
    .cta {
        border-radius: 5px;
    }
}

.cta:focus {
    outline-color: #004869;
    outline-offset: 2px;
}

.cta:before {
    -webkit-transition: background 0.3s ease-in-out;
    -o-transition: background 0.3s ease-in-out;
    transition: background 0.3s ease-in-out;
    content: '';
    position: absolute;
    top: 7px;
    right: 10px;
    width: 16px;
    height: 16px;
    background-size: 17px;
    background-repeat: no-repeat;
    background-position: center;
}

@media (min-width: 700px) {
    .cta:before {
        top: 10px;
        right: 9px;
        width: 20px;
        height: 19px;
        background-size: 22px;
    }
}

.cta--primary {
    padding: 5px 30px 4px 13px;
    background: #C0DF5D;
}

@media (min-width: 700px) {
    .cta--primary {
        padding: 9px 31px 9px 18px;
    }
}

.cta--primary:hover {
    color: #000000;
    background-color: #A2C238;
    text-decoration: none;
    border-color: #A2C238;
}

.cta--primary:before {
    background-image: url("/_resources/images/icons/arrow-right-black.svg");
}

.cta--primary.cta--white {
    outline-color: #FFFFFF;
}

.cta--primary.cta--white:hover {
    background-color: #FFFFFF;
    color: #00727D;
    border-color: #FFFFFF;
}

.cta--primary.cta--white:hover:before {
    background-image: url("/_resources/images/icons/arrow-right-teal.svg");
}

.cta--secondary {
    padding: 5px 30px 4px 13px;
    background: transparent;
}

@media (min-width: 700px) {
    .cta--secondary {
        padding: 9px 31px 9px 18px;
    }
}

.cta--secondary:hover {
    color: #000000;
    text-decoration: none;
    background: #EAF6DF;
}

.cta--secondary:before {
    -webkit-transition: background 0.3s ease-in-out;
    -o-transition: background 0.3s ease-in-out;
    transition: background 0.3s ease-in-out;
    background-image: url("/_resources/images/icons/arrow-right-black.svg");
}

.cta--secondary.cta--white {
    border-color: #FFFFFF;
    color: #FFFFFF;
    outline-color: #FFFFFF;
}

.cta--secondary.cta--white:before {
    background-image: url("/_resources/images/icons/arrow-right-white.svg");
}

.cta--secondary.cta--white:hover {
    color: #000000;
    background-color: #FFFFFF;
}

.cta--secondary.cta--white:hover:before {
    background-image: url("/_resources/images/icons/arrow-right-black.svg");
}

.alert--minor {
    background-color: #EAF6DF;
}

.alert--minor .cta.cta {
    outline-color: #004869;
}

.alert--medium {
    background-color: #FFCC66;
}

.alert--major {
    background-color: #E46C54;
}

@media (min-width: 1025px) {
    .alert__message {
        display: -webkit-box;
        display: -webkit-flex;
        display: -moz-box;
        display: -ms-flexbox;
        display: flex;
    }
}

.alert__title {
    margin: 0 0 4px;
    font-size: 1.6rem;
    line-height: 1.5;
    font-weight: 700;
    max-width: 80%;
}

.alert--major .alert__title {
    color: #ffffff;
}

@media (min-width: 700px) {
    .alert__title {
        margin: 0 0 1px;
        font-size: 1.8rem;
        line-height: 1.444;
        max-width: 25%;
    }
}

@media (min-width: 1025px) {
    .alert__title {
        -webkit-flex-shrink: 0;
        -ms-flex-negative: 0;
        flex-shrink: 0;
        margin: 0 19px 0 0;
        font-size: 2.1rem;
        line-height: 1.333;
        max-width: 23%;
    }
}

.alert__description {
    margin: 0 0 13px;
    font-size: 1.4rem;
    line-height: 1.5;
    max-width: 85%;
}

@media (min-width: 700px) {
    .alert__description {
        margin: 0 0 0 10px;
        padding-right: 18px;
        font-size: 1.6rem;
        line-height: 1.5;
        max-width: 60%;
    }
}

@media (min-width: 1025px) {
    .alert__description {
        margin: 0 0 0 10px;
        padding: 2px 20px 0 0;
        font-size: 1.8rem;
        line-height: 1.555;
        max-width: 56%;
    }
}

.alert--inpage {
    padding: 20px;
    margin: 15px 0;
    border-radius: 22px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    flex-direction: column;
}

@media (min-width: 700px) {
    .alert--inpage {
        flex-direction: row;
    }
}

.alert--icon {
    margin-right: 15px;
}

.alert--icon .alert-icon {
    padding: 10px;
    background-color: #fff;
    border-radius: 50px;
    font-size: 1.5em;
    height: 50px;
    width: 50px;
    text-align: center;
    margin-bottom: 10px;
}

@media (min-width: 1025px) {
    .alert--icon .alert-icon {
        padding: 15px;
        height: 65px;
        width: 65px;
    }
}

.alert .cta {
    margin: 0;
    background: rgba(255, 255, 255, 1);
    border-color: #FFFFFF;
    -webkit-flex-shrink: 0;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.alert .cta:hover {
    background: rgba(255, 255, 255, .5);
    border-color: #ffffff;
}

.alert__title-inpage {
    margin: 10px 19px 0 10px;
    font-size: 2.1rem;
    line-height: 1.333;
    font-weight: 900
}

.alert__message-inpage {
    margin: 10px 0 20px 10px;
    padding: 2px 20px 0 0;
    font-size: inherit;
    line-height: inherit
}

.alert--inpage .cta {
    margin-bottom: 10px
}

.some-page-wrapper {
    margin: 15px;
    background-color: red;
}

.row {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    width: 100%;
}

.col--modal {
    display: flex;
    width: 100%;
}

.column {
    flex-direction: column;
    flex-basis: 100%;
    flex: 1;
    margin: 1rem 0 2rem;
}

@media (max-width: 700px) {
    .col--modal {
        display: flex;
        flex-direction: column;
        flex-basis: 100%;
        flex: 1;
    }
}

@media (max-width: 700px) {
    .container {
        padding: 0 10px;
    }
	
button {
	line-height: inherit;
}