/* ------------------------------------------------------------ *\
	Helpers
\* ------------------------------------------------------------ */

.hidden { display: none; }

/* ------------------------------------------------------------ *\
	Validator
\* ------------------------------------------------------------ */

.form-controls.error .select select,
.form-controls.error .textarea,
.form-controls.error .field { border-color: #bf0909; }

.list-radios-shipping.error:after { background: #bf0909; color: #fff; }

/* ------------------------------------------------------------ *\
	Main
\* ------------------------------------------------------------ */

.main-shopping { padding-bottom: 0; }

/* ------------------------------------------------------------ *\
	Nav mobile // fixes the blue header bug
\* ------------------------------------------------------------ */

.nav-mobile { transform: translateX(-276px); }

/* ------------------------------------------------------------ *\
	Section Shopping
\* ------------------------------------------------------------ */

.section-shopping .shell:after,
.section-shopping .section-body:after { content: ''; line-height: 0; display: table; clear: both; }

.section-shopping .shell { position: relative; }

.section-shopping .section-head { background: #3165b0; color: #fff; padding: 20px 0; }
.section-shopping .section-head h2 { font-size: 25px; text-transform: uppercase; font-weight: 400; font-family: 'Montserrat', sans-serif; }

.section-shopping .section-nav { background: #0b3776; color: #fff; font-family: 'Montserrat', sans-serif; position: relative; z-index: 1; }
.section-shopping .section-nav ul { counter-reset: list; }
.section-shopping .section-nav li { display: inline-block; position: relative; color: #3e7bbe; font-size: 16px; font-weight: 400; padding: 15px 0; }
.section-shopping .section-nav li:before { content: counter(list) '.'; counter-increment: list; margin-right: 5px; }
.section-shopping .section-nav li ~ li { margin-left: 90px; }
.section-shopping .section-nav a { pointer-events: none; cursor: default; color: inherit; text-decoration: none; }
.section-shopping .section-nav .current { color: #fff; }
.section-shopping .section-nav .current:after { content: ''; width: 0; height: 0; border-style: solid; border-width: 12px 12px 0 12px; border-color: #0b3776 transparent transparent transparent; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); -webkit-transform: translateX(-50%); }
.section-shopping .section-nav .checked:after { content: ''; border: 0; background: url(images/icons/ico-nav-checked.png) no-repeat 0 0; width: 24px; height: 16px; display: inline-block; vertical-align: middle; position: absolute; top: 20px; left: 100%; margin-left: 10px; }
.section-shopping .section-nav .checked a { pointer-events: auto; cursor: pointer; }

.section-shopping .section-content { width: calc(100% - 347px); float: left; padding-top: 40px; padding-bottom: 80px; padding-right: 38px; -webkit-box-shadow: inset -10px 0px 10px -5px #efefef; box-shadow: inset -10px 0px 10px -5px #efefef; }
.section-shopping .section-aside { width: 309px; float: right; padding: 40px 16px 80px 0px; position: relative; }
.section-shopping .section-aside .section-aside-loading-overlay { background: rgba(172, 172, 172, 0.5); position: absolute; width: 110%; height: 100%; z-index: 10; margin-left: -16px; display: none; }
.section-shopping .section-aside.loading .section-aside-loading-overlay { display: block; }
.section-aside-loading-overlay .loading-overlay-content { text-align: center; top: 50%; position: absolute; width: 100%; font-size: 25px; color: black; }

.section-shopping .section-aside-inner { width: 309px; }

.section-shopping .section-actions-mobile { display: none; text-align: center; }
.section-shopping .section-actions-mobile .btn { display: block; }

@media(max-width: 1199px){
	.section-shopping .shell { padding: 0 15px; }
}

@media(max-width: 767px){
	.section-shopping .section-content,
	.section-shopping .section-aside { width: 100%; -webkit-box-shadow: none; box-shadow: none; }
	
	.section-shopping .section-content { padding-right: 0; padding-bottom: 20px; }
	.section-shopping .section-aside { padding: 12px 0 30px; width: 100%; }
	.section-shopping .section-aside-inner { position: static !important; width: 100%; }

	.section-shopping .section-head { text-align: center; font-size: 17px; }

	.section-shopping .section-nav ul { display: table; width: 100%; }
	.section-shopping .section-nav li { font-size: 15px; display: table-cell; text-align: center; }
	.section-shopping .section-nav li:before { display: none; }
	.section-shopping .section-nav li ~ li { margin-left: 0; }
	.section-shopping .section-nav .checked:after { display: none; }

	.section-shopping .section-actions-mobile { display: block; }
}

/* ------------------------------------------------------------ *\
	Table Products
\* ------------------------------------------------------------ */

.table-products { }
.table-products table { width: 100%; }

.table-products th { font-size: 14px; font-weight: 600; color: #5c5c5c; border-bottom: 1px solid  #f1f1f1; text-align: left; padding-bottom: 10px; }
.table-products td { border-bottom: 1px solid  #f1f1f1; padding: 37px 0; vertical-align: top; }
.table-products td:nth-child(2) { width: 160px; }
.table-products td:nth-child(3) { width: 135px; }
.table-products td:nth-child(4) { text-align: right; }
.table-products td:nth-child(4) a { font-size: 13px; }

.table-products h3 { color: #225d9b; font-size: 14px; font-weight: 600; line-height: 1.3; text-transform: capitalize; padding-right: 25px; }
.table-products h3 span { text-transform: uppercase; display: block; }

.table-products .price { color: #5c5c5c; font-size: 15px; }
.table-products .table-controls:after { content: ''; line-height: 0; display: table; clear: both; }
.table-products .form-controls { width: 45px; display: inline-block; float: left; }
.table-products .field { border: 1px solid  #f0f0f0; color: #3e7bbe; width: 100%; height: 34px; text-align: right; margin-top: 10px; }
.table-products .btn { height: 34px; line-height: 34px; font-size: 12px; font-family: 'Montserrat', sans-serif; padding-top: 1px; border: 0; margin-top: 10px; }
.table-products .btn { line-height: 1.2; height: auto; padding: 10px 20px; }

.table-products .table-controls { margin-top: -10px; }

.table-products .table-foot { text-align: right; border-bottom: 1px solid  #f1f1f1; font-size: 14px; color: #5c5c5c; padding: 20px 0; }
.table-products .table-foot:after { content: ''; line-height: 0; display: table; clear: both; }
.table-products .table-foot span { display: inline-block; margin-left: 45px; }

.table-products .table-actions { padding-top: 30px; }
.table-products .table-actions:after { content: ''; line-height: 0; display: table; clear: both; }

@media(max-width: 1200px){
	.table-products td:nth-child(1) { padding-right: 10px; }
	.table-products td:nth-child(2) { width: 120px; }
	.table-products td:nth-child(3) { width: 80px; }
	.table-products .btn { padding: 10px 5px; }
}

@media(max-width: 1023px){
	.table-products td:nth-child(2) { padding-right: 10px; }
	.table-products td:nth-child(4) { text-align: right; }
	.table-products .form-controls { float: right; margin-bottom: 15px; }
	.table-products .form-controls { float: none; display: block; overflow: hidden; width: 100%; }
	.table-products .form-controls .field { float: right; width: 45px; }
}

@media(max-width: 767px){
	.table-products tr,
	.table-products td,
	.table-products tbody,
	.table-products thead,
	.table-products table { display: block; width: 100%; }
	
	.table-products tr { position: relative; min-height: 280px; border-bottom: 1px solid  #f1f1f1; padding: 45px 0 90px; }
	.table-products tr:first-child { min-height: 0; padding: 0; }
	.table-products th:nth-child(2) { display: none; }
	.table-products th:nth-child(3) { display: none; }
	.table-products td { border-bottom: 0; padding: 0; }
	.table-products td:nth-child(1) { padding-right: 100px; }
	.table-products td:nth-child(2) { width: 90px; position: absolute; top: 45px; right: 0; }
	.table-products td:nth-child(4) { position: absolute; bottom: 5px; left: 0; width: 100%; text-align: right; }
	.table-products td:nth-child(4):before { content: 'Quantity'; font-size: 14px; color: #5c5c5c; font-weight: 600; position: absolute; top: 7px; left: 0; }
	
	.table-products .form-controls { float: none; }
	.table-products .link-remove { margin-top: 10px; display: block; width: 100%; text-align: left; }
	.table-products .btn { margin-top: 0px; }
	.table-products .table-foot { text-align: left; font-size: 18px; }
	.table-products .table-foot span { float: right; font-size: 28px; margin-top: -7px; }
	
	.table-products .form-controls { float: none; width: 45px; display: inline-block; margin: 10px 10px 0 0; }
	.table-products .form-controls .field { float: none; width: 100%; margin: 0 ; }
	.table-products td:nth-child(4) .btn { float: right; margin-top: 10px; }
	.table-products .btn { padding: 10px 20px; }
}

/* ------------------------------------------------------------ *\
	Table Costs
\* ------------------------------------------------------------ */

.table-costs { margin-bottom: 35px; }
.table-costs table { width: 100%; }
.table-costs td { padding: 2px 0; font-size: 14px; color: #5c5c5c; }
.table-costs td:last-child { text-align: right; }
.table-costs tr:last-child td { font-size: 20px; }

/* ------------------------------------------------------------ *\
	Voucher
\* ------------------------------------------------------------ */

.voucher { float: left; width: 60%; }
.voucher label { color: #5c5c5c; font-size: 14px; font-weight: 600; display: block; margin-bottom: 10px; }
.voucher-field { width: 100%; max-width: 164px; height: 34px; border: 1px solid  #9b9b9b; display: inline-block; padding: 0 10px; }
.voucher-btn { display: inline-block; vertical-align: top; background: #93ad5c; color: #fff; height: 34px; padding: 0px 15px; border: 0; -webkit-transition: background-color .3s; -o-transition: background-color .3s; transition: background-color .3s; text-transform: uppercase; }
.voucher-btn:hover { background: #758e41; }

@media(max-width: 1023px){
	.voucher { width: 100%; float: none; margin-bottom: 20px; }
}

@media(max-width: 767px){
	.voucher { border-bottom: 1px solid  #efefef; }
	.voucher label { color: #3e7bbe; font-size: 13px; font-weight: 400; }
	.voucher-field { width: calc(100% - 110px); max-width: 100%; }
	.voucher-btn { float: right; }
	.voucher-inner { display: none; }
}

/* ------------------------------------------------------------ *\
	Widgets Shopping
\* ------------------------------------------------------------ */

.widgets-shipping { list-style: none; }
.widgets-shipping p { font-weight: 600; color: #424242; font-size: 15px; }
.widgets-shipping a { color: #3e7bbe; }
.widgets-shipping .widget-body { margin-bottom: 15px; }
.widgets-shipping .btn { width: 100%; color: #fff; margin-bottom: 10px; min-height: 60px; }
.widgets-shipping .widget-actions small { color: #000; font-size: 14px; line-height: 1.3; display: inline-block; }

/*  Widget Shipping  */

.widget-shipping p { font-size: 15px; color: #5c5c5c; }
.widget-shipping p span { color: #ed2200; }

/*  Widget Checkout  */

.widget-checkout { }

.widget-checkout h4 { font-size: 19px; color: #424242; font-weight: 600; margin-bottom: 15px; margin-top: 10px; }
.widget-checkout .order-review { margin-top: 0; font-size: 19px;}

.widget-checkout .paypal { font-family: 'Montserrat', sans-serif; font-size: 13px; color: #5c5c5c; letter-spacing: 0.018em; margin-bottom: 11px; }
.widget-checkout .paypal:after { content: ''; line-height: 0; display: table; clear: both; }
.widget-checkout .paypal i { float: right; }
.widget-checkout .paypal img { float: right; width:78px; height:20px; }

.widget-checkout .widget-address { border: 1px solid  #f0f0f0; padding: 15px; margin-bottom: 20px; }
.widget-checkout .widget-address strong { font-size: 15px; font-weight: 600; color: #424242; letter-spacing: 0.018em; display: block; margin-bottom: 15px; }
.widget-checkout .widget-address strong a { text-transform: uppercase; font-size: 11px; color: #3e7bbe; font-weight: 700; }
.widget-checkout .widget-address p { font-size: 15px; line-height: 1.5; font-weight: 400; }

@media(max-width: 767px){
	.widget-logged-in .widget-actions p,
	.widget-logged-in p { display: none; }
}

/* ------------------------------------------------------------ *\
	List Radios Shipping
\* ------------------------------------------------------------ */

.list-radios-shipping { list-style: none; margin-top: 20px; margin-bottom: 20px; position: relative; }
/*.list-radios-shipping:after { content: 'Please choose a shipping option'; display: block; width: calc(100% - 10px); background: #d8d8d8; text-align: center; color: #424242; font-size: 14px; padding: 5px; }
.list-radios-shipping.filled:after { display: none; }*/

.list-radios-shipping li { position: relative; }

.list-radios-shipping input[type=radio] { display: none; }
.list-radios-shipping input[type=radio]:checked + label { border-color: #3a6cb3; position: relative; z-index: 1; }
.list-radios-shipping input[type=radio]:checked + label:before { background: #0b3776 url(images/icons/ico-check-white.png) no-repeat center 7px; border-color: #0b3776; }
.list-radios-shipping label { display: block; border: 1px solid  #999; font-size: 13px; color: #000; padding: 10px 40px 10px 15px; cursor: pointer; margin-top: -1px; }
.list-radios-shipping label:before { content: ''; width: 24px; height: 24px; border-radius: 50%; border: 1px solid  #9b9b9b; position: absolute; top: 50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); -o-transform: translateY(-50%); transform: translateY(-50%); right: 10px; z-index: 2; }
.list-radios-shipping-footer { background: #d8d8d8; text-align: center; color: #424242; font-size: 14px; padding: 5px; margin-top: -20px; margin-bottom: 20px; }
 .list-radios-shipping.filled + .list-radios-shipping-footer { display: none; }

/* ------------------------------------------------------------ *\
	List Products
\* ------------------------------------------------------------ */

.list-products { list-style: none; margin-bottom: 23px; }
.list-products li { position: relative; border-bottom: 1px solid  #c0c0c0; padding-right: 25px; color: #424242; font-size: 12px; font-weight: 600; padding-bottom: 15px; margin-bottom: 10px; font-size: 14px; color: #5c5c5c; }
.list-products strong { color: #225d9b; display: block; font-size: 12px; text-transform: capitalize; }
.list-products strong span { position: initial; text-transform: uppercase; display: block; }
.list-products span { position: absolute; top: 0; right: 0; }

@media(max-width: 767px){
	.list-products strong,
	.list-products li { font-size: 12px; }
}

/* ------------------------------------------------------------ *\
	Form Login
\* ------------------------------------------------------------ */

.form-login-secondary { border-top: 1px solid  #979797; margin-top: 15px; }

.form-login-secondary .form-head h3 { font-size: 15px; color: #424242; font-weight: 600; padding: 20px 0; }
.form-login-secondary .form-row ~ .form-row { margin-top: 10px; }

.form-login-secondary .field { width: 100%; border: 1px solid  #9b9b9b; height: 45px; padding: 0 10px; }
.form-login-secondary .form-label { color: #424242; font-size: 12px; letter-spacing: 0.018em; font-weight: 600; margin-bottom: 5px; display: inline-block; }
.form-login-secondary .form-btn { border: 1px solid  #989898; background: #444; color: #fff; text-align: center; width: 100%; height: 42px; display: inline-block; text-transform: uppercase; font-size: 15px; }
.form-login-secondary .form-btn:hover { background: #444 url(images/form-btn-hover.png) no-repeat center 0; -webkit-background-size: 100%; background-size: 100%; }
.form-login-secondary .form-actions { margin-top: 22px; text-align: center; font-family: 'Montserrat', sans-serif; }
.form-login-secondary .form-actions a { color: #326dbc; font-size: 15px; }

/* ------------------------------------------------------------ *\
	Form Shipping
\* ------------------------------------------------------------ */

.form-shipping { border-bottom: 1px solid  #efefef; }

.form-shipping p { margin: 10px 0; }
.form-shipping h4 { margin: 20px 0; font-size: 16px; }
.form-shipping h5 { margin: 0px 0 10px; font-size: 19px; color: #424242; font-weight: 600; }

.form-shipping .form-row { margin: 0 -21px; }
.form-shipping .form-row ~ .form-row { margin-top: 20px; }
.form-shipping .form-row:after { content: ''; line-height: 0; display: table; clear: both; }
.form-shipping .form-col { float: left; padding: 0 21px; width: 100%; }
.form-shipping .form-col-1of2 { width: 50%; }

.form-shipping .form-head { margin-bottom: 20px; }
.form-shipping .form-head:after { content: ''; line-height: 0; display: table; clear: both; }
.form-shipping .form-head h3 { font-size: 19px; color: #424242; font-weight: 600; float: left; }
.form-shipping .form-head small { float: right; color: #424242; font-size: 13px; font-style: italic; margin-top: 3px; }
.form-shipping .form-head small span { color: #ed2200; }

.form-shipping .textarea,
.form-shipping .field { width: 100%; height: 45px; border: 1px solid  #d2d2d2; padding: 0 10px; color: #074a89; font-size: 17px; }

.form-shipping .textarea { height: 80px; padding-top: 5px; padding-bottom: 5px; }
.form-shipping .form-label { font-size: 13px; color: #424242; margin-bottom: 5px; display: inline-block; }
.form-shipping .form-label span { color: #ed2200; }
.form-shipping .form-btn { border: 0; border-bottom: 5px solid #758e41; padding: 16px 20px; }
.form-shipping .field:disabled { background: none; }

.form-shipping .form-controls-disabled .field { border: 0; padding: 0; }

.form-shipping .form-section ~ .form-section { border-top: 2px solid  #f2f2f2; margin-top: 30px; padding-top: 30px; }

.form-shipping .form-section ~ .form-section-address,
.form-shipping .form-section ~ .form-section-details { border-top: 0; margin-top: 0; padding-top: 0; }

.form-shipping .form-section-address { display: none; }
.form-shipping .form-summary { margin-bottom: 20px; }

.form-shipping .select { position: relative; }
.form-shipping .select:hover:before { background: #93ad5c url(images/select-hover.png) no-repeat center 0; -webkit-background-size: 100%; background-size: 100%; }
.form-shipping .select:before { content: ''; background: #93ad5c; display: inline-block; position: absolute; top: 0; right: 0; bottom: 0; width: 45px; pointer-events: none; }
.form-shipping .select:after { content: ''; background: url(images/icons/ico-arrow-down.png) no-repeat 0 0; width: 20px; height: 12px; display: inline-block; vertical-align: middle; position: absolute; top: 50%; right: 13px; pointer-events: none; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); -o-transform: translateY(-50%); transform: translateY(-50%); }
.form-shipping .select select { display: block; width: 100%; height: 45px; -webkit-appearance: none; -moz-appearance: none; appearance: none; cursor: pointer; border: 1px solid  #d2d2d2; padding-left: 10px; border-radius: 0; background: #fff; font-size: 17px; color: #074a89; }
.form-shipping .select option { padding-left: 10px; }

.form-shipping .list-checkboxes { list-style: none; }
.form-shipping .list-checkboxes li { position: relative; }
.form-shipping .list-checkboxes label { font-size: 15px; color: #5c5c5c; font-weight: 700; }
.form-shipping .list-checkboxes label:before { content: ''; display: inline-block; vertical-align: middle; width: 20px; height: 20px; border: 1px solid  #d2d2d2; margin-right: 10px; margin-top: -3px; }
.form-shipping .list-checkboxes input[type=checkbox] { display: none; }
.form-shipping .list-checkboxes input[type=checkbox]:checked + label:before { background: #fff url(images/icons/ico-checked-blue.png) no-repeat center center; }
.form-shipping .list-checkboxes-shipping { margin-bottom: 15px; }
.form-shipping .list-checkboxes-secondary { margin-top: 20px; }
.form-shipping .list-checkboxes-secondary label { font-size: 12px; }
.form-shipping .list-checkboxes-secondary label:before { width: 16px; height: 16px; }

.form-shipping .list-radios-shipping label { display: block; color: #000; margin-bottom: 0; line-height: 1.3; }

.form-shipping .btn-checkout:disabled { opacity: 0.7; }

@media(max-width: 767px){
	.form-shipping .form-col { float: none; width: 100%; }
	.form-shipping .form-col ~ .form-col { margin-top: 20px; }

	.form-shipping .form-head small { float: none; display: block; }
	.form-shipping .form-head h3 { float: none; }

	.form-shipping .form-section-address p { display: none; }

	.form-shipping .form-summary { font-size: 16px; }
}

/* ------------------------------------------------------------ *\
	Btn
\* ------------------------------------------------------------ */

/*  Btn Update  */

.btn-update { background: #93ad5c; -webkit-transition: background-color .3s; -o-transition: background-color .3s; transition: background-color .3s; }
.btn-update:hover { background: #758e41; }

/*  Btn Checkout  */

.btn-checkout { background: #93ad5c; border-bottom: 5px solid  #758e41; font-family: 'Montserrat', sans-serif; font-size: 18px; -webkit-transition: none; -o-transition: none; transition: none; }
.btn-checkout:hover { background: #93ad5c url(images/btn-checkout-hover.png) no-repeat center 0; -webkit-background-size: 100%; background-size: 100%; }
.btn-checkout:active { background: #a5c661; border-bottom-width: 2px; margin-top: 3px; }

.btn-checkout-secondary { font-size: 16px; }
.btn-checkout-secondary span { display: block; font-size: 14px; }

/* ------------------------------------------------------------ *\
	Links
\* ------------------------------------------------------------ */

/*  Link Remove  */

.link-remove { margin-top: 20px; display: inline-block; }

/*  Link Return  */

.link-return { float: right; background: #3165b0; display: inline-block; font-size: 13px; color: #fff; padding: 10px 30px; font-family: 'Montserrat', sans-serif; text-transform: uppercase; }
.link-return:hover { text-decoration: none; background: #3165b0 url(images/link-return-hover.png) no-repeat center 0; -webkit-background-size: 100%; background-size: 100%; }

@media(max-width: 1023px){
	.link-return { width: 100%; text-align: center; }
}

/* ------------------------------------------------------------ *\
	Icons
\* ------------------------------------------------------------ */

.ico-paypal,
.ico-delete { display: inline-block; vertical-align: middle; font-size: 0; line-height: 0; text-indent: -4004px; }

.ico-paypal { background: url(images/icons/ico-paypal.png) no-repeat 0 0; width: 94px; height: 24px; }
.ico-delete { background: url(images/icons/ico-delete.png) no-repeat 0 0; width: 12px; height: 12px; }

@media only screen and ( -webkit-min-device-pixel-ratio: 2 ), only screen and ( min-device-pixel-ratio: 2 ), only screen and ( min-resolution: 192dpi ) {
	.ico-paypal { background: url(images/icons/@2x/ico-paypal@2x.png) no-repeat 0 0; -webkit-background-size: 100%; background-size: 100%; }
	.ico-delete { background: url(images/icons/@2x/ico-delete@2x.png) no-repeat 0 0; -webkit-background-size: 100%; background-size: 100%; }
	.form-shipping .select:after { background: url(images/icons/@2x/ico-arrow-down@2x.png) no-repeat 0 0; -webkit-background-size: 100%; background-size: 100%; }
	.section-shopping .section-nav .checked:after { background-image: url(images/icons/@2x/ico-nav-checked@2x.png); -webkit-background-size: 100%; background-size: 100%; }
	.form-shipping .list-checkboxes input[type=checkbox]:checked + label:before { background-image: url(images/icons/@2x/ico-checked-blue@2x.png); -webkit-background-size: 15px 11px; background-size: 15px 11px; }
	.list-radios-shipping input[type=radio]:checked + label:before { background-image: url(images/icons/@2x/ico-check-white@2x.png); -webkit-background-size: 16px 12px; background-size: 16px 12px; }
}

.btn-block {
	border: none;
	width: 100%;
	min-height: 55px;
}
.btn-checkout.btn-faded {
	background: #afc36f;
	border-bottom: 5px solid #8fa350;
}
