@charset "utf-8";
:root {
    font-size: 16px;
}
* {
    box-sizing: border-box;
    margin: 0;
}
html {
    min-height: 100%;
}
body {
    color: #000;
    font: 1em/1.5 Arial, sans-serif;
}
#wrapper {
    position: relative;
    max-width: 1048px;
    margin: 1rem auto;
    border: solid 1px #000;
    background-color: #fff;
    overflow: hidden;
}
#wrapper::before {
    content: "";
    width: 360px;
    height: 100%;
    background-color: #262667;
    position: absolute;
    top: 0;
    left: 0;
}
h1 {
    margin: 0 0 2.625rem;
    font-size: 1.4em;
    line-height: 1.1;
}
h1 span {
    font-size: 0.7em;
    font-weight: 400;
    line-height: 1.3;
    display: block;
}
h2 {
    font-size: 1.25em;
    line-height: 1.3;
    margin-bottom: 0.75rem;
    color: #262668;
}
h2 + p {
    text-align: justify;
    padding-bottom: 1.75rem;
}
h3 {
    font-size: 1.063em;
    line-height: 1.3;
    margin-bottom: 0.25rem;
}
.left h3 {
    font-size: 0.75em;
    line-height: 1.3;
}
h4 {
    font-size: 0.8em;
    line-height: 1.3;
    margin-bottom: 0.625rem;
}
h4 span, .bg:last-of-type p:last-of-type {
    font-size: 0.6rem;
    line-height: 1.3;
    display: block;
}
.upper {
    text-transform: uppercase;
}
:is(a:link, a:visited, a:hover, a:active) {
    color: inherit;
    text-decoration: none;
    white-space: nowrap;
}
img {
    max-width: 100%;
    height: auto;
}
ul {
    padding: 0 0 1.625rem;
    list-style: none;
}
.pb {
    padding-bottom: 0.25rem;
}
li {
    padding: 0 0 0.5rem 2.625rem;
}
ul li:before {
    content: "›";
    font-size: 1em;
    float: left;
    margin: -1px 0 0 -1.25rem;
}
.icon li::before {
    content: "";
    width: 12px;
    height: 15px;
    background: url('../images/icon.jpg') no-repeat center;
    margin: 2px 0 0 -1.625rem;
}
header, .left, footer {
    position: absolute;
    left: 3rem;
    width: 270px;
}
header {
    top: 4.25rem;
}
.left {
    top: 9rem;
}
.left li {
    padding: 0 0 0.75rem 1.5rem;
    font-size: 0.85em;
    line-height: 1.3;
}
.left ul li::before {
    margin: 0 0  0 -0.75rem;
}
.font {
    font-size: 0.8em;
    line-height: 1.3;
    padding-bottom: 1.25rem;
}
.font span {
    font-size: 0.7em;
    line-height: 1.3;
    display: block;
    color: #75759F;
}
.right {
    width: 578px;
    margin: 2.625rem 3rem 30.5rem auto;
}
hr {
    margin: 0.625rem 0 1.125rem;
    width: 262px;
    border: 0;
    border-bottom: 1px solid #75759F;
}
footer {
    bottom: 2rem;
}
.bg {
    background-color: #1A1A4D;
    border-radius: 0 0 4px 4px;
    padding: 1.25rem 0.875rem 0.875rem;
    border-top: 3px solid #D3317C;
}
.bg:first-of-type {
    margin-bottom: 228px;
    padding-top: 0.375rem;
}
.bg:last-of-type p {
    padding-bottom: 1rem;
    font-size: 0.7em;
    line-height: 1.4;
}
h3, footer strong, ul li::before, h1 span {
    color: #D3317C;
}
h1, .left :is(p, li), footer p, h4 {
    color: #fff;
}
.font span, h4 span, .color {
    color: #75759F;
}
footer h3 + p {
    font-size: 0.8em;
    line-height: 1.4;
}
@media only screen and (max-width: 1047px) {
    #wrapper {
        border: none;
        margin: 0 auto;
    }
    #wrapper::before, h1 br {
        display: none;
    }
    header, .left, footer {
        width: auto;
        padding: 1rem 2rem;
        position: static;
        background-color: #262667;
    }
    header {
        display: flex;
        justify-content: center;
    }
    h1 {
        text-align: center;
        margin-bottom: 2rem;
    }
    .font {
        width: 110px;
        margin: 0 auto;
    }
    hr {
        margin: 0.625rem auto 1.25rem;
    }
    .right {
        margin: 0;
        width: auto;
        padding: 1rem 2rem;
    }
    h2 + p {
        text-align: left;
    }
    .bg:first-of-type {
        margin-bottom: 2.5rem;
    }
    h4 span, .bg:last-of-type p:last-of-type {
        font-size: 0.7rem;
        line-height: 1.4;
    }
}
@media only screen and (max-width: 1047px) {
    header, .left, .right, footer {
        padding: 1rem;
    }
    li {
        padding-left: 1.625rem;
    }
}