.promo-container {
    overflow: hidden;
    position: relative;
    max-width: 1920px;
    margin: 0 auto;
}

.promo-container img {
    display: block;
    width: 100%;
}

.promo-container h2 {
    font-size: min(2.345vw,45px);
    font-weight: 500;
    margin: 20px 0;
}

.promo-container h3 {
    font-size: min(1.25vw,24px);
    font-weight: 500;
    margin-top: 1em;
}

.promo-container p {
    font-size: min(1.02vw,19.5px);
    line-height: 2;
}

.promo-container a {
    color: #0a5a5a;
}

.promo-container ul,
.promo-container ol {
    font-size: min(1vw,19.5px);
    margin: .5em 1.5em;
}

.promo-container li {
    margin-bottom: .5em;
}

.promo-container .hero {
    position: relative;
    width: 100%;
}

.promo-container .hero .text-container {
    position: absolute;
    display: flex;
    flex-direction: column;
    width: 37%;
    left: 4%;
    top: 30%;
}

.promo-container .hero h1 {
    font-size: min(3.125vw,80px);
    font-weight: 400;
    line-height: 1;
    color: white;
    margin: 0;
}

.promo-container .hero span.green-text {
    color: #a8cf3b;
}

.promo-container .hero .text-container p {
    font-size: min(1.5vw,28px);
    color: #fff;
    margin: .5em 0;
}

.promo-container .hero a.redeem-button {
    display: block;
    width: fit-content;
    background: rgb(168,207,59);
    font-size: min(1.5vw,28px);
    padding: .2em 1em;
    border-radius: .7em;
    color: #000;
    text-decoration: none;
}

.promo-container .hero .caption {
    position: absolute;
    transform: translateX(-50%);
    color: white;
    text-align: center;
    margin: 0;
}

.promo-container .hero .caption.lg {
    font-size: min(2.25vw,36px);
    line-height: 1;
    top: 30%;
    left: 86%;
    width: 25%;
}

.promo-container .hero .caption.sm {
    font-size: min(1.375vw,22px);
    top: 73%;
    left: 86%;
}

.promo-container .hero .caption span.bold {
    font-weight: 500;
}

.promo-container .promo-content {
    margin: min(4.17vw,80px);
}

.promo-container .promo-content a.terms {
    font-size: min(1vw,19.5px);
}

.promo-container .promo-content table {
    width: 18%;
    border: 2.5px solid;
    border-collapse: collapse;
    table-layout: fixed;
    margin-top: min(1.04vw,20px);
}

.promo-container .promo-content th, td {
    border-left: 3px solid #000;
    border-bottom: 2px solid #000;
}

.promo-container .promo-content th {
    background: #00a870;
    font-size: min(1vw,19.5px);
    font-weight: 500;
    text-align: center;
    color: white;
    padding: .75em;
}

.promo-container .promo-content td {
    font-size: min(.91vw,17.5px);
    padding: .25em .45em;
}

.promo-container .promo-content td:nth-child(2) {
    text-align: right;
}

.promo-container .redemption {
    display: flex;
    flex-direction: column;
    background: #7eccd9;
}

.promo-container .redemption h2 {
    font-size: min(2.345vw,45px);
    font-weight: 500;
    color: #2b2b2b;
}

.promo-container .redemption label {
    font-size: min(1.02vw,19.5px);
    line-height: 1.25;
    color: #2b2b2b;
    margin-bottom: .3em;
}

.promo-container .redemption form {
    width: min(60.94vw,1170px);
    position: relative;
    display: flex;
    margin: 3vw auto;
}

.promo-container .redemption .content {
    width: 100%;
}

.promo-container .redemption .field {
    display: flex;
    flex-direction: column;
    margin-bottom: 1vw;
    width: 100%;
}

.promo-container .redemption .field.small {
    display: flex;
    flex-direction: column;
    margin-bottom: 1vw;
    width: 50%;
}

.promo-container .redemption .shrink {
    display: flex;
    align-items: center;
    margin-bottom: 1vw;
    width: fit-content;
}

.promo-container .redemption .shrink .attachment-name {
    display: flex;
    font-size: 1.25em;
    margin-left: 1em;
    width: fit-content;
}

.promo-container .redemption .field .text {
    padding: .5em .5em;
    border-radius: .5em;
    border: 0;
    font-size: min(1.02vw,19.5px);
}

.promo-container .redemption .display {
    display: flex;
    flex-direction: column;
    margin-bottom: 1vw;
    width: 100%;
}

.promo-container .redemption .display .text {
    background: transparent;
    font-size: min(1.02vw,19.5px);
    border: 0;
    font-family: inherit;
    width: 100%;
}

.promo-container .redemption .field input[type="date"] {
    font-family: inherit;
    font-size: min(1.02vw,19.5px);
    color: #6b6b6b;
    width: 30%;
}

.promo-container .redemption .field input[type="date"]::-webkit-datetime-edit {
    font-family: inherit;
}

.promo-container .redemption .field input.redeem-value {
    background: transparent;
}

.promo-container .redemption form .field-row {
    display: flex;
    justify-content: space-between;
    gap: 7%;
}

.promo-container .redemption form .empty {
    display: none;
    color: #8A0303;
    margin: .5em .5em;
}

.promo-container .redemption form select {
    font-family: inherit;
}

.promo-container .redemption form select:invalid {
    color: #6b6b6b;
}

.promo-container .redemption form .submit {
    margin: 0 auto;
    display: inline-block;
}

.promo-container .redemption form button.btn {
    margin-top: 1em;
    padding: 0.75em 5em;
    font-size: min(1.02vw,19.5px);
    border-radius: .5em;
    border: 0;
}

.promo-container .redemption form button.btn:hover {
    cursor: pointer;
    background: #f1c900;
}

.promo-container .redemption .submission {
    margin: 2vw 0;
}