
/* ======================= Improved One Page Checkout with tabs  ======================== */
.block-progress .block-title { background:none; margin:0 0 34px; padding:0; }
.checkout-onepage-index .page-title { }

.opc { position:relative; overflow:hidden; height:970px; padding-top:20px; text-align:center; background:#fff; color: #444;}
.opc .buttons-set { margin:15px 0 0; opacity:1!important; }
.opc .buttons-set p.required { margin:0; padding:0 0 10px; }
.opc .buttons-set .back-link { display:none; }
.opc .buttons-set .please-wait { position:absolute; z-index:99; top:30%; left:50%; margin:-80px 0 0 -146px; border:5px solid #f3b66f; font-size:12px; background:#fff; padding:30px; white-space:nowrap; border:1px solid #c0c0c0; -moz-border-radius:6px; -webkit-border-radius:6px; border-radius:6px; -moz-box-shadow:1px 1px 2px rgba(0,0,0,0.2); -webkit-box-shadow:0 0 50px rgba(0,0,0,0.2); box-shadow:0 0 50px rgba(0,0,0,0.2); }
.opc .buttons-set a { color:#214D90; }
.opc .ul { list-style:disc outside; padding-left:18px; }
.opc li.section { display:inline; }
.opc .form-list .field,.opc .form-list .wide { }
.opc .form-list li fieldset { }
.opc .form-list label { float:left; width:220px; text-align:right; padding:4px 0 0; }
.opc .form-list label.required em { float:none; position:relative; right:4px; }
.opc .form-list li.fields { margin:0; }
.opc .form-list div.fields { width:100%; overflow:hidden; margin:0 0 8px; }
.opc .form-list .wide,.opc .form-list li.fields .field { width:645px; margin:0 0 8px; }
.opc .form-list li.wide .input-box,.opc .form-list .input-box { clear:none; float:right; margin-right:140px; width:260px; }
.opc .form-list li.wide select { width:390px; }
.opc .form-list li.wide input.input-text { width:254px; }
.opc .form-list .control input { margin:8px 0 0 25px; }
.opc .form-list li.control label { float:left; }
.opc form .form-list li.wide { margin-bottom:8px; }
.opc form .address-select { margin:8px 0 0; }
.opc p.required { padding: 0 15px; }
	
.opc:first-of-type .step{-webkit-transition: all 0.5s ease-in-out;-moz-transition: all 0.5s ease-in-out;-o-transition: all 0.5s ease-in-out;-webkit-transition: all 0.5s ease-in-out;transition: all 0.5s ease-in-out;}
.opc:first-of-type .step[style*='display:none;'],
.opc:first-of-type .step[style*='display: none;']{display:block !important;}
.opc:first-of-type .section .step{left: 100%;}
.opc:first-of-type .allow .step{left: -100%;}
.opc:first-of-type .active .step{left:0;}
.opc:first-of-type li:last-child .step-title a{width:50%}
.opc:first-of-type li:first-child .step-title a{width:50%;left:50%}

#opc-login p.required { display:none; }
#opc-login .col-2 { float:left; }
#opc-login .col-2 form fieldset h4 { display:none; }
#opc-login .col-2 { display:block; width:300px; }
#opc-login .col-2 fieldset { width:300px; }
#opc-login .col-2 .input-box { width:188px; margin:0; float:left; }
#opc-login .col-2 .input-text { width:182px; }
#opc-login .col-2 .form-list label { text-align:left; }
#opc-login .col-2 .form-list label { width:110px; }
#opc-login .form-list li.control label { float:none; }
#opc-login .form-list li.control input { margin:0 8px 0 0; }
#opc-login .col-1 { float:right; }
#opc-login .col-1 { width:290px; }
#checkout-step-review.step {  }

#opc-review .step {border-top:1px solid #BBAFA0; }
#opc-review .product-name { font-weight:bold; color:#0a263c; }
#opc-review .item-options { margin:5px 0 0; }
#opc-review .buttons-set { padding:20px 0; border:0; }
#opc-review .buttons-set p { margin:0; line-height:40px; }
#opc-review .buttons-set .please-wait { height:40px; line-height:40px; }
#opc-shipping_method .buttons-set { border-top:1px solid #E4E4E4; }
/* ================================= Solution by www.h-o.nl =============================== */






/* ==================== Improved One Page Checkout with progressbar  ===================== */
.block-progress .block-title { background:none; margin:0 0 10px; padding:0; }
.opc-container { border: 1px solid #c9c9c9; }

.opc { position:relative; overflow:hidden; height:970px; padding-top:20px; text-align:left; margin-top:45px;}
.opc .buttons-set { margin:15px 0 0; opacity:1!important; }
.opc .buttons-set p.required { margin:0; padding:0 0 10px; }
.opc .buttons-set .back-link { display:none; }
.opc .buttons-set .please-wait { position:absolute; z-index:99; top:30%; left:50%; margin:-80px 0 0 -146px; border:5px solid #f3b66f; font-size:12px; background:#fff; padding:30px; white-space:nowrap; border:1px solid #c0c0c0; -moz-border-radius:6px; -webkit-border-radius:6px; border-radius:6px; -moz-box-shadow:1px 1px 2px rgba(0,0,0,0.2); -webkit-box-shadow:0 0 50px rgba(0,0,0,0.2); box-shadow:0 0 50px rgba(0,0,0,0.2); }
.opc .buttons-set a { color:#214D90; }
.opc .ul { list-style:disc outside; padding-left:18px; }
.opc li.section { display:inline; }
.opc .step-title,.opc .allow .step-title { border-color:#FBFAF6; }
.opc .step { position:absolute; border:0; top:55px; left:0; z-index:1; background:#fff; height:900px; border-bottom:1px dotted #ccc; border:none; background:none; text-align:left; background:#fff; border-top:1px solid #BBAFA0; }
.opc .step-title a { display:none; }
.opc .step-title h2 { font-size:14px; color:#444; line-height: 28px; }
.opc .allow .step-title h2 { color:#fff; }
.opc .active .step-title h2 { color:#fff; }
.opc .step-title .number { border: 0; background: none; color: #444; line-height: 28px; font-size: 14px;}
.opc .allow .step-title .number,
.opc .active .step-title .number { background: none; color: #fff;} 
.opc .step-title,.opc .allow .step-title,.opc .active .step-title { position:relative; text-align:center; border:none; background:none; overflow:hidden!important; display:inline-block; vertical-align:top; }
.opc .allow .step-title,
.opc .active .step-title { background: url(../images/opc_step_active.png) no-repeat top right; color: #fff;}
.opc .step-title,.opc .allow .step-title { color: #444; } 
.opc .step-title h2,.opc .allow .step-title h2,.opc .active .step-title h2 { text-align:center; display: inline;}
.opc .step-title { height: 28px; padding: 0 20px 0 15px; margin-right: -15px; background: url(../images/opc_step.png) no-repeat top right;  position: relative;}
#opc-login .step-title { z-index: 5; }
#opc-billing .step-title { z-index: 4; }
#opc-shipping .step-title { z-index: 3; }
#opc-shipping_method .step-title { z-index: 2; }
#opc-payment .step-title { z-index: 1; }
#opc-review .step-title { z-index: 0; }
.opc .form-list .field,.opc .form-list .wide { }
.opc .form-list li fieldset { padding: 10px 15px; }
.opc .form-list label { float:left; width:25%; text-align:right; padding:4px 0 0; }
.opc .form-list label.required em { float:none; position:relative; right:4px; }
.opc .form-list li.fields { margin:0; }
.opc .form-list div.fields { width:100%; overflow:hidden; margin:0 0 8px; }
.opc .form-list .wide,.opc .form-list li.fields .field { width:100%; margin:0 0 8px; }
.opc .form-list li.wide .input-box,.opc .form-list .input-box { clear:none; float:right; width:73%; margin-right: 0; }
.opc .form-list li.wide .input-box input.input-text, .opc .form-list .input-box input.input-text {  width: 85%;  } 
.opc .form-list li.wide .input-box select, .opc .form-list .input-box select {  width: 86%;  } 
.opc .form-list li.wide select { width:390px; }
.opc .form-list li.wide input.input-text { width:254px; }
.opc .form-list li.control { padding-left: 20%; }
.opc .form-list .control input { margin:3px 5px 0 0; float: left; }
.opc .form-list .control label { float:left; width: 50%; text-align: left; padding-top: 0; }
.opc table.control td.col1 label { width: 100%; text-align: right;} 
.opc table.control { width: 100%; }
.opc table.control .col1{ width: 26.3%; font-weight: bold; text-align: right; color: #666666; }
.opc table.control .col2 { padding: 2px 1.5%; }
.opc table.control td { padding: 2px 5px; }
.opc form .form-list li.wide { margin-bottom:8px; }
.opc form .address-select { margin:8px 0 0; }
.opc .bottom-actions { border-bottom: 1px solid #DCDCDC; height: 22px;}
.opc .bottom-actions .continue { position: absolute; right: 15px; }
.opc .bottom-actions .please-wait { position:absolute; right: 130px; }
.opc .wrapper { padding: 10px 15px; }

.opc:first-of-type .step{-webkit-transition: all 0.5s ease-in-out;-moz-transition: all 0.5s ease-in-out;-o-transition: all 0.5s ease-in-out;-webkit-transition: all 0.5s ease-in-out;transition: all 0.5s ease-in-out;}
.opc:first-of-type .step[style*='display:none;'],
.opc:first-of-type .step[style*='display: none;']{display:block !important;}
.opc:first-of-type .section .step{left: 100%;}
.opc:first-of-type .allow .step{left: -100%;}
.opc:first-of-type .active .step{left:0;}
.opc:first-of-type li:last-child .step-title a{width:50%}
.opc:first-of-type li:first-child .step-title a{width:50%;left:50%}

.opc:first-of-type .allow .step-title a {}

#opc-login p.required { display:none; }
#opc-login .col-2 { float:left; }
#opc-login .col-2 form fieldset h4 { display:none; }
#opc-login .col-2 { display:block; width:300px; }
#opc-login .col-2 fieldset { width:300px; }
#opc-login .col-2 .input-box { width:188px; margin:0; float:left; }
#opc-login .col-2 .input-text { width:182px; }
#opc-login .col-2 .form-list label { text-align:left; }
#opc-login .col-2 .form-list label { width:110px; }
#opc-login .form-list li.control label { float:none; }
#opc-login .form-list li.control input { margin:0 8px 0 0; }
#opc-login .col-1 { float:right; }
#opc-login .col-1 { width:290px; }
#checkout-step-review.step { width:100%; }

#opc-review .step { border-top:1px solid #BBAFA0; }
#opc-review .product-name { font-weight:bold; color:#0a263c; }
#opc-review .item-options { margin:5px 0 0; }
#opc-review .buttons-set { padding:20px 0; border:0; }
#opc-review .buttons-set p { margin:0; line-height:40px; }
#opc-review .buttons-set .please-wait { height:40px; line-height:40px; }
#opc-shipping_method .buttons-set { border-top:1px solid #E4E4E4; }
/* ================================= Solution by www.h-o.nl =============================== */
