﻿@font-face {
    font-family: 'GothamNarrowBook';
    src: url('fonts/GothamNarrowBook.eot');
    src: url('fonts/GothamNarrowBook.eot') format('embedded-opentype'), url('fonts/GothamNarrowBook.woff2') format('woff2'), url('fonts/GothamNarrowBook.woff') format('woff'), url('fonts/GothamNarrowBook.ttf') format('truetype'), url('fonts/GothamNarrowBook.svg#GothamNarrowBook') format('svg');
}

@font-face {
    font-family: 'GothamNarrowBold';
    src: url('fonts/GothamNarrowBold.eot');
    src: url('fonts/GothamNarrowBold.eot') format('embedded-opentype'), url('fonts/GothamNarrowBold.woff2') format('woff2'), url('fonts/GothamNarrowBold.woff') format('woff'), url('fonts/GothamNarrowBold.ttf') format('truetype'), url('fonts/GothamNarrowBold.svg#GothamNarrowBold') format('svg');
}

@font-face {
    font-family: 'GothamNarrowLight';
    src: url('fonts/GothamNarrowLight.eot');
    src: url('fonts/GothamNarrowLight.eot') format('embedded-opentype'), url('fonts/GothamNarrowLight.woff2') format('woff2'), url('fonts/GothamNarrowLight.woff') format('woff'), url('fonts/GothamNarrowLight.ttf') format('truetype'), url('fonts/GothamNarrowLight.svg#GothamNarrowLight') format('svg');
}

a, .btn {
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
}

::selection {
    background-color: #990000;
    color: #fff;
}

::-moz-selection {
    background-color: #990000;
    color: #fff;
}
/*ONE CSS TO RULE THEM ALL */
* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    outline: none;
}

body, html {
    -webkit-font-smoothing: antialiased;
    text-rendering: geometricPrecision;
    font-family: 'GothamNarrowBook', Arial, sans-serif !important;
}

    html body {
        font-weight: 400;
        background: #222222;
        font-size: 15px;
        margin: 0;
        padding: 0;
        line-height: 1.3;
    }
	header{
		background:#fff
	}

img.auth0-lock-custom-icon {
    width: 40px !important;
    height: auto !important;
    top: 0 !important;
    left: 0 !important;
}

body .auth0-lock.auth0-lock .auth0-lock-header-logo {
    width: auto;
    height: 85px;
    display: inline-block;
    margin: 10px 0 11px;
    vertical-align: middle;
    transition: margin-top 0.4s;
}

.auth0-lock.auth0-lock .auth0-lock-header-logo.centered {
    margin-top: 10px !important;
}

p {
    font-family: 'GothamNarrowBook', Arial, sans-serif !important;
    margin: 0 0 15px;
}

strong {
    font-family: 'GothamNarrowBold', Arial, sans-serif !important;
    font-weight: 400;
}

h1, h2, h3, h4, h5, h6 {
    font-weight: 400;
}

h2 {
    margin: 0;
    text-transform: uppercase;
    font-size: 26px;
}

h3 {
    font-size: 24px;
    margin: 10px 0 20px;
}

h4 {
    font-size: 21px;
    margin: 0 0 5px;
}

h5 {
    font-size: 18px;
    margin: 0 0 10px;
}

header {
   /* border-bottom: 1px solid #323232;*/
    padding: 15px 0 10px;
}

.text-center {
    text-align: center;
}

.container {
    width: 100%;
}

.wrapper {
    width: 650px;
    margin: 0 auto 50px;
    position: relative;
    border-radius: 4px;
}

    .wrapper.flexible {
        width: 100%;
        border-radius: 0px !important;
    }
    .wrapper.dsssub{
        width:70%;
    }

    .wrapper .content {
        padding: 20px 40px;
    }

    .wrapper .title {
        padding: 20px 40px;
        color: #fff;
        border-radius: 4px 4px 0 0;
    }

.bg-white {
    background: #FFF;
}

.bg-red {
    background: #990000;
}

.bg-lightgray {
    background: #ddd;
}

.buffer-bottom-10 {
    margin-bottom: 10px;
}

.buffer-bottom-20 {
    margin-bottom: 20px;
}

.buffer-bottom-30 {
    margin-bottom: 30px;
}

.buffer-bottom-40 {
    margin-bottom: 40px;
}

.buffer-bottom-50 {
    margin-bottom: 50px;
}

.buffer-top-30 {
    margin-top: 30px;
}

.buffer-top-10 {
    margin-top: 10px;
}

.pad-bottom-30 {
    padding-bottom: 30px;
}

footer {
    border-top: 1px solid #323232;
    color: #7c7c7c;
    padding: 25px 0;
    font-size: 14px;
}

hr.dashed {
    border-top: 1px dashed #ccc;
    height: 0;
    /* Set the hr color */
    color: transparent; /* old IE */
    background-color: transparent; /* Modern Browsers */
}

input[type="text"], input[type="password"], select {
    padding: 4px 12px;
    height: 40px;
    border: 1px solid #999999;
    border-radius: 2px;
    background: #FFF;
    width: 100%;
}

    input[type="text"].half, input[type="password"].half {
        width: 50%;
    }

    input[type="text"].small, input[type="password"].small {
        width: 100px;
    }

    input[type="text"].inline, input[type="password"].inline {
        display: inline-block;
    }

label {
    font-size: 11px;
    color: #999999;
    font-family: 'GothamNarrowBold';
    text-transform: uppercase;
    display: block;
    margin-bottom: 5px;
}

.col-full {
    width: 100%;
    float: left;
    padding-right: 15px;
    padding-left: 15px;
}

.col-half {
    width: 50%;
    float: left;
    padding-right: 15px;
    padding-left: 15px;
}

.col-third {
    width: 33.33%;
    float: left;
    padding-right: 15px;
    padding-left: 15px;
}

.col-twothird {
    width: 66.66%;
    float: left;
    padding-right: 15px;
    padding-left: 15px;
}

.col-quarter {
    width: 25%;
    float: left;
    padding-right: 15px;
    padding-left: 15px;
}

.row {
    margin-right: -15px;
    margin-left: -15px;
}

    .row:after {
        clear: both;
        content: "";
        display: table;
    }

.btn {
    height: 40px;
    min-width: 120px;
    padding: 10px 12px;
    text-align: center;
    text-transform: uppercase;
    border-width: 1px;
    border-style: solid;
    border-radius: 3px;
    font-family: 'GothamNarrowBold';
    margin-top: 0;
    font-size: 13px;
    position: relative;
    top: 1px;
}

.btn-red {
    background-color: #990000;
    border-color: #990000;
    color: #ffffff;
}

a.btn {
    text-decoration: none;
    display: inline-block;
    padding-top: 10px;
}

.btn-red:hover, a.btn-red:hover {
    opacity: 0.8;
    color: #fff;
}

.footer {
    border-top: 1px solid #ccc;
    padding: 20px 40px 0;
    margin-right: -40px;
    margin-left: -40px;
}

    .footer p {
        margin: 0;
    }

.logo {
    height: 45px;
}

a {
    font-family: GothamNarrowBold;
    text-decoration: underline;
    color: inherit;
}

    a:hover {
        color: #990000;
        text-decoration: none;
    }
/* ▲ MATCH ▲ */
.color-red {
    color: #990000;
}

.color-grey {
    color: #666666;
}

.border-bottom {
    border-bottom: 1px dashed #ddd;
}

.notification {
    border-radius: 10px;
    padding: 10px 15px;
}

    .notification p {
        margin: 0;
        font-size: 13px;
    }

    .notification.error {
        background: #e74c3c;
        color: #fff;
    }

    .notification.info {
        background: #f39c12;
        color: #fff;
    }

    .notification.success {
        background: #1abc9c;
        color: #fff;
    }
/* ▲ ACCESS ▲ */

.img-responsive {
    width: 100%;
}

.img-responsive-50 {
    width: 50%;
}

.box {
    padding: 10px;
}

    .box.bg-lightgray:hover {
        background: #ccc;
        cursor: pointer;
    }

.font-small {
    font-size: 13px;
}

.float-left {
    float: left;
}

.cancel {
    line-height: 2;
    margin-left: 10px;
}

.ErrorField {
    border-color: #e74c3c !important;
}

.NewLoader, .LoginLoader {
    background-image: url('../../../images/loading.gif');
    background-repeat: no-repeat;
    display: block;
    width: 32px;
    height: 32px;
    margin-left: -7px;
} 

/* */

@media only screen and (max-width: 1024px) {
    .col-third.offer {
        width: 100%;
    }     
}

@media only screen and (min-width: 1024px) {
    .logomargin {
        margin-left: 18% !important;
    }
}

@media only screen and (max-width: 650px) {
    .wrapper, .wrapper.flexible {
        width: 90%;
    }

        .wrapper .content {
            padding: 20px 5%;
        }

    .footer {
        padding: 20px 0 0;
        margin-right: 0;
        margin-left: 0;
    }

    input[type="text"], input[type="password"], select {
        margin-bottom: 15px;
    }

    .wrapper .title {
        padding: 20px 15px;
    }  
    
     #pnlLogout .userloginlogo span, #pnlLogout .userloginlogo .userlogout, .userloginlogotext {
        display: none;
    }  
}

@media only screen and (max-width: 600px) {
    .col-full, .col-half, .col-third, .col-twothird, .col-quarter {
        width: 100%;
    }

    input[type="text"], input[type="password"] {
        width: 100% !important;
    }

    .col-third-ch {
        width: 33.33% !important;
    }     
}


.placeholder {
    color: #aaa;
}

ul, li {
    list-style: none;
    margin: 0;
    padding: 0;
}

    ul.square {
        margin-bottom: 25px;
    }

        ul.square li {
            list-style: square inside;
            margin-bottom: 10px;
        }



.absolute {
    position: absolute;
}


input[type="text"].zip {
    min-width: 100px;
}

input[type="checkbox"], input[type="radio"] {
    float: left;
}

input.zip {
    max-width: 90px;
    font-size: 15px;
}

input.short {
    max-width: 60px;
}

header, nav, section, article, aside, footer {
    display: block;
}

.floatleft, .left {
    float: left;
}

.floatright, .right {
    float: right;
}

.clearfloat, .clear {
    clear: both;
    height: 0px;
    line-height: 0px;
}

.border {
    border-bottom: 1px #CCC dashed;
    padding-bottom: 8px;
}

.label {
    background: #CCC;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 13px;
    font-weight: 300;
}

    .label.color {
        background: #394e7a;
        color: #FFF;
    }

.one-third {
    width: 33.3%;
}

.two-third {
    width: 63.6%;
}

.one-fourth {
    width: 25%;
}

.is_inactive, .is_inactive:hover {
    border: 1px #cccccc solid;
    background: #e6e6e6;
    color: #999999;
}


.HighlightErrorFormField {
    border-color: red !important;
    border-style: dashed !important;
    border-width: 1px !important;
}

.CustomFormError {
    cursor: pointer;
}

fieldset {
    border: 0;
    padding: 0;
}

select.ccExpiration {
    background-color: #FFFFFF !important;
}



.validInput {
    background: url("/images/global/tick.png") no-repeat right 10px center transparent !important;
}


.UnChecked {
    background: url("/images/global/UnCheck.gif") no-repeat left top transparent;
}

.Checked {
    background: url("/images/global/Check.png") no-repeat left top transparent;
}

.NewCheck {
    min-height: 16px;
    display: inline-block;
    min-width: 16px;
    vertical-align: text-bottom;
    cursor: pointer;
    background-size: 16px;
    margin-right: 5px;
}

.ExpansibleCollapse {
    background: url("/images/global/collapse.png") no-repeat left top transparent;
}

.ExpansibleExpand {
    background: url("/images/global/expand.png") no-repeat left top transparent;
}

.Expansible {
    min-height: 20px;
    min-width: 20px;
    padding-left: 4%;
    cursor: pointer;
    vertical-align: middle;
    margin-bottom: 20px;
}

.AddressView {
    background-color: #FFFFFF !important;
}

.BillingView {
    background-color: #FFFFFF !important;
}

.GoBackLink {
    cursor: pointer;
}


.expand {
    display: block;
    cursor: pointer;
    color: #394e7a;
    font-size: 13px;
    text-transform: uppercase;
    padding: 8px 0;
    border-top: 1px solid #eeeeee;
    border-bottom: 1px solid #eeeeee;
    margin: 10px;
    text-align: center;
}

.more {
    display: block;
    cursor: pointer;
    color: #394e7a;
    padding: 5px 0;
    border-top: 1px dotted #333D4A;
    margin: 0 0 10px;
    font-size: 13px;
}

.v-align {
    display: inline-block;
}

.loader > img {
    vertical-align: middle;
    margin-right: 5px;
}



.MultiLine {
    white-space: pre-wrap;
}


/*******MOST USED*******/
#dss .view {
    display: none;
    height: auto;
}

#dss .show {
    display: block !important;
}

#dss .hide {
    display: none !important;
}
/*******EXTRAS*******/
#dss .block {
    display: block;
}
/*******LIGHTBOX*******/
#lightbox {
    display: none;
    height: 80%;
    position: absolute;
    top: 0;
    width: 100%;
    left: 0;
}

    #lightbox DIV {
        background-color: #fff;
        margin: 0;
        position: relative;
        float: right;
        width: 264px;
        border: 1px solid #ddd;
        -moz-box-shadow: 0px 1px 3px rgba(000,000,000,0.5), inset 0px 1px 1px rgba(255,255,255,1);
        -webkit-box-shadow: 0px 1px 3px rgba(000,000,000,0.5), inset 0px 1px 1px rgba(255,255,255,1);
    }
/*******STUFF*******/

#dss #dvGift ul {
    background: #ddd;
    border: 1px solid #ccc;
}

    #dss #dvGift ul li {
        list-style: none;
    }

#dss .connect_to_digital > label, #dss #zip_promo_view > label {
    display: block;
    margin-top: 10px;
}

#dss .offer_list > h4 {
    margin-bottom: 15px;
}

#tooltip {
    padding: 10px 20px;
    color: white;
    background: black;
    border: 2px solid white;
    border-radius: 10px;
    box-shadow: 0 0 7px black;
    width: 300px;
}

.forgotPassword {
    font-size: 12px;
}
/**************************************************** THE CORE ONES */

#view-price-comparison {
    cursor: pointer;
    border-top: 1px solid #dddddd;
    border-bottom: 1px solid #dddddd;
    padding: 10px 0;
    display: block;
    text-align: center;
    text-transform: uppercase;
    font-size: 13px;
    color: #666666;
}

#showme {
    display: block !important;
}

.js-goto_offers + p {
    margin: 8px 0 0;
    text-indent: 10px;
}
/**************************************************** CONFIRM! */
.confirm .error {
    display: none;
}

.totalAmount {
    margin: 10px 0 20px;
}

ul.card-types {
    margin-left: 40px;
}

.cards {
    overflow: hidden;
    list-style: none;
    background-color: #FFFFFF !important;
}

    .cards li {
        -webkit-transition: all .2s;
        -moz-transition: all .2s;
        -ms-transition: all .2s;
        -o-transition: all .2s;
        transition: all .2s;
        background-image: url(/images/global/card_logos.png);
        background-position: 0 0;
        float: left;
        height: 32px;
        margin-right: 8px;
        text-indent: -9999px;
        width: 51px;
    }

        .cards li:last-child {
            margin-right: 0;
        }

    .cards .visa_electron {
        background-position: 204px 0;
    }

    .cards .mastercard {
        background-position: 153px 0;
    }

    .cards .amex {
        background-position: 102px 0;
    }

    .cards .discover {
        background-position: 51px 0;
    }

    .cards .visa.off {
        background-position: 0 32px;
    }

    .cards .visa_electron.off {
        background-position: 204px 32px;
    }

    .cards .mastercard.off {
        background-position: 153px 32px;
    }

    .cards .amex.off {
        background-position: 102px 32px;
    }

    .cards .discover.off {
        background-position: 51px 32px;
    }

.payment-options {
}

    .payment-options .field.opt.bank-account {
        margin-right: 0;
    }

    .payment-options .field.opt input[type="radio"] + label:before {
        left: 24px;
        top: 8px;
    }

.credit-card-Tab {
    min-width: 11%;
}

.payment-options .field.credit-card input {
    float: left;
}

.payment-options .card-types li {
    background-image: url(/dss/images/credit-cards-2x.png);
    background-repeat: no-repeat;
    background-size: 200px 32px;
    display: block;
    float: left;
    margin-right: 5px;
    height: 32px;
    text-indent: -9999px;
    width: 50px;
    transition: all 0.3s ease;
}

    .payment-options .card-types li.vi {
        background-position: 0 0;
        margin-left: -15px;
    }

    .payment-options .card-types li.mc {
        background-position: -50px 0;
    }

    .payment-options .card-types li.ax {
        background-position: -100px 0;
    }

    .payment-options .card-types li.di {
        background-position: -150px 0;
        margin-right: 20px;
    }

    .payment-options .card-types li.disabled {
        opacity: .3;
    }

.payment-method {
    display: none;
    min-height: 100px;
}

    .payment-method fieldset {
        width: 340px;
    }

    .payment-method.credit-card .field.card-security {
        float: left;
        margin: 0 10px 5px 0;
    }

    .payment-method.credit-card .ccv-example {
        background-image: url(/dss/images/credit-card-ccv-2x.png);
        background-position: 0 0;
        background-repeat: no-repeat;
        background-size: 107px 32px;
        display: block;
        float: left;
        height: 32px;
        position: relative;
        text-indent: -9999px;
        top: 2px;
        width: 107px;
    }

    .payment-method.credit-card .note {
        clear: both;
        color: #999999;
        font-size: 12px;
        margin-bottom: 0;
    }

    .payment-method.bank-account .note {
        color: #999999;
        font-size: 12px;
        margin: 2px 0 -10px 0;
    }

    .payment-method.bank-account .field.bank-routing-number, .payment-method.bank-account .field.bank-account-number {
        float: left;
        margin-right: 12px;
        width: 252px;
    }

    .payment-method.bank-account .check-example {
        background-image: url(/dss/images/check-numbers-2x.png);
        background-size: 151px 34px;
        background-repeat: no-repeat;
        display: block;
        height: 34px;
        float: left;
        text-indent: -9999px;
        width: 76px;
    }

#view_submit_account input:disabled {
    background: #ccc;
    border-color: #aaa;
    color: #aaa;
}



@media only screen and (max-width: 600px) {
    footer li {
        display: block;
        padding: 0 14px 0 0;
        border-right: none;
    }  
}
/***********************************************
 LONG FORM OR SHORT FORM, THE MAGIC HAPPENS HERE
 ***********************************************/

/******** ONE PAGE LAYOUT ********/
@media only screen and (max-width: 768px) {
    .longFormHide {
        display: block !important;
    }

    #pnlLogout .userloginlogo span, #pnlLogout .userloginlogo .userlogout, .userloginlogotext {
        display: none;
    }    
}

@media only screen and (min-width: 768px) {
    .longFormHide {
        display: none !important;
    }

    .step-text {
        display: none;
    }     
}

@media screen and (max-width: 480px) {   
    #pnlLogout .userloginlogo span, #pnlLogout .userloginlogo .userlogout, .userloginlogotext {
        display: none;
    }
}


.userloginlogo svg {
    display: inline-block;
    vertical-align: middle;
    width: 16px;
    height: 18px;
    cursor:pointer;
}
.userloginlogo .userlogout{
    cursor:default;
    margin-right:3px;
}

.userloginlogo svg path {
    fill-rule: evenodd;
    clip-rule: evenodd;
    fill: none;
    stroke: #000;
    stroke-width: 2;
    stroke-miterlimit: 10;
}

.userloginlogo svg line, .userloginlogo svg polygon, .userloginlogo svg polyline {
    fill-rule: evenodd;
    clip-rule: evenodd;
    fill: none;
    stroke: #000;
    stroke-width: 2;
    stroke-miterlimit: 10;
}

.userloginlogo svg polygon {
    fill: #000;
    stroke-width: 1;
}

.userloginlogotext {
    font-weight: 400;
    cursor: pointer;
    max-width: 210px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    vertical-align: middle;
    color: #000;
   
}

.userloginlogo, .userloginlogotext  {
    margin-top: 10px;
    vertical-align:bottom;
}

.topNavdss {
    font-weight: 400;
    padding: 5px;    
}

.dssloginbox {
    float: right;
    padding-right: 25px;
}
    .dssloginbox span {
        margin-right: 5px;
        vertical-align: bottom
    }

.innerdiv {   
    display: inline-block;
}

.bold{font-weight:bold;}

.pad-left-25 {
    padding-left: 25px;
    padding-top: 10px;
}
.pad-left-0{
    padding-left: 0px;
}

.title.bg-red h2{
    color:#fff;
}