* {
	margin: 0;
	padding: 0;
	box-sizing:border-box;
}
html, body {
	height:100%;
	background-color: white;
}
body {
	overflow-y: hidden;
	font-size: 14px;
	font-family: 'Open Sans', sans-serif;
	padding: 7rem 0 3rem;
}
a, span {
	display: inline-block;
}
a {
	cursor: pointer;
}
a, h1, h2, h3, h4, h5, h6 {
	color: #230871;
	font-weight: normal;
}
textarea {
	resize: none !important;
}
hr {
	border-color: #dfe5e6;
	border-style: solid;
	border-width: 1px;
	margin: 1.5rem 0 !important;
}
select {
	background-color: #fff;
}
input:read-only,
select:disabled {
	background-color: #e9e9ed !important;
}
/* CUSTOM CLASS */
.d-none {
	display: none;
}
.mt {
	margin-top: 1rem;
}
/* BUTTON */
.btn {
	border:none;
	cursor: pointer;
	padding:0.5rem;
}
.btn-danger {
	background-color: #dc3545;
	color: #fff;
}
.btn span {
	margin-left:0.5rem;
}
.btn-small {
	padding:0.25rem 0.5rem;
	text-transform: lowercase;
}
.disabled {
	opacity: 0.5;
	pointer-events: none;
}
/* BUTTON BAG */
.btn-bag {
	background-color: #ff8043;
	color: white;
	height:2rem;
	width:2rem;
	padding: 0rem;
	line-height: 2rem;
	text-align: center;
	border-radius: 1rem;
}
.btn-primary,
.btn-liquid {
	border: none;
	background-color: #fe6600;
	color: white;
	text-transform: uppercase;
	text-align: center;
	border-radius: 0.25rem;
}
/* BUTTON LIQUID */
.btn-liquid {
	padding: 1rem;
	width:100%;
}
.btn-liquid:hover,
.btn-liquid:active {
	background-color:#da4f02;
}
/* BUTTON BIG */
.btn-big {
	padding: 2rem;
	text-align: center;
	border-radius: 0.25rem;
}
.btn-big i {
	font-size: 3rem;
}
.btn-big span {
	display: block;
	margin-top:1rem;
	margin-left:0;
}
a.btn-big:hover,
a.btn-big:active {
	background-color: #dfe5e6;
}
.table {
	width: 100%;
	margin: 1rem auto;
	border-collapse: separate;
}
.table th,
.table td {
	padding: 0.5rem;
	border: 1px solid #ccc;
}
.row::after {
	content: "";
	clear: both;
	display: table;
}
.row { margin-left: -1rem; margin-top:1rem; }
.row .col { padding-left:1rem; float: left; }
.col-1 { width:8.3333%; }
.col-2 { width:16.6666%; }
.col-3 { width:25%; }
.col-4 { width:33.3333%; }
.col-5 { width:41.6666%; }
.col-6 { width:50%; }
.col-7 { width:58.3333%; }
.col-8 { width:66.6666%; }
.col-9 { width:75%; }
.col-10 { width:83.3333%; }
.col-11 { width:91.6666%; }
.col-12 { width:100%; }

.form-group {
	text-align: left;
	margin-top: 1rem;
}
.form-group:first-child {
	margin-top: 0;
}
.form-group.small {
	margin-top:0.25rem;
}
.form-group.small .input-group {
	background-color:#dfe5e6;
	border-radius: 0.25rem;
}
.form-group.small input {
	background-color: transparent;
}
.form-group label {
	display: inline-block;
	padding-bottom: 0.5rem;
}
.form-control {
	width:100%;
	padding:0.5rem;
	border-radius: 0.25rem;
	border: 1px solid #dfe5e6;
}
.input-group {
	width:100%;
	display: flex;
	align-items: stretch;
	justify-content: space-around;
	border:1px solid #dfe5e6;
	border-radius: 0.25rem;
}
.input-group-prepend,
.input-group-append {
	padding:1px;
	display: flex;
	align-items: center;
	flex-shrink: 0;
}
.input-group-input {
	flex-grow: 1;
	flex-shrink: 1;
}
.input-group-input input,
.input-group-input select,
.input-group-input textarea {
	border: none;
}

/* TEXT ALIGN AND COLOR */
.text-left {
	text-align: left;
}
.text-center {
	text-align: center;
}
.text-justify {
	text-align: justify !important;
}
.text-right {
	text-align: right;
}
.text-primary {
	color: #007bff;
}
.text-secondary {
	color: #6c757d;
}
.text-success {
	color: #28a745;
}
.text-danger {
	color: #dc3545;
}
.text-warning {
	color: #ffc107;
}
.text-info {
	color: #17a2b8;
}
.font-weight-bold {
	font-weight: bold;
}
/**/
.w-50 {
	width: 50% !important;
}
.alert {
	padding: 1rem;
	background-color: #dfe5e6;
	border-radius: 0.25rem;
	margin: 1rem 0;
}
.alert-warning {
	padding: 1rem;
	border: 1px solid #fe6600;
	background-color: #F0B27A;
	border-radius: 0.25rem;
	margin: 1rem 0;
}
/* DESIGN */
header {
	position: fixed;
	width:100%;
	top:0;
	height:7rem;
	box-shadow: 0px 1px 32px rgba(0,0,0,0.256);
}
#empresaMenu,
#usuarioMenu,
#titulo,
#subtitulo,
.titulo,
.subtitulo,
div.modeloItem,
div.modeloImagen,
div.modeloFoto,
div.input-group-input {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
div.buttons {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 1rem;
}
#titulo,
.titulo {
	margin-bottom:1rem;
	font-size: 1rem;
}
#titulo .precio {
	font-size:1.5rem;
}
#subtitulo,
.subtitulo {
	margin-bottom:1rem;
	font-size:0.8rem;	
}
#empresaMenu {
	height: 4rem;
	padding: 0 1rem;
	background-color: white;
}
#usuarioMenu {
	padding: 0 1rem;
	height: 3rem;
	background-color:#fb6500;
	color: white;
}
#usuarioMenu a {
	color: white;
}
footer {
	padding: 1rem;
	height: 3rem;
	width:100%;
	text-align: center;
	background-color: #fe6600;
	color: white;
	position: fixed;
	bottom:0;
}
#sectionLogin,
#appMenu,
#appModulos,
#sectionContent {
	width:100%;
	position: fixed;
	top: 7rem;
	bottom: 3rem;
	overflow-y: scroll;
}
#sectionLogin {
	display: flex;
	justify-content: center;
	align-items: center;
}
#sectionLogin form {
	max-width: 240px;
	text-align: center;
}
#verPassword {
	position: relative;
}
#verPassword a {
	position: absolute;
	top:0;
	right:0;
	padding: 0.5rem;
}
#verPassword input[type="text"],
#verPassword input[type="password"] {
	padding-right: 2rem;
}
#empresaLogo {
	max-width: 192px;
	max-height: 64px;
	width: auto;
	height: auto;
}
#alerta {
	padding: 1rem;
	background-color: #dfe5e6;
	border-radius: 0.25rem;
	margin: 1rem 0;
}
#recuperar {
	margin-top: 2rem;
}
#empresa {
	background-image: url(empresa-logo.png);
	background-repeat: no-repeat;
	width:102px;
	height:32px;
	margin:14px 0;
}
#empresa span {
	display: none;
}
#appMenu {
	padding:1rem;
	text-align: center;
}
#appMenu .opciones {
	margin-top:1rem;
}
#appMenu a.btn-big {
	width:140px;
	font-size: 0.75rem;
}
#appName {
	text-decoration: none;
}
#appModulos {
	text-align: center;
}
#appModulos .opciones {
	padding:1rem;
}
#appModulos a {
	display: flex;
	align-items: center;
	width:100%;
	text-decoration: none;
	border-top: 1px solid #dfe5e6;
}
#appModulos a:first-child {
	border-top: none;
}
#appModulos span {
	margin-top: 0;
}
#appModulos i {
	width:6rem;
	text-align: center;
}
#sectionContent .content:first-child {
	padding: 1rem 1rem 6rem;
}

/* GRID - DATATABLES */
table {
	width:100%;
}
table th,
table td {
	text-align: left;
}
table th.opciones,
table td.opciones {
	width: 1rem;
}
table tbody td {
	border-top:1px solid #ccc;
	padding: 0.5rem 0.5rem 0.5rem 0;
}
table td.opciones {
	font-size: 1rem;
}
table th.identificador,
table td.identificador {
	text-align: right;
	padding:0 1rem;
}
table td.identificador {
	width:5rem;
}
table tbody tr:hover {
	/*background-color: rgba(251, 101, 0, 0.1); */
}

/* PAGINACIÓN */
.paginacion {
	display: flex;
	align-items: center;
	justify-content: right;
	border-top:1px solid #dfe5e6;
	padding-top:0.5rem;
	margin-top:0.5rem;
}
.paginacion .form-control {
	width:5rem;
	margin:0 1rem;
	text-align: center;
}
#paginas {
	margin:0 1rem;
	font-weight: bold;
}

/* MODELOS LISTA */
div.modelosLista {
	margin-top: 1rem;
}
div.modeloItem {
	padding:0.5rem;
	transition: background-color 0.256s;
}
div.modeloItem:hover {
	background-color: #dfe5e6;
}
div.modeloImagen {
	flex-basis: 7rem;
	flex-grow: 0;
	text-align: center;
	justify-content: center;
}
div.modeloFoto {
	position: relative;
	width: 6rem;
	height: 8rem;
}
div.modeloFoto img {
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 100%;
	display: block;
}
a.modeloVer,
a.modeloEliminar {
	position: absolute;
	bottom:0.5rem;
}
a.modeloVer{
	right:0.5rem;
}
a.modeloEliminar{
	left:0.5rem;
}
div.modeloDescripcion{
	flex-grow: 1;
	margin-left: 1rem;
}
h2.modeloProducto {
	font-size: 1rem;
	font-weight: bold;
	color: #230871;
}
h3.modeloNombre{
	font-size: 1rem;
	font-weight: normal;
}
p.modeloMedidas{}
p.modeloPrecio{
	font-size: 1.25rem;
	font-weight: bold;
}
span.modeloUnidad{
	font-size: 0.75em;
	font-weight: normal
}
span.pesos{}
sup.centavos{}

.sucursal,
.domicilio {
	padding: 1rem;
}
.sucursal label,
.domicilio label {
	padding-left: 0.5rem;
}
.sucursal address,
.domicilio address {
	margin-top: 0.5rem;
}
.sucursal:hover,
.domicilio:hover {
	background-color: #dfe5e6;
}
.tipoDeEnvio {
	display: none;
}
#pedidoEnvio {
	display: none;
	margin-top: 1rem;
}
#pedidoPaqueterias {
	display: none;
	margin-top: 1rem;
}
#pedidoDatos {
	display: none;
	margin-top: 1rem;
}
#pedidoRetroceder,
#pedidoAvanzar,
.superButton {
	position: fixed;
	bottom:4rem;
	border-radius:2rem;
	background-color: #230871;
	transition: background-color 0.256s;
}
#pedidoRetroceder:hover,
#pedidoAvanzar:hover,
.superButton:hover {
	background-color:#665ec7;
}
#pedidoRetroceder i,
#pedidoAvanzar i,
.superButton i {
	width:4rem;
	height:4rem;
	text-align: center;
	line-height: 2rem;
	font-size:2rem;
	padding:1rem;
	color: white;
}
#pedidoRetroceder {
	left:1rem;
	display: none;
}
#pedidoAvanzar,
.superButton {
	right:1rem;
}
#domiciliosLista {
	background-color: #eeeeee;
	padding:0.5rem;
}
.paqueteria-box {
	background-color: #eeeeee;
	padding: 1rem;
	margin-top: 1rem;
}
.paqueteria-box:first-child {
	margin-top: 0;
}
.paqueteria-box p {
	margin-top: 1rem;
}
#pedidoPago {
	display: none;
}
#pedidoPago .metodos,
#metodosDePago {
	display: flex;
	justify-content: space-between;
	text-align: center;
	flex-wrap: wrap;
	margin-top: 1rem;
}
#pedidoPago .metodos a.btn-pago {
	width: 140px;
	font-size: 0.75rem;
}
#pedidoPago .btn-liquid {
	margin-bottom: 1rem;
}
#metodosDePago .btn-pago {
	width:140px;
}
/* OXXOPAY */
#oxxopay {
	box-sizing: border-box;
	margin: 40px auto;
	overflow: hidden;
	font-family: 'Open Sans', sans-serif;
	color: #4f5365;
}
#oxxopay h3 {
	margin-bottom: 10px;
	font-size: 15px;
	font-weight: 600;
	text-transform: uppercase;
}
#oxxopay-header {
	border-radius: 4px;
	border-bottom-right-radius: 0;
	border-bottom-left-radius: 0;
	border: 1px solid #b0afb5;
	border-bottom: none;
	padding: 0 45px 45px;
}
#oxxopay-reminder {
	position: relative;
	top: -1px;
	padding: 9px 0 10px;
	font-size: 11px;
	text-transform: uppercase;
	text-align: center;
	color: #ffffff;
	background: #000000;
}

#oxxopay-info {
	margin-top: 26px;
}

#oxxopay-brand img {
	max-width: 150px;
	margin-top: 2px;
}

#oxxopay-ammount h2 {
	font-size: 36px;
	color: #000000;
	line-height: 24px;
	margin-bottom: 15px;
}

#oxxopay-ammount h2 sup {
	font-size: 16px;
	position: relative;
	top: -2px
}

#oxxopay-ammount p {
	font-size: 10px;
	line-height: 14px;
}

#oxxopay-reference {
	margin-top: 14px;
}

#oxxopay-reference p {
	font-size: 1rem;
	color: #000000;
	text-align: center;
	margin-top: -1px;
	padding: 6px 0 7px;
	border: 1px solid #b0afb5;
	border-radius: 4px;
	background: #f8f9fa;
}

#oxxopay-body {
	border: 1px solid #b0afb5;
	border-bottom: none;
	padding: 32px 45px 45px;
	background: #f8f9fa;
}

#oxxopay ol {
	margin: 17px 0 0 16px;
}

#oxxopay li + li {
	margin-top: 10px;
	color: #000000;
}

#oxxopay a {
	color: #1155cc;
}

#oxxopay-footer {
	padding: 22px 20px 24px;
	color: #108f30;
	text-align: center;
	border-radius: 4px;
	border-top-left-radius: 0;
	border-top-right-radius: 0;
	border: 1px solid #108f30;
	background: #ffffff;
}
#ordenResumen .concepto {
	text-align: right;
	padding-right: 1rem;
}
#ordenResumen .cantidad {
	width: 150px;
}

/* PARA EL TRANSPORTE */
div.transporte-imagen {
	position: relative;
}
div.transporte-imagen a.btn.eliminar,
div.transporte-imagen a.btn.ver {
	position: absolute;
	display: inline-block;
	bottom:10px;
	right:10px;
}
div.transporte-imagen a.btn.eliminar {
	right: 60px;
}
div.transporte-imagen img {
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
}

/*Badges*/
.badge {
	background-color: #fb6500;
	display: inline-block;
	padding: .35em .65em;
	font-size: .75em;
	font-weight: 700;
	line-height: 1;
	color: #fff;
	text-align: center;
	white-space: nowrap;
	vertical-align: baseline;
	border-radius: .25rem
}
.badge i,
.badge span,
.badge a {
	color: #fff;
}

/* UL TYPES */
ul.simple {
	list-style-type: none;
}

/* BREADCRUMBS */
ul.breadcrumb {
	display: flex;
    flex-wrap: wrap;
    list-style: none;
	padding-right: 0.5rem;
    color: #230871;
    font-size: 12px;
}
ul.breadcrumb li:not(:last-child) a {
	font-weight: bold;
}
ul.breadcrumb li:not(:last-child)::after {
    display: inline-block;
    margin: 0 .25rem;
    content: "\\";
}