/**********************************************/
/*******        Helper Classes          *******/
/**********************************************/
/* @group region*/

/* Removes Padding of Columns Inside This Row  */
.relative {
    position: relative;
}

/* Removes Padding of Columns Inside This Row So They Touch The Edge Of Container */
.row-nopad {
    margin-right: -15px;
    margin-left: -15px;
}

.row-nopad>* {
    padding-right: 0;
    padding-left: 0;
}

.row-nopad:before,
.row-nopad:after {
    display: table;
    content: " ";
}

.row-nopad:after {
    clear: both;
}

.nopad-md {
    padding: 0;
}

@media (min-width: 992px) {
    .nopad-md {
        padding-right: 15px;
        padding-left: 15px;
    }
}

/* Disables Textarea Resize that Messes with Design */
textarea {
    resize: none;
}

/* Force Block Elements To Stack Horizontally */
/* Ex: Span Around A Phrase So It drops Down */
/* As a Whole When Responding  */
.inline-block {
    display: inline-block
}

/* Prevents Flicker On Transition */
.carousel {
    position: relative;
    z-index: 1000;
}

/* Always Displays a Scrollbar even if page does not need to scroll */
html {
    font-size: 16px;
    height: 100%;
    overflow-y: scroll;
    scroll-behavior: smooth;
}

/* @endregion*/

/**********************************************/
/*******        Fonts Classes           *******/
/**********************************************/

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
    color: #017dc3;
    font-family: 'Muli', sans-serif;
    font-weight: 600;
    line-height: 1.4;
    margin-top: 0;
}

h1 {
    position: absolute;
    color: #ffc728;
    font-size: 2.25rem;
    margin-bottom: 0;
    right: calc(15% + 15px);
    bottom: 50px;
    text-shadow: 1px 1px 3px rgba(53, 47, 40, .85);
    z-index: 4;
}

h2 {
    margin-bottom: 20px;
    text-shadow: 1px 1px 1px rgba(185, 185, 185, .80);
}

.PedAnmName {
    color: #017dc3;
    font-family: 'Muli', sans-serif;
    font-weight: 600;
    line-height: 1.4;
    text-shadow: 1px 1px 1px rgba(185, 185, 185, .80);
}

.yellow {
    color: #ffc728;
}

.blue {
    color: #017dc3;
}

a {
    color: #017dc3;
}

a:hover, a:focus {
    color: #02314b;
}

main p {
    width: 98%;
}

main .bullet-list {
    width: 90%;
}

main p.full-width {
    width: 100%;
}

.lead {
    font-size: 1.1875rem;
    line-height: 1.5;
}

.bold {
    font-weight: 700;
}

.italic {
    font-style: italic;
}

/**********************************************/
/*******       Template Classes         *******/
/**********************************************/

body {
    background-color: #000;
    color: #000;
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    font-size: 1rem;
    line-height: 1.6;
    height: 100%;
    min-height: 100%;
}

.wrapper {
    overflow: hidden;
}

main {
    padding-top: 30px;
    padding-bottom: 30px;
}

header {
    height: 200px;
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-left: -15px;
    margin-right: -15px;
}

header::before {
    content: '';
    background-image: -o-linear-gradient(10deg, rgba(0, 49, 75, 1), rgba(0, 49, 75, 1), rgba(0, 49, 75, .8), rgba(0, 49, 75, .4), rgba(0, 49, 75, 0));
    background-image: linear-gradient(80deg, rgba(0, 49, 75, 1), rgba(0, 49, 75, 1), rgba(0, 49, 75, .8), rgba(0, 49, 75, .4), rgba(0, 49, 75, 0));
    position: absolute;
    left: 0;
    width: 45%;
    top: 0;
    bottom: 0;
    z-index: 3;
}

header::after {
    content: '';
    background: url('../images/template/striped-bg.gif');
    position: absolute;
    right: 0;
    width: calc(15% + 110px);
    top: -5px;
    bottom: 0;
    -webkit-box-shadow: inset -5px 0 13px 0 rgba(255, 255, 255, .52);
    box-shadow: inset -5px 0 13px 0 rgba(255, 255, 255, .52);
}

.logo {
    position: absolute;
    bottom: 36px;
    left: 2%;
    z-index: 3;
}

.header-contact-bar {
    position: relative;
    background-color: #017dc3;
    color: #fff;
    margin-top: auto;
    padding: 10px 0;
    text-align: center;
    width: 100%;
    z-index: 3;
    -webkit-box-shadow: 0 2px 6px 0 rgba(0, 0, 0, .65);
    box-shadow: 0 2px 6px 0 rgba(0, 0, 0, .65);
}

.header-contact-bar a[href^="tel"] {
    color: #fff;
}

.header-contact-bar p {
    margin-bottom: 0;
    text-shadow: 1px 1px 2px rgba(2, 49, 75, .8);
}

.header-bg {
    background: url('../images/template/header-bg.jpg') no-repeat right 20%;
    background-size: cover;
    border-radius: 0 110px 0 0;
    position: absolute;
    left: 0;
    width: 85%;
    top: 0;
    bottom: 0;
    z-index: 2;
    -webkit-box-shadow: 5px 0 13px 0 rgba(255, 255, 255, .52);
    box-shadow: 5px 0 13px 0 rgba(255, 255, 255, .52);
}

footer {
    font-size: .75rem;
    padding: 15px 0;
    text-align: center;
}

footer, footer a, footer a:hover, footer a:focus {
    color: #999;
}

main {
    background-color: #fff;
    border-radius: 0 0 70px 0;
}

.left-sidebar {
    background: url('../images/template/striped-bg.gif');
    position: relative;
    margin-top: -15px;
    margin-bottom: -10px;
    padding: 20px 0;
    -webkit-box-shadow: inset -5px 0 13px 0 rgba(255, 255, 255, .52);
    box-shadow: inset -5px 0 13px 0 rgba(255, 255, 255, .52);
}

hr {
    border-color: e2e2e2;
    margin-top: 35px;
    margin-bottom: 35px;
}

ul.bullet-list {
    list-style-type: none;
    padding-left: 25px;
}

ul.bullet-list li::before {
    content: "\2022";
    color: #ffc728;
    font-size: 1.25rem;
    font-weight: bold;
    display: inline-block;
    width: 1rem;
    margin-left: -1rem;
    top: 2px;
    position: relative;
}

img.img-left {
    float: left;
    margin: 5px 15px 0 0;
    max-width: 450px;
}

.img-right {
    float: right;
    margin: 5px 0 0 15px;
    max-width: 450px;
}

.main-content {
    padding-bottom: 50px;
}

.main-footer {
    clear: both;
}

.main-footer::before {
    display: table;
    content: " ";
}

.footer-nav {
    font-size: .875rem;
    max-width: 85%;
    margin: 0 auto;
    overflow: hidden;
    position: relative;
}

.footer-list {
    list-style-type: none;
    margin-left: -1px;
    margin-bottom: 0;
    padding-left: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.footer-list li {
    font-weight: 300;
    line-height: 1;
    margin: .375em 0;
    padding: 0 .5em;
    text-align: center;
    border-left: 1px solid #e2e2e2;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-preferred-size: auto;
    flex-basis: auto;
}

.footer-list li a:hover {
    text-decoration: none;
}

.footer-list .dropdown {
    display: none;
}

.carousel {
    max-width: 720px;
    margin: 0 20px 30px 0;
    -webkit-box-shadow: 6px 10px 15px rgba(0, 0, 0, 0.22);
    box-shadow: 6px 10px 15px rgba(0, 0, 0, 0.22);
}

.banner {
    max-width: 720px;
    margin: 0 20px 30px 0;
    -webkit-box-shadow: 6px 10px 15px rgba(0, 0, 0, 0.22);
    box-shadow: 6px 10px 15px rgba(0, 0, 0, 0.22);
}

.carousel-control {
    width: 10%;
}

.glyphicon-chevron-right:before {
    content: '\f35a';
    font: var(--fa-font-regular);
}

.glyphicon-chevron-left:before {
    content: '\f359';
    font: var(--fa-font-regular);
}

/* Carousel Fading slide */
.carousel-fade .carousel-inner {
    background: #000;
}

.carousel-fade .carousel-control {
    z-index: 2;
}

.carousel-fade .item {
    opacity: 0;
    -webkit-transition-property: opacity;
    -o-transition-property: opacity;
    transition-property: opacity;
}

.carousel-fade .next.left,
.carousel-fade .prev.right,
.carousel-fade .item.active {
    opacity: 1;
}

.carousel-fade .active.left,
.carousel-fade .active.right {
    left: 0;
    opacity: 0;
    z-index: 1;
}

/* Safari Fix */
@media all and (transform-3d), (-webkit-transform-3d) {

    .carousel-fade .carousel-inner>.item.next,
    .carousel-fade .carousel-inner>.item.active.right {
        opacity: 0;
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

    .carousel-fade .carousel-inner>.item.prev,
    .carousel-fade .carousel-inner>.item.active.left {
        opacity: 0;
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

    .carousel-fade .carousel-inner>.item.next.left,
    .carousel-fade .carousel-inner>.item.prev.right,
    .carousel-fade .carousel-inner>.item.active {
        opacity: 1;
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }
}

.carousel-control .prev {
    margin-left: -15px;
    left: 50%;
}

/* Prev */

.carousel-control .next {
    margin-right: -15px;
    right: 50%;
}

/* Next */

/* Removing BS background */
.carousel .control-box {
    opacity: 0;
}

a.carousel-control.left {
    left: 0;
    background: transparent;
    border: 0;
}

a.carousel-control.right {
    right: 0;
    background: transparent;
    border: 0;
}

/* Animation */
.control-box, a.carousel-control {
    -webkit-transition: all 250ms ease;
    -o-transition: all 250ms ease;
    transition: all 250ms ease;
}

.carousel:hover .control-box {
    opacity: 1;

}

.carousel:hover a.carousel-control.left {
    left: 15px;
}

.carousel:hover a.carousel-control.right {
    right: 15px;
}

.form-control {
    border-radius: 0;
    border-color: #e2e2e2;
}

.btn-primary {
    border: none;
    border-radius: 0;
    background-color: #ffc728;
    color: #000;
    padding: 8px 14px;
    position: relative;
    -webkit-transition: all .2s linear;
    -o-transition: all .2s linear;
    transition: all .2s linear;
    -webkit-box-shadow: 2px 4px 5px rgba(0, 0, 0, 0.4);
    box-shadow: 2px 4px 5px rgba(0, 0, 0, 0.4);
}

.btn-primary:hover, .btn-primary:focus {
    background-color: #ffd04a;
    color: #000;
    top: -1px;
    -webkit-box-shadow: 4px 7px 10px rgba(0, 0, 0, 0.2);
    box-shadow: 4px 7px 10px rgba(0, 0, 0, 0.2);
}

.btn-primary:active {
    top: 0;
    -webkit-box-shadow: 1px 2px 3px rgba(0, 0, 0, 0.6);
    box-shadow: 1px 2px 3px rgba(0, 0, 0, 0.6);
}

.contact-btn {
    margin-left: 3px;
}

label {
    font-weight: 400;
}

legend {
    border-bottom: 0;
    font-family: 'Muli', sans-serif;
    font-weight: 600;
    margin-bottom: 5px;
}

fieldset {
    margin-bottom: 10px;
}

.form-inline .form-group {
    margin-left: 5px;
}

.form-inline input {
    max-width: 140px;
}

.form-inline .form-group:first-child {
    margin-left: 0;
}

.form-title.smaller {
    color: #666;
    font-size: .75rem;
}

.form-select-narrow {
    max-width: 70px;
}

.form-title-large {
    font-size: 1.25rem;
}

/* .required {
    color: #017dc3;
    font-size: .75rem;
} */

.cowherd-form fieldset:last-of-type {
    margin-bottom: 0;
}

.cowherd-form .form-group:last-child {
    margin-bottom: 15px;
}

.cowherd-form .form-group.mb-25:last-child {
    margin-bottom: 25px;
}

.cowherd-form .form-group {
    margin-bottom: 25px;
}

.cowherd-form label, .form-title {
    margin-bottom: 2px;
}

.social ul {
    padding-left: 20px;
}

.social li {
    font-size: 2rem;
    list-style-type: none;
    display: inline;
    margin-right: 15px;
}

.social li a {
    color: #fff;
}

.social li a:hover, .social li a:focus {
    color: #ffc728;
}

.cover-sm {
    max-width: 175px;
}

/**********************************************/
/*******      Navigation Classes        *******/
/**********************************************/

.navbar {
    border: 0;
    border-radius: 0;
    margin-bottom: 0;
}

.navbar-collapse {
    border: none;
    padding-left: 0;
    padding-right: 0;
}

.nav>li>a {
    color: #fff;
    font-size: 1.125rem;
}

.nav>li>a:hover, .nav>li>a:focus {
    background: rgba(255, 190, 25, .85);
    color: #02314b;
    -webkit-box-shadow: inset -6px 0 8px 0 rgba(255, 255, 255, .35);
    box-shadow: inset -6px 0 8px 0 rgba(255, 255, 255, .35);
}

.navbar-toggle {
    margin-bottom: 0;
}

.navbar-toggle .icon-bar {
    border-radius: 0;
    width: 32px;
    height: 3px;
}

.navbar-toggle .icon-bar+.icon-bar {
    margin-top: 5px;
}

.navbar-toggle.collapsed:hover .icon-bar, .navbar-toggle .icon-bar {
    background-color: #ffc728;
    -webkit-box-shadow: 1px 1px 1px rgba(0, 0, 0, .7);
    box-shadow: 1px 1px 1px rgba(0, 0, 0, .7);
}

.navbar-toggle.collapsed .icon-bar {
    background-color: #fff;
    -webkit-box-shadow: 1px 1px 2px rgba(0, 0, 0, .35);
    box-shadow: 1px 1px 2px rgba(0, 0, 0, .35);
}

.navbar-header {
    position: absolute;
    bottom: 2px;
    right: 0;
    z-index: 4;
}

.dropdown>a::before {
    content: '\f053';
    font: var(--fa-font-regular);
    position: absolute;
    right: 20px;
    top: 13px;
    color: #fff;
    font-size: 1rem;
    z-index: 2;
    -webkit-transition: -webkit-transform .5s linear;
    transition: -webkit-transform .5s linear;
    -o-transition: transform .5s linear;
    transition: transform .5s linear;
    transition: transform .5s linear, -webkit-transform .5s linear;
    -webkit-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    transform: rotate(-90deg);
}

.dropdown>a:hover::before, .dropdown>a:focus::before {
    color: #02314b;
}

.dropdown.open>a::before {
    color: #02314b;
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
}

.nav .open>a, .nav .open>a:hover, .nav .open>a:focus {
    background-color: rgba(255, 190, 25, .85);
    color: #02314b;
    -webkit-box-shadow: inset -6px 0 8px 0 rgba(255, 255, 255, .35);
    box-shadow: inset -6px 0 8px 0 rgba(255, 255, 255, .35);
}

.dropdown .dropdown-menu {
    background: transparent;
    border: none;
    border-radius: 0;
    display: block;
    padding: 0;
    position: relative;
    float: none;
    max-height: 0;
    overflow: hidden;
    -webkit-box-shadow: none;
    box-shadow: none;
    -webkit-transition: max-height .8s linear;
    -o-transition: max-height .8s linear;
    transition: max-height .8s linear;
}

.dropdown.open .dropdown-menu {
    max-height: 500px;
}

.dropdown-menu>li>a {
    color: #fff;
    font-size: 1rem;
    padding: 8px 25px;
}

.dropdown-menu>li>a:hover, .dropdown-menu>li>a:focus {
    background-color: rgba(255, 190, 25, .85);
    color: #02314b;
}

/**********************************************/
/*******        Animal Classes          *******/
/**********************************************/

.animals>div {
    margin-bottom: 30px;
}

.animal-thumb img {
    margin-bottom: 10px;
}

.animal-box {
    background-color: #017dc3;
    color: #fff;
    padding: 10px;
    height: 100%;
    -webkit-box-shadow: 1px 1px 5px rgba(125, 125, 125, .75);
    box-shadow: 1px 1px 5px rgba(125, 125, 125, .75);
}

.animal-name {
    text-align: center;
}

.animal-thumb a {
    text-decoration: none;
}

.animal-thumb a h4 {
    color: #B5DBED;
    font-size: 1.25rem;
    text-decoration: none;
    text-transform: uppercase;
    text-shadow: 1px 1px 2px rgba(2, 49, 75, .5);
}

.animal-thumb a:hover h4, .animal-thumb a:focus h4 {
    color: #ffc728;
    text-shadow: 1px 1px 2px rgba(2, 49, 75, .9);
}

.animal-desc {
    margin-bottom: 20px;
}

.animal-desc p {
    margin-bottom: 0;
    width: 100%;
}

.animal-btn {
    text-align: right;
    margin-bottom: 5px;
}

.animal-thumb a img {
    -webkit-filter: grayscale(65%);
    filter: grayscale(65%);
    -webkit-box-shadow: 1px 1px 4px rgba(2, 49, 75, .4);
    box-shadow: 1px 1px 4px rgba(2, 49, 75, .4);
    -webkit-transition: all .2s linear;
    -o-transition: all .2s linear;
    transition: all .2s linear;
}

.animal-thumb a:hover img {
    -webkit-filter: grayscale(0);
    filter: grayscale(0);
    -webkit-box-shadow: 1px 1px 4px rgba(2, 49, 75, .8);
    box-shadow: 1px 1px 4px rgba(2, 49, 75, .8);
}

.divEpdTbl thead, .divEpdTbl tbody {
    font-size: .875rem;
}

.divEpdTbl caption {
    background-color: #017dc3;
    color: #fff;
    text-shadow: 1px 1px 2px rgba(2, 49, 75, .65);
}

.PedTable {
    margin-bottom: 15px;
}

.EPDAsOfDt {
    padding-top: 0;
}

.epd-btn {
    display: none;
    margin-bottom: 10px;
}

#case img {
    -webkit-box-shadow: 1px 1px 5px rgba(125, 125, 125, .75);
    box-shadow: 1px 1px 5px rgba(125, 125, 125, .75);
}

/**********************************************/
/********        Form Classes          ********/
/**********************************************/

label {
    font-weight: 400;
}

legend {
    border: none;
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 10px;
}

.btn-form:disabled {
    opacity: .65;
    cursor: not-allowed;
    pointer-events: all;
}

.btn-form[disabled],
.btn-form[disabled]:hover,
.btn-form[disabled]:focus,
.btn-form[disabled]:active {
    background-color: #ffc728;
    color: #000;
    outline: none;
    top: 0;
    -webkit-box-shadow: 2px 4px 5px rgba(0, 0, 0, 0.4);
            box-shadow: 2px 4px 5px rgba(0, 0, 0, 0.4);
}

.btn-form {
    -webkit-transition: outline .25s ease-in-out;
    -o-transition: outline .25s ease-in-out;
    transition: outline .25s ease-in-out;
}

.btn-form:focus,
.btn-form:active:focus {
    outline-offset: 2px;
    outline: 2px solid #f3a36a;
}

.form-control:focus {
    border-color: #86b7fe;
    -webkit-box-shadow: 0 0 0 2px #86b7fe;
    box-shadow: 0 0 0 2px #86b7fe;
}

.breederFormError,
.form-control.breederFormError {
    border-color: #d64947;
}

.breederFormError:focus,
.form-control.breederFormError:focus {
    -webkit-box-shadow: 0 0 0 2px #d64947;
    box-shadow: 0 0 0 2px #d64947;
}

.breederFormErrorMesssage {
    display: none;
    position: relative;
    color: #d64947;
    font-size: 12px;
    font-style: italic;
    white-space: nowrap;
}

.breederFormError~.breederFormErrorMesssage {
    display: block;
    margin-left: 2px;
    top: 1px;
}

.breederFormOptional {
    font-size: 85%;
    color: #888;
}

.sm-pad-3-col>.col-xs-6 {
    padding-right: 5px;
}

.sm-pad-3-col>.col-xs-3 {
    padding-left: 5px;
    padding-right: 5px;
}

.sm-pad-3-col>.col-xs-3:last-child {
    padding-right: 15px;
}

.sm-pad-2-col>.col-xs-6:first-child {
    padding-right: 5px;
}

.sm-pad-2-col>.col-xs-6:last-child {
    padding-left: 5px;
}

.breederEmailHeading,
.breederEmailHeadingC {
    display: none;
}

.grow-wrap {
    display: grid;
}

.grow-wrap::after {
    content: attr(data-replicated-value) " ";
    white-space: pre-wrap;
    visibility: hidden;
}

.grow-wrap>textarea {
    resize: none;
    overflow: hidden;
}

/* Match the other input field styles */
.grow-wrap>textarea,
.grow-wrap::after {
    border: 1px solid #e2e2e2;
    border-radius: 0;
    font-size: 14px;
    color: #555;
    min-height: 100px;
    padding: 6px 12px;
    grid-area: 1 / 1 / 2 / 2;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
}

.g-recaptcha {
    margin-bottom: 10px;
}

/* Checkbox and Radio Styles. Remove if form doesn't have either element*/
.checkbox,
.form-radio {
    --selection-color: #017dc3;
}

.checkbox input,
.form-radio input {
    width: auto;
    opacity: 0.00000001;
    position: absolute;
    left: 0;
}

/* Begin Checkbox */
.checkbox {
    position: relative;
    margin-bottom: 15px;
    margin-top: 0;
}

.checkbox label {
    position: relative;
    cursor: pointer;
    text-align: left;
    display: inline-block;
    padding-left: 30px;
}

.checkbox input {
    width: auto;
    opacity: 0.00000001;
    position: absolute;
    left: 0;
}

.checkbox input[type=checkbox] {
    margin-left: 0;
}

.checkbox .checkbox-helper {
    position: absolute;
    top: 2px;
    left: 0;
    width: 18px;
    height: 18px;
    background: #fff;
    z-index: 0;
    border: 1px solid #e2e2e2;
    border-radius: 0;
    -webkit-transition: all 0.2s ease;
    -o-transition: all 0.2s ease;
    transition: all 0.2s ease;
}

.checkbox input:focus+.checkbox-helper,
.checkbox input:checked:focus+.checkbox-helper {
    -webkit-box-shadow: 0 0 0 2px #86b7fe;
    box-shadow: 0 0 0 2px #86b7fe;
}

.checkbox input:checked+.checkbox-helper {
    background: var(--selection-color);
    border-color: var(--selection-color);
    -webkit-box-shadow: none;
    box-shadow: none;
}

.checkbox .checkbox-helper::before,
.checkbox .checkbox-helper::after {
    content: '';
    position: absolute;
    height: 0;
    width: 3px;
    background-color: #fff;
    display: block;
    opacity: 0;
    -webkit-transform-origin: left top;
    -ms-transform-origin: left top;
    transform-origin: left top;
    -webkit-transition: opacity 0.2s ease, height 0s linear 0.2s;
    -o-transition: opacity 0.2s ease, height 0s linear 0.2s;
    transition: opacity 0.2s ease, height 0s linear 0.2s;
}

.checkbox .checkbox-helper::before {
    top: 14px;
    left: 5px;
    -webkit-transform: rotate(-135deg);
    -ms-transform: rotate(-135deg);
    transform: rotate(-135deg);
}

.checkbox .checkbox-helper::after {
    top: 9px;
    left: 0;
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.checkbox:hover .checkbox-helper {
    border-color: var(--selection-color);
}

.checkbox input:checked~.checkbox-helper {
    border-color: var(--selection-color);
}

.checkbox input:checked~.checkbox-helper::after,
.checkbox input:checked~.checkbox-helper::before {
    opacity: 1;
    -webkit-transition: height 0.2s ease;
    -o-transition: height 0.2s ease;
    transition: height 0.2s ease;
}

.checkbox input:checked~.checkbox-helper::after {
    height: 7px;
}

.checkbox input:checked~.checkbox-helper::before {
    height: 15px;
    -webkit-transition-delay: 0.2s;
    -o-transition-delay: 0.2s;
    transition-delay: 0.2s;
}

/* End Checkbox */

/* Begin Radio */
.form-radio {
    position: relative;
}

.radio label {
    padding-left: 30px;
    display: inline-block;
    position: relative;
}

.radio input[type=radio] {
    margin-left: 0;
}

.radio .radio-helper {
    position: absolute;
    top: -2px;
    left: -4px;
    cursor: pointer;
    display: block;
    font-size: 16px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    color: #999;
}

.radio .radio-helper::before,
.radio .radio-helper::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    margin: 4px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 2px solid currentColor;
    -webkit-transition: all .2s ease;
    -o-transition: all .2s ease;
    transition: all .2s ease;
}

.radio .radio-helper::before {
    border-color: currentColor;
    -webkit-transition: all .2s ease;
    -o-transition: all .2s ease;
    transition: all .2s ease;
}

.radio .radio-helper::after {
    background-color: var(--selection-color);
    border-color: var(--selection-color);
    -webkit-transform: scale(0);
    -ms-transform: scale(0);
    transform: scale(0);
}

.radio:hover .radio-helper::before {
    border-color: var(--selection-color);
}

.radio input:checked~.radio-helper::after {
    -webkit-transform: scale(0.5);
    -ms-transform: scale(0.5);
    transform: scale(0.5);
}

.radio input:focus+.radio-helper::before {
    -webkit-box-shadow: 0 0 0 5px rgb(0 0 255 / 30%);
    box-shadow: 0 0 0 5px rgb(0 0 255 / 30%);
}

.radio input:checked~.radio-helper::before {
    color: var(--selection-color);
}

/* End Radio */

/**********************************************/
/*******        Helper Classes          *******/
/**********************************************/

.mb-0 {
    margin-bottom: 0;
}

.mb-5 {
    margin-bottom: 5px;
}

.mb-10 {
    margin-bottom: 10px;
}

.mb-20 {
    margin-bottom: 20px;
}

.mb-25 {
    margin-bottom: 25px;
}

.mb-30 {
    margin-bottom: 30px;
}

.mb-40 {
    margin-bottom: 40px;
}

.mb-50 {
    margin-bottom: 50px;
}

.mt-10 {
    margin-top: 10px;
}

/**********************************************/
/*******      Media Query Classes       *******/
/**********************************************/

@media screen and (min-width: 768px) {
    header {
        height: 250px;
    }

    .lead {
        font-size: 1.25rem;
    }

    .animals {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .animal-box {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
    }

    .animal-text {
        /* height: 100%; */
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-flex: 1;
        -ms-flex: 1;
        flex: 1;
    }

    .animal-btn {
        margin-top: auto;
    }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    .navbar-toggle {
        display: block;
    }

    .carousel-control .glyphicon-chevron-right, .carousel-control .glyphicon-chevron-left {
        font-size: 2.5rem;
        margin-top: -25px;
    }
}

@media screen and (min-width: 992px) {
    .wrapper {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-flex: 1;
        -ms-flex: 1 0 auto;
        flex: 1 0 auto;
    }

    .left-sidebar {
        height: auto !important;
        min-height: 100% !important;
        margin-top: -15px;
        margin-bottom: -10px;
        padding: 10px 0 60px;
    }

    .container {
        min-height: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
    }

    main {
        min-height: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
    }

    .main-content {
        -webkit-box-flex: 1;
        -ms-flex: 1 0 auto;
        flex: 1 0 auto;
    }

    .navbar-collapse {
        margin-top: 10px;
    }

    .collapse {
        display: block;
        visibility: visible;
    }

    main p {
        width: 93%;
    }

    main .bullet-list {
        width: 85%;
    }

    main p.full-width {
        width: 100%;
    }
}

@media screen and (min-width: 992px) and (max-width: 1199px) {
    .logo img {
        max-width: 85%;
    }

    h1 {
        font-size: 2rem;
    }
}

@media screen and (min-width: 1200px) {
    .carousel {
        margin: 0 auto;
        -webkit-box-shadow: 15px 20px 30px rgba(0, 0, 0, 0.25);
        box-shadow: 15px 20px 30px rgba(0, 0, 0, 0.25);
    }

    .banner {
        -webkit-box-shadow: 15px 20px 30px rgba(0, 0, 0, 0.25);
        box-shadow: 15px 20px 30px rgba(0, 0, 0, 0.25);
    }

    .carousel-control .glyphicon-chevron-right, .carousel-control .glyphicon-chevron-left {
        font-size: 2.5rem;
        margin-top: -25px;
    }
}

@media screen and (max-width: 1199px) {
    img.img-left, img.img-right {
        max-width: 60%;
    }

    .img-cover-lg {
        height: 100%;
        width: 100%;
        -o-object-fit: cover;
        object-fit: cover;
        -o-object-position: center center;
        object-position: center center;
    }

    .img-cover-container-lg {
        position: relative;
        width: 100%;
        height: 350px;
    }

    .mb-10-lg {
        margin-bottom: 10px;
    }

    .mb-30-lg {
        margin-bottom: 30px;
    }
}

@media screen and (max-width: 991px) {
    .navbar-collapse {
        -webkit-box-shadow: none;
        box-shadow: none;
    }

    .logo {
        bottom: 30%;
    }

    .logo img {
        max-width: 85%;
    }

    h1 {
        font-size: 1.5rem;
    }

    .mb-5-md {
        margin-bottom: 5px;
    }

    .mb-10-md {
        margin-bottom: 10px;
    }

    .mb-20-md {
        margin-bottom: 20px;
    }

    .mb-30-md {
        margin-bottom: 30px;
    }

    .mb-40-md {
        margin-bottom: 40px;
    }

    .mb-50-md {
        margin-bottom: 50px;
    }
}

@media screen and (max-width: 767px) {
    .mb-5-sm {
        margin-bottom: 5px;
    }

    .mb-10-sm {
        margin-bottom: 10px;
    }

    .mb-20-sm {
        margin-bottom: 20px;
    }

    .mb-30-sm {
        margin-bottom: 30px;
    }

    .mb-40-sm {
        margin-bottom: 40px;
    }

    .mb-50-sm {
        margin-bottom: 50px;
    }
}

@media screen and (max-width: 650px) {
    img.img-left, img.img-right {
        display: block;
        float: none;
        margin: 5px auto;
        max-width: 100%;
    }

    .img-cover-container-lg {
        height: 275px;
    }
}

@media screen and (max-width: 499px) {
    .header-contact-bar {
        font-size: .75rem;
        padding: 13px 15px;
        text-align: left;
    }

    h1 {
        font-size: 1.25rem;
    }

    .img-cover-container-lg {
        height: 225px;
    }
}