*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
}

a {
    background-color: transparent;
}

button,
input,
textarea,
select {
    font: inherit;
    margin: 0;
}

button {
    border-radius: 0;
}

.container {
    width: 100%;
    max-width: 1200px;
    margin-right: auto;
    margin-left: auto;
    padding-right: 15px;
    padding-left: 15px;
}

.row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -15px;
    margin-left: -15px;
}

.row > [class^="col-"],
.row > [class*=" col-"] {
    position: relative;
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
}

.col-2 { flex: 0 0 16.666667%; max-width: 16.666667%; }
.col-10 { flex: 0 0 83.333333%; max-width: 83.333333%; }
.col-12 { flex: 0 0 100%; max-width: 100%; }

.d-none { display: none !important; }
.d-flex { display: flex !important; }

.text-left { text-align: left !important; }
.text-center { text-align: center !important; }
.text-white { color: #fff !important; }
.text-danger { color: #dc3545 !important; }

.m-0 { margin: 0 !important; }
.m-5 { margin: 3rem !important; }
.m-auto { margin: auto !important; }
.mt-5 { margin-top: 3rem !important; }
.p-0 { padding: 0 !important; }
.pt-3 { padding-top: 1rem !important; }
.pl-0 { padding-left: 0 !important; }

@media (min-width: 576px) {
    .col-sm-6 { flex: 0 0 50%; max-width: 50%; }
}

@media (min-width: 768px) {
    .col-md-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
    .col-md-6 { flex: 0 0 50%; max-width: 50%; }
    .col-md-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
    .col-md-12 { flex: 0 0 100%; max-width: 100%; }
    .d-md-block { display: block !important; }
    .d-md-inline-flex { display: inline-flex !important; }
    .text-md-right { text-align: right !important; }
}

@media (min-width: 992px) {
    .col-lg-3 { flex: 0 0 25%; max-width: 25%; }
    .col-lg-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
    .col-lg-6 { flex: 0 0 50%; max-width: 50%; }
    .col-lg-7 { flex: 0 0 58.333333%; max-width: 58.333333%; }
    .col-lg-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
    .col-lg-9 { flex: 0 0 75%; max-width: 75%; }
    .pl-lg-2 { padding-left: .5rem !important; }
    .pl-lg-5 { padding-left: 3rem !important; }
}
