:root{
	--psk-blue: #005696;
	--psk-blue-dark: #003d6b;
	--psk-blue-light: #0070b8;
	--psk-green: #8CC63F;
	--psk-green-dark: #6fa82e;
	--psk-gray: #707070;
	--psk-gray-light: #e8ecf0;
	--psk-bg: #f0f4f8;
	--psk-white: #ffffff;
	--psk-radius: 10px;
	--psk-shadow: 0 2px 12px rgba(0, 86, 150, 0.08);
	--psk-shadow-lg: 0 20px 60px rgba(0, 86, 150, 0.18);
}

*{
	padding:0px;
	margin:0px;
}

html,
body{
	height:100%;
	padding:0px;
	margin:0px;
	font-size: 13px;
	font-family: 'Segoe UI', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
	color: #333;
}

.consecutivo {
  font-size: 20px;
  color: var(--psk-blue-dark);
  background-color: rgba(0, 86, 150, 0.08);
  border-radius: var(--psk-radius);
  padding: 4px 10px;
}


[data-toggle="money"]{
	text-align:right;
}

[data-toggle="datepicker"]{
	cursor: pointer;
}

.psk-datepicker,
input[data-toggle="datepicker"]{
	background-color: var(--psk-white) !important;
	opacity: 1;
}

.bg-dark{
	background: linear-gradient(135deg, var(--psk-blue-dark) 0%, var(--psk-blue) 100%) !important;
}

.bg-success{
	background-color: rgba(140, 198, 63, 0.15) !important;
}

.btn{
	border-radius: 8px;
	font-weight: 500;
	transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
}

.btn:active{
	transform: scale(0.98);
}

.btn-xs{
	font-size:13px;
	padding:2px 10px;
}

.btn-primary,
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active{
	color:#FFF;
	cursor:pointer;
	background-color:var(--psk-blue);
	border-color:var(--psk-blue);
}

.btn-primary:hover,
.btn-primary:focus{
	background-color:var(--psk-blue-dark);
	border-color:var(--psk-blue-dark);
	box-shadow: 0 4px 12px rgba(0, 86, 150, 0.25);
}

.btn-success,
.btn-success:hover,
.btn-success:focus,
.btn-success:active{
	color:#FFF;
	cursor:pointer;
	background-color:var(--psk-green);
	border-color:var(--psk-green);
}

.btn-success:hover,
.btn-success:focus{
	background-color:var(--psk-green-dark);
	border-color:var(--psk-green-dark);
	box-shadow: 0 4px 12px rgba(140, 198, 63, 0.35);
}

.btn-danger{
	color:#FFF;
	cursor:pointer;
	background-color:#D9534F;
	border-color:#D9534F;
}

.btn-danger:hover{
	background-color:#c9302c;
	border-color:#c9302c;
}

.btn-warning{
	color:var(--psk-green-dark);
	cursor:pointer;
	background-color:#fff;
	border-color:var(--psk-green);
}

.btn-warning:hover{
	color:#fff;
	background-color:var(--psk-green);
	border-color:var(--psk-green);
}

.btn-info,
.btn-info:hover,
.btn-info:focus,
.btn-info:active{
	color:#fff;
	background-color:var(--psk-blue-light);
	border-color:var(--psk-blue-light);
}

.btn-info:hover{
	background-color:var(--psk-blue);
	border-color:var(--psk-blue);
}

.btn-secondary,
.btn-outline-secondary{
	color:var(--psk-gray);
	background-color:#fff;
	border-color:var(--psk-gray-light);
}

.btn-secondary:hover,
.btn-outline-secondary:hover{
	color:var(--psk-blue);
	background-color:rgba(0, 86, 150, 0.06);
	border-color:var(--psk-blue);
}

.btn-white{
	color:var(--psk-blue);
	background-color:rgba(255, 255, 255, 0.15);
	border:1px solid rgba(255, 255, 255, 0.4);
}

.btn-white:hover{
	color:#fff;
	background-color:rgba(255, 255, 255, 0.25);
	border-color:rgba(255, 255, 255, 0.6);
}

.grilla{
	margin-top:10px;
	min-height: 200px;
	background: var(--psk-white);
	border-radius: 12px;
	border: 1px solid var(--psk-gray-light);
	box-shadow: var(--psk-shadow);
	overflow: auto;
}

.grilla .table{
	margin-bottom: 0;
}

.modal{
	overflow-y:scroll;
}

.modal-content{
	border: none;
	border-radius: 14px;
	overflow: hidden;
	box-shadow: var(--psk-shadow-lg);
}

.modal-header{
	padding: 14px 20px;
	background: linear-gradient(135deg, var(--psk-blue-dark) 0%, var(--psk-blue) 100%);
	color: #FFF;
	border-bottom: none;
}

.modal-header .close{
	color: #fff;
	opacity: 0.85;
	text-shadow: none;
}

.modal-header .close:hover{
	opacity: 1;
}

.modal-title{
	font-size: 1.05rem;
	font-weight: 600;
	letter-spacing: 0.02em;
}

.modal-footer{
	background: #f8fafc;
	border-top: 1px solid var(--psk-gray-light);
	padding: 12px 20px;
}

label{
	margin: 0px;
	padding: 0px;
	display: inline-block;
}

select{
	color:#000;
}

textarea{
	resize:none;
}

.contenedor{
	max-width: 600px;
	margin:auto;
}

#contenedor{
	min-height:100%;
	margin-bottom: -80px;
}

#contenedor:after{
	content:'';
	display: block;
	height:80px;
}

footer{
	height:80px;
}

.form-control,
select,
select.form-control{
	border: 1.5px solid var(--psk-gray-light);
	border-radius: var(--psk-radius);
	padding: 9px 14px;
	height: auto;
	min-height: 40px;
	font-family: inherit;
	font-size: 0.875rem;
	font-weight: 500;
	color: #333;
	line-height: 1.35;
	background-color: var(--psk-white);
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.form-control:focus,
select:focus,
select.form-control:focus{
	border-color: var(--psk-blue);
	box-shadow: 0 0 0 3px rgba(0, 86, 150, 0.12);
	outline: none;
}

select,
select.form-control{
	display: block;
	width: 100%;
	max-width: 100%;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23005696' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 14px;
	padding: 9px 38px 9px 14px;
	cursor: pointer;
	box-shadow: 0 1px 2px rgba(0, 86, 150, 0.04);
}

select:hover,
select.form-control:hover{
	border-color: var(--psk-blue);
	background-color: #fafcfe;
}

select:disabled,
select.form-control:disabled{
	background-color: #f1f5f9;
	color: #94a3b8;
	cursor: not-allowed;
	opacity: 1;
}

select option{
	font-weight: 400;
	color: #333;
}

/* ── Input groups modernos ── */
.psk-input-group,
.input-group.psk-input-group{
	display: flex;
	align-items: stretch;
	width: 100%;
	border: 1.5px solid var(--psk-gray-light);
	border-radius: var(--psk-radius);
	background: var(--psk-white);
	overflow: hidden;
	box-shadow: 0 1px 3px rgba(0, 86, 150, 0.05);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.psk-input-group:focus-within{
	border-color: var(--psk-blue);
	box-shadow: 0 0 0 3px rgba(0, 86, 150, 0.1);
}

.psk-input-group .form-control,
.psk-input-group select.form-control{
	flex: 1 1 auto;
	min-width: 0;
	width: 1%;
	border: none !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	min-height: 40px;
	padding: 9px 14px;
	background: transparent;
}

.psk-input-group .form-control:focus,
.psk-input-group select.form-control:focus{
	box-shadow: none !important;
}

.psk-input-group .input-group-prepend,
.psk-input-group .input-group-append,
.psk-input-group .input-group-addon{
	display: flex;
	margin: 0;
}

.psk-input-group .input-group-text{
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 40px;
	padding: 0 14px;
	border: none;
	border-radius: 0;
	background: #f1f5f9;
	color: var(--psk-blue);
	font-size: 0.9rem;
}

.psk-input-group .psk-ig-prefix + .form-control,
.psk-input-group .psk-ig-prefix + select.form-control{
	border-left: 1.5px solid var(--psk-gray-light) !important;
}

.psk-input-group .input-group-append .btn,
.psk-input-group .input-group-prepend .btn,
.psk-input-group .input-group-addon .btn{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	min-height: 40px;
	padding: 0 14px;
	margin: 0;
	border: none !important;
	border-radius: 0 !important;
	line-height: 1;
	box-shadow: none !important;
}

.psk-input-group .input-group-append.psk-ig-search,
.psk-input-group .input-group-append.psk-ig-action{
	border-left: 1.5px solid var(--psk-gray-light);
}

.psk-input-group .psk-ig-search .btn,
.psk-input-group .psk-ig-search .btn.btn-primary{
	background: var(--psk-blue) !important;
	color: #fff !important;
}

.psk-input-group .psk-ig-search .btn:hover,
.psk-input-group .psk-ig-search .btn.btn-primary:hover{
	background: var(--psk-blue-dark) !important;
}

.psk-input-group .psk-ig-add .btn,
.psk-input-group .psk-ig-add .btn.btn-warning,
.psk-input-group .psk-ig-action.psk-ig-add .btn,
.psk-input-group .psk-ig-action .btn.btn-success{
	background: var(--psk-green) !important;
	color: #fff !important;
	border-color: var(--psk-green) !important;
}

.psk-input-group .psk-ig-add .btn:hover,
.psk-input-group .psk-ig-add .btn.btn-warning:hover,
.psk-input-group .psk-ig-action.psk-ig-add .btn:hover,
.psk-input-group .psk-ig-action .btn.btn-success:hover{
	background: var(--psk-green-dark) !important;
	border-color: var(--psk-green-dark) !important;
	color: #fff !important;
}

.psk-input-group .psk-ig-action:not(.psk-ig-add) .btn.btn-warning{
	background: #f59e0b !important;
	color: #fff !important;
	border-color: #f59e0b !important;
}

.psk-input-group .psk-ig-action:not(.psk-ig-add) .btn.btn-warning:hover{
	background: #d97706 !important;
	border-color: #d97706 !important;
}

.psk-input-group .psk-ig-action .btn.btn-danger{
	background: #fff !important;
	color: #c9302c !important;
}

.psk-input-group .psk-ig-action .btn.btn-danger:hover{
	background: rgba(217, 83, 79, 0.08) !important;
}

.psk-input-group .input-group-append.psk-ig-saldo{
	border-left: 1.5px solid var(--psk-gray-light);
	flex: 0 0 auto;
}

.psk-input-group .psk-ig-saldo{
	display: flex;
	align-items: stretch;
	background: linear-gradient(135deg, rgba(0, 86, 150, 0.05) 0%, rgba(140, 198, 63, 0.12) 100%);
}

.psk-input-group .psk-ig-saldo-label{
	display: flex;
	align-items: center;
	padding: 0 10px;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--psk-blue);
	white-space: nowrap;
	border-right: 1px solid var(--psk-gray-light);
	background: rgba(255, 255, 255, 0.55);
}

.psk-input-group .psk-ig-saldo-input,
.psk-input-group .psk-ig-saldo .form-control{
	width: 112px !important;
	min-width: 112px !important;
	max-width: 112px;
	flex: 0 0 112px !important;
	border: none !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	background: transparent !important;
	font-weight: 700;
	font-size: 0.95rem;
	color: var(--psk-blue-dark);
	text-align: right;
	padding: 9px 10px;
}

.form-s{
	width:100%;
	max-width:400px;
}

.form-m{
	width:100%;
	max-width:600px;
}

.form-l{
	width:100%;
	max-width:800px;
}

.form-xl{
	width:100%;
	max-width:980px;
}

.modal-body{
	padding:15px 25px;
}

.titulos-form{
	padding: 14px 20px;
	border-bottom: none;
	background: linear-gradient(135deg, var(--psk-blue-dark) 0%, var(--psk-blue) 100%);
	color: #fff;
}

.contenido-form{
	padding:5px 10px;	
}

.footer-form{
	margin-top: 0;
	padding: 12px 20px;
	border-top: 1px solid var(--psk-gray-light);
	background: #f8fafc;
}

/* Dropdowns modernos */
.dropdown > .btn[data-toggle="dropdown"],
.dropdown > button[data-toggle="dropdown"]{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 6px 14px;
	border: 1.5px solid var(--psk-gray-light) !important;
	border-radius: 8px !important;
	background: var(--psk-white) !important;
	color: var(--psk-blue) !important;
	font-weight: 500;
	font-size: 0.82rem;
	box-shadow: var(--psk-shadow);
	transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.dropdown > .btn[data-toggle="dropdown"]:hover,
.dropdown > button[data-toggle="dropdown"]:hover,
.dropdown.show > .btn[data-toggle="dropdown"],
.dropdown.show > button[data-toggle="dropdown"]{
	border-color: var(--psk-blue) !important;
	background: rgba(0, 86, 150, 0.06) !important;
	color: var(--psk-blue-dark) !important;
	box-shadow: 0 4px 14px rgba(0, 86, 150, 0.14);
}

.dropdown .caret{
	display: none;
}

.dropdown > .btn[data-toggle="dropdown"]::after,
.dropdown > button[data-toggle="dropdown"]::after{
	content: '';
	display: inline-block;
	width: 0;
	height: 0;
	margin-left: 2px;
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	border-top: 5px solid currentColor;
	vertical-align: middle;
	transition: transform 0.2s ease;
}

.dropdown.show > .btn[data-toggle="dropdown"]::after,
.dropdown.show > button[data-toggle="dropdown"]::after{
	transform: rotate(180deg);
}

.grilla .dropdown,
.table .dropdown,
#resultado_grilla .dropdown,
#resultado_busqueda .dropdown{
	position: relative;
}

.dropdown-menu{
	margin: 0;
	padding: 8px;
	border: 1px solid var(--psk-gray-light);
	border-radius: 14px;
	background: var(--psk-white);
	box-shadow: 0 16px 48px rgba(0, 86, 150, 0.18);
	min-width: 200px;
	list-style: none;
}

.dropdown-menu.psk-dropdown-floating{
	position: fixed !important;
	margin: 0 !important;
	transform: none !important;
	animation: psk-dropdown-in 0.18s ease;
}

@keyframes psk-dropdown-in{
	from{
		opacity: 0;
		transform: translateY(-6px);
	}
	to{
		opacity: 1;
		transform: translateY(0);
	}
}

.dropdown-menu.psk-dropdown-floating{
	animation-name: psk-dropdown-in-fixed;
}

@keyframes psk-dropdown-in-fixed{
	from{ opacity: 0; }
	to{ opacity: 1; }
}

.dropdown ul.dropdown-menu,
.dropdown > .dropdown-menu{
	padding: 8px;
}

.dropdown-menu > li,
.dropdown-menu .dropdown-item{
	list-style: none;
	margin: 0;
	padding: 0;
}

.dropdown li,
.dropdown-menu .dropdown-item,
.dropdown-menu > li.psk-dropdown-item{
	display: flex;
	align-items: center;
	gap: 12px;
	cursor: pointer;
	padding: 10px 12px;
	margin: 3px 0;
	border: none;
	border-radius: 10px;
	font-size: 0.86rem;
	font-weight: 500;
	color: #3d4f5f;
	line-height: 1.35;
	transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
	white-space: nowrap;
}

.dropdown li i,
.dropdown-menu .dropdown-item i,
.dropdown-menu > li.psk-dropdown-item i{
	width: 32px;
	height: 32px;
	min-width: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 9px;
	background: rgba(0, 86, 150, 0.08);
	color: var(--psk-blue);
	font-size: 0.9rem;
	flex-shrink: 0;
	transition: background 0.18s ease, color 0.18s ease;
}

.dropdown li small,
.dropdown-menu .dropdown-item small{
	font-size: 0.78rem;
	font-weight: 500;
	color: inherit;
	opacity: 0.9;
}

.dropdown li:hover,
.dropdown-menu .dropdown-item:hover,
.dropdown-menu .dropdown-item:focus,
.dropdown-menu > li.psk-dropdown-item:hover{
	background: linear-gradient(135deg, rgba(0, 86, 150, 0.09) 0%, rgba(140, 198, 63, 0.1) 100%);
	color: var(--psk-blue-dark);
	text-decoration: none;
	box-shadow: inset 0 0 0 1px rgba(0, 86, 150, 0.08);
}

.dropdown li:hover i,
.dropdown-menu .dropdown-item:hover i,
.dropdown-menu > li.psk-dropdown-item:hover i{
	background: var(--psk-blue);
	color: #fff;
}

.dropdown li:active,
.dropdown-menu .dropdown-item:active,
.dropdown-menu > li.psk-dropdown-item:active{
	background: rgba(0, 86, 150, 0.14);
}

.dropdown-menu > li.psk-dropdown-item.psk-dropdown-danger i{
	background: rgba(217, 83, 79, 0.1);
	color: #c9302c;
}

.dropdown-menu > li.psk-dropdown-item.psk-dropdown-danger:hover{
	background: rgba(217, 83, 79, 0.1);
	color: #c9302c;
	box-shadow: inset 0 0 0 1px rgba(217, 83, 79, 0.15);
}

.dropdown-menu > li.psk-dropdown-item.psk-dropdown-danger:hover i{
	background: #c9302c;
	color: #fff;
}

.dropdown-divider,
.dropdown-menu .dropdown-divider{
	margin: 6px 8px;
	border-top: 1px solid var(--psk-gray-light);
}

.dropdown-header,
.dropdown-menu .dropdown-header{
	padding: 8px 12px 4px;
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--psk-gray);
}

.inline-block{
	font-size:0px;
}

.inline-block > div,
.inline-block > li{
	font-size:13px;
	display: inline-block;
}

.vertical-align-top > div,
.vertical-align-top > li{
	vertical-align:top;
}

.vertical-align-middle > div,
.vertical-align-middle > li{
	vertical-align:middle;
}

.vertical-align-bottom > div,
.vertical-align-bottom > li{
	vertical-align:bottom;
}

.tr-td-1,
.tr-td-2,
.tr-td-3{
	padding:5px;
}

.tr-td-1{
	width:100%;
}

.tr-td-2{
	width:50%;
}

.tr-td-3{
	width:33.33%;
}

.swal-toast-psk{
	font-family: 'Segoe UI', system-ui, -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: 0.9rem !important;
	padding: 12px 16px !important;
	border-radius: 10px !important;
	box-shadow: 0 8px 24px rgba(0, 86, 150, 0.18) !important;
}

.swal2-container.swal2-top-end{
	top: 16px !important;
	right: 16px !important;
	padding: 0 !important;
}

.swal-toast-psk .swal2-title,
.swal-toast-psk .swal2-html-container{
	margin: 0 !important;
	padding: 0 !important;
	font-size: 0.9rem !important;
	color: #333 !important;
	text-align: left !important;
}

.swal-toast-psk .swal2-icon{
	width: 1.75em !important;
	height: 1.75em !important;
	margin: 0 10px 0 0 !important;
}

.swal-toast-psk.swal2-icon-success{
	border-color: #8CC63F !important;
}

.swal-toast-psk .swal2-icon.swal2-success [class^='swal2-success-line']{
	background-color: #8CC63F !important;
}

.swal-toast-psk .swal2-icon.swal2-success .swal2-success-ring{
	border-color: rgba(140, 198, 63, 0.3) !important;
}

.swal-toast-psk .swal2-icon.swal2-info{
	border-color: #005696 !important;
	color: #005696 !important;
}

.swal-toast-psk .swal2-icon.swal2-error{
	border-color: #DD0024 !important;
	color: #DD0024 !important;
}

.swal-toast-psk .swal2-timer-progress-bar{
	background: #005696 !important;
}

#cargando{
	display: none;
	position: fixed;
	inset: 0;
	z-index: 9999;
	align-items: center;
	justify-content: center;
	background: rgba(0, 61, 107, 0.35);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}

#cargando.cargando-visible{
	display: flex;
}

.cargando-box{
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
	padding: 28px 36px;
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 20px 60px rgba(0, 86, 150, 0.22);
	animation: cargando-fade-in 0.2s ease-out;
}

@keyframes cargando-fade-in{
	from{
		opacity: 0;
		transform: scale(0.95);
	}
	to{
		opacity: 1;
		transform: scale(1);
	}
}

.cargando-spinner{
	width: 52px;
	height: 52px;
	border: 4px solid rgba(0, 86, 150, 0.12);
	border-top-color: #005696;
	border-right-color: #8CC63F;
	border-radius: 50%;
	animation: cargando-spin 0.75s linear infinite;
}

@keyframes cargando-spin{
	to{
		transform: rotate(360deg);
	}
}

.cargando-texto{
	font-family: 'Segoe UI', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.82rem;
	font-weight: 600;
	color: #005696;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.paginado{
	display: block;
	width:100%;
	text-align: center;
}

.paginado > div{
}

.col-md-12,
.col-md-8,
.col-md-6,
.col-md-4,
.col-md-3{
	margin-bottom:10px;
	padding:0px 5px;
}

.nav-tabs{
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 18px;
	padding: 10px 12px;
	border: none;
	border-radius: 12px;
	background: var(--psk-white);
	box-shadow: var(--psk-shadow);
	border: 1px solid var(--psk-gray-light);
}

.nav-tabs .nav-item{
	margin-bottom: 0;
}

.nav-tabs .nav-link{
	border: none;
	border-radius: 20px;
	color: var(--psk-gray);
	font-weight: 500;
	font-size: 0.82rem;
	padding: 7px 14px;
	background: var(--psk-bg);
	transition: color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
	white-space: nowrap;
}

.nav-tabs .nav-link:hover{
	color: var(--psk-blue);
	background: rgba(0, 86, 150, 0.1);
	border-color: transparent;
}

.nav-tabs .nav-link.active{
	color: #fff;
	background: linear-gradient(135deg, var(--psk-blue) 0%, var(--psk-blue-light) 100%);
	font-weight: 600;
	box-shadow: 0 2px 8px rgba(0, 86, 150, 0.28);
	border: none;
	margin-bottom: 0;
}

.nav-tabs .nav-link.active:hover{
	color: #fff;
	background: linear-gradient(135deg, var(--psk-blue-dark) 0%, var(--psk-blue) 100%);
}

.tab-content{
	padding-top: 4px;
}

@media (max-width: 768px){
	.nav-tabs{
		flex-wrap: nowrap;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 8px;
	}

	.nav-tabs::-webkit-scrollbar{
		height: 4px;
	}

	.nav-tabs::-webkit-scrollbar-thumb{
		background: var(--psk-gray-light);
		border-radius: 4px;
	}
}

.table thead tr{
	background: linear-gradient(90deg, var(--psk-blue-dark) 0%, var(--psk-blue) 100%);
}

.table thead th{
	background: transparent;
	color: #fff;
	font-weight: 600;
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	border: none;
	padding: 11px 12px;
	vertical-align: middle;
}

.table-striped tbody tr:nth-of-type(odd){
	background-color: rgba(0, 86, 150, 0.03);
}

.table-hover tbody tr:hover,
.table tbody tr:hover{
	background-color: rgba(140, 198, 63, 0.08);
}

.table td,
.table th{
	vertical-align: middle;
	border-color: var(--psk-gray-light);
}

.table tbody td,
.table tbody th{
	font-size: 0.92rem;
	line-height: 1.35;
}

.psk-tabla-modulos-wrap,
#lista_modulos_adicionales_sm:not(:empty){
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	border-radius: 10px;
	border: 1px solid var(--psk-gray-light);
	background: #fff;
}

.psk-tabla-modulos{
	width: 100%;
	margin: 0 !important;
	border-collapse: collapse;
}

.psk-tabla-modulos .psk-th-check,
.psk-tabla-modulos .psk-td-check{
	width: 52px;
	min-width: 52px;
}

.psk-tabla-modulos .psk-th-nombre,
.psk-tabla-modulos .psk-td-nombre{
	min-width: 180px;
}

.psk-tabla-modulos .psk-th-precio,
.psk-tabla-modulos .psk-td-precio{
	min-width: 96px;
	white-space: nowrap;
}

.psk-tabla-modulos .psk-checkbox-inline{
	display: inline-flex;
	margin: 0;
}

.psk-tabla-modulos thead tr{
	background: linear-gradient(135deg, var(--psk-blue-dark) 0%, var(--psk-blue) 100%);
}

.psk-tabla-modulos thead th{
	background: transparent !important;
	color: #fff;
	border: none;
}

.psk-modulos-adicionales-block{
	margin-top: 20px;
}

.psk-section-title{
	margin: 16px 0 10px;
	padding-bottom: 8px;
	border-bottom: 2px solid var(--psk-green);
	color: var(--psk-blue-dark);
	font-size: 1.05rem;
	font-weight: 700;
}

.psk-section-title u{
	text-decoration: none;
}

.busqueda_grilla{
	background: var(--psk-white);
	border-radius: 12px;
	padding: 16px 20px;
	margin-bottom: 16px;
	box-shadow: var(--psk-shadow);
	border: 1px solid var(--psk-gray-light);
}

/* Seguimiento: notas y aprobaciones en grilla */
.table thead th.psk-th-nota,
.table thead th.psk-th-aprobar{
	width: 38px;
	min-width: 38px;
	padding: 11px 6px;
	font-size: 0.72rem;
}

.psk-td-nota,
.psk-td-aprobar{
	width: 38px;
	min-width: 38px;
	padding: 6px 4px !important;
	vertical-align: middle !important;
}

.psk-td-dias{
	min-width: 44px;
	font-weight: 600;
	color: var(--psk-blue);
}

.psk-nota-btn{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	padding: 0;
	border-radius: 50%;
	border: 2px solid var(--psk-gray-light);
	background: var(--psk-bg);
	color: var(--psk-gray);
	font-size: 0.72rem;
	font-weight: 700;
	line-height: 1;
	cursor: pointer;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
}

.psk-nota-btn:hover{
	border-color: var(--psk-blue);
	color: var(--psk-blue);
	background: rgba(0, 86, 150, 0.08);
	transform: scale(1.08);
}

.psk-nota-btn.psk-nota-active{
	background: #d9534f;
	border-color: #d9534f;
	color: #fff;
	box-shadow: 0 2px 6px rgba(217, 83, 79, 0.35);
}

.psk-nota-btn.psk-nota-active:hover{
	background: #c9302c;
	border-color: #c9302c;
	color: #fff;
}

.psk-aprobar-check{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 0;
	cursor: pointer;
	position: relative;
}

.psk-aprobar-check input{
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.psk-aprobar-box{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 8px;
	border: 2px solid var(--psk-gray-light);
	background: var(--psk-bg);
	color: transparent;
	font-size: 0.7rem;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.psk-aprobar-check:hover input:not(:checked) + .psk-aprobar-box{
	border-color: var(--psk-blue);
	background: rgba(0, 86, 150, 0.06);
}

.psk-aprobar-check:hover input:checked + .psk-aprobar-box{
	background: var(--psk-green);
	border-color: var(--psk-green-dark);
	color: #fff;
}

.psk-aprobar-check input:checked + .psk-aprobar-box{
	background: var(--psk-green);
	border-color: var(--psk-green);
	color: #fff;
	box-shadow: 0 2px 6px rgba(140, 198, 63, 0.35);
}

.psk-badge-estatus{
	display: inline-block;
	padding: 4px 12px;
	border-radius: 20px;
	font-size: 0.75rem;
	font-weight: 600;
	white-space: nowrap;
}

.psk-badge-activo{
	background: rgba(140, 198, 63, 0.15);
	color: var(--psk-green-dark);
}

.psk-badge-suspendida{
	background: rgba(217, 83, 79, 0.12);
	color: #c9302c;
}

.busqueda_grilla .row > [class*="col-"]{
	margin-bottom: 12px;
}

.busqueda_grilla .psk-search-filter{
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.busqueda_grilla .psk-search-filter > .psk-field-label,
#modal_busqueda .psk-search-filter > .psk-field-label{
	margin-bottom: 0;
}

.psk-search-toolbar{
	display: flex;
	align-items: stretch;
	width: 100%;
	border-radius: var(--psk-radius);
	box-shadow: 0 2px 10px rgba(0, 86, 150, 0.08);
	overflow: hidden;
	border: 1.5px solid var(--psk-gray-light);
	background: var(--psk-white);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.psk-search-toolbar:focus-within{
	border-color: var(--psk-blue);
	box-shadow: 0 0 0 3px rgba(0, 86, 150, 0.12);
}

.psk-search-toolbar select.psk-select-filtro,
.psk-search-toolbar select[name="filtro_busqueda"]{
	width: auto;
	min-width: 140px;
	max-width: 38%;
	flex: 0 0 auto;
	margin: 0;
	border: none !important;
	border-radius: 0 !important;
	border-right: 1.5px solid var(--psk-gray-light) !important;
	box-shadow: none !important;
	min-height: 42px;
	padding: 9px 36px 9px 14px;
	background-color: #f8fafc;
	font-size: 0.84rem;
	font-weight: 600;
	color: var(--psk-blue-dark);
	cursor: pointer;
}

.psk-search-toolbar select.psk-select-filtro:hover,
.psk-search-toolbar select[name="filtro_busqueda"]:hover{
	background-color: rgba(0, 86, 150, 0.06);
}

.psk-search-toolbar select.psk-select-filtro:focus,
.psk-search-toolbar select[name="filtro_busqueda"]:focus{
	box-shadow: none !important;
	outline: none;
	background-color: #fff;
}

.psk-search-toolbar > .psk-input-group,
.psk-search-toolbar > .input-group{
	flex: 1 1 auto;
	min-width: 0;
	border: none !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	background: transparent;
}

.psk-search-toolbar > .psk-input-group:focus-within,
.psk-search-toolbar > .input-group:focus-within{
	box-shadow: none !important;
	border-color: transparent !important;
}

.psk-search-toolbar .psk-input-group .form-control{
	min-height: 42px;
	padding-left: 14px;
	font-size: 0.9rem;
}

.psk-search-toolbar .psk-input-group .form-control::placeholder{
	color: #94a3b8;
}

.psk-search-toolbar .psk-input-group .input-group-append .btn{
	min-height: 42px;
	min-width: 44px;
}

#modal_busqueda .psk-search-toolbar .input-group-addon .btn{
	border-radius: 0;
}

.busqueda_grilla .psk-field-label{
	display: block;
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--psk-blue);
	margin-bottom: 6px;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

.busqueda_grilla select.form-control:not(.psk-select-filtro){
	margin-top: 6px;
}

.ck-editor__editable {
    min-height: 300px;
}

/* Checkbox moderno */
.container_checkbox{
	display: inline-flex;
	align-items: center;
	position: relative;
	padding: 8px 14px 8px 40px;
	margin: 0 8px 8px 0;
	cursor: pointer;
	font-size: 0.86rem;
	font-weight: 500;
	color: #444;
	background: var(--psk-white);
	border: 1.5px solid var(--psk-gray-light);
	border-radius: 10px;
	box-shadow: var(--psk-shadow);
	transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.container_checkbox:hover{
	border-color: var(--psk-blue);
	background: rgba(0, 86, 150, 0.04);
	box-shadow: 0 4px 12px rgba(0, 86, 150, 0.1);
}

.container_checkbox input{
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
	cursor: pointer;
}

.container_checkbox input:focus-visible ~ .checkmark{
	box-shadow: 0 0 0 3px rgba(0, 86, 150, 0.2);
}

.container_checkbox input:checked ~ .checkmark{
	background: var(--psk-green);
	border-color: var(--psk-green);
}

.container_checkbox input:checked ~ .checkmark:after{
	display: block;
}

.container_checkbox:has(input:checked){
	border-color: var(--psk-green);
	background: rgba(140, 198, 63, 0.1);
	color: var(--psk-green-dark);
}

.checkmark{
	position: absolute;
	top: 50%;
	left: 12px;
	transform: translateY(-50%);
	height: 20px;
	width: 20px;
	background: var(--psk-bg);
	border: 2px solid var(--psk-gray-light);
	border-radius: 6px;
	transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.container_checkbox:hover input:not(:checked) ~ .checkmark{
	border-color: var(--psk-blue);
	background: #fff;
}

.container_checkbox:hover input:checked ~ .checkmark{
	background: var(--psk-green);
	border-color: var(--psk-green-dark);
}

.checkmark:after{
	content: "";
	position: absolute;
	display: none;
	left: 6px;
	top: 2px;
	width: 5px;
	height: 9px;
	border: solid #fff;
	border-width: 0 2.5px 2.5px 0;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}

.psk-checkbox-row{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin-top: 4px;
}

.lf-drop{
  display:block; border:1px dashed #CBD5E1; border-radius:14px; background:#F8FAFC;
  padding:18px; cursor:pointer; transition:.2s;
}
.lf-drop:hover{ background:#EEF2F7; }
.lf-drop .lf-icon{ font-size:26px; line-height:1; }
.lf-drop .lf-title{ font-weight:700; margin-top:6px; }
.lf-drop .lf-hint{ font-size:.85rem; color:#64748B; }

.lf-grid{ display:flex; flex-wrap:wrap; gap:12px; margin-top:12px; }
.lf-col{ width:100%; }
@media (min-width:576px){ .lf-col{ width:calc(50% - 6px);} }
@media (min-width:768px){ .lf-col{ width:calc(33.333% - 8px);} }
@media (min-width:992px){ .lf-col{ width:calc(25% - 9px);} }

.lf-card{
  border:1px solid #E5E7EB; border-radius:14px; background:#fff;
  box-shadow:0 6px 18px rgba(2,6,23,.06); padding:10px 12px; display:flex; align-items:center; gap:10px;
}
.lf-file-icon{
  width:42px; height:54px; border-radius:6px; background:#16A34A; color:#fff;
  display:flex; align-items:center; justify-content:center; font-weight:800;
}
.lf-file-name{ flex:1; min-width:0; }
.lf-file-name .lf-txt{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:block; }
.lf-file-meta{ font-size:.75rem; color:#6B7280; }
.lf-del{ border:none; background:transparent; color:#DC2626; padding:6px; border-radius:8px; }
.lf-del:hover{ background:#FEE2E2; }

/* Lista de precios */
.psk-lista-precios-toolbar{
	padding: 18px 22px;
}

.psk-lista-precios-toolbar-top{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	margin-bottom: 14px;
}

.psk-lista-precios-actions{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
}

.psk-lista-precios-actions .btn{
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-weight: 600;
	border-radius: 8px;
	padding: 8px 14px;
}

.psk-segment-control{
	display: inline-flex;
	align-items: stretch;
	padding: 4px;
	border-radius: 10px;
	background: #f1f5f9;
	border: 1px solid var(--psk-gray-light);
	gap: 4px;
}

.psk-segment-control input{
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
	pointer-events: none;
}

.psk-segment-control label{
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin: 0;
	padding: 8px 14px;
	border-radius: 8px;
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--psk-gray);
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
	white-space: nowrap;
}

.psk-segment-control label i{
	font-size: 0.78rem;
	opacity: 0.85;
}

.psk-segment-control label:hover{
	color: var(--psk-blue);
	background: rgba(255, 255, 255, 0.65);
}

.psk-segment-control input:checked + label{
	background: var(--psk-white);
	color: var(--psk-blue-dark);
	box-shadow: 0 2px 8px rgba(0, 86, 150, 0.12);
}

.psk-precios-grilla-wrap{
	border: 1px solid rgba(0, 86, 150, 0.12);
	border-radius: 12px;
	background: #f4f7fa;
	overflow: hidden;
	box-shadow: 0 2px 10px rgba(0, 86, 150, 0.06);
	padding: 14px 14px 0;
}

.psk-precios-grilla-wrap .psk-lista-precios-search{
	width: 300px;
	max-width: 100%;
	padding: 12px 14px;
	margin: 0 0 16px;
	border: 1px solid rgba(0, 86, 150, 0.14);
	border-radius: 10px;
	background: #fff;
	box-shadow: 0 1px 4px rgba(0, 86, 150, 0.05);
}

.psk-precios-grilla-wrap .psk-lista-precios-search .psk-field-label{
	display: block;
	margin-bottom: 6px;
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--psk-blue-dark);
}

.psk-precios-grilla-wrap .psk-lista-precios-search .input-group-text{
	background: #fff;
	border-color: var(--psk-gray-light);
	color: var(--psk-blue);
}

.psk-precios-grilla-wrap .psk-precios-grilla{
	border: none;
	border-radius: 0 0 12px 12px;
	box-shadow: none;
	background: #fff;
}

.psk-lista-precios-legend{
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 12px;
}

.psk-legend-chip{
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	border: 1px solid transparent;
}

.psk-legend-pago-unico{ background: #eef6fc; color: #0070b8; border-color: rgba(0, 112, 184, 0.25); }
.psk-legend-tri-anual{ background: #e8f2f9; color: #005696; border-color: rgba(0, 86, 150, 0.25); }
.psk-legend-bi-anual{ background: #e6eef5; color: #003d6b; border-color: rgba(0, 61, 107, 0.25); }
.psk-legend-anual{ background: #f3f9ea; color: #5a8f1e; border-color: rgba(140, 198, 63, 0.35); }
.psk-legend-semestral{ background: #edf8fa; color: #0e7490; border-color: rgba(14, 116, 144, 0.25); }
.psk-legend-trimestral{ background: #eef2f7; color: #4a6280; border-color: rgba(74, 98, 128, 0.25); }
.psk-legend-mensual{ background: #f3f5f7; color: #64748b; border-color: rgba(100, 116, 139, 0.25); }

.psk-lista-precios-hint{
	display: flex;
	align-items: flex-start;
	gap: 8px;
	margin: 0;
	padding: 10px 12px;
	border-radius: 10px;
	background: rgba(0, 86, 150, 0.06);
	border: 1px solid rgba(0, 86, 150, 0.1);
	font-size: 0.82rem;
	color: var(--psk-blue-dark);
	line-height: 1.45;
}

.psk-lista-precios-hint i{
	color: var(--psk-blue);
	margin-top: 2px;
	flex-shrink: 0;
}

.psk-precios-panel .psk-precios-grilla,
.psk-lista-precios .psk-precios-grilla{
	margin-top: 0;
	max-height: calc(100vh - 280px);
	overflow: auto;
}

.psk-lista-precios .psk-precios-grilla-wrap .psk-precios-grilla{
	max-height: calc(100vh - 340px);
}

.psk-precios-panel--compact .psk-precios-grilla{
	max-height: none;
	margin-top: 0;
	border: none;
	box-shadow: none;
	background: transparent;
}

.psk-precios-panel--compact{
	padding: 0;
}

.psk-recargo-inline{
	display: block;
	width: 100%;
	max-width: 120px;
	margin: 6px auto 0;
}

.psk-precios-panel .psk-precios-grilla .psk-precios-table,
.psk-lista-precios .psk-precios-grilla .psk-precios-table,
.psk-precios-panel .psk-precios-table,
.psk-lista-precios .psk-precios-table{
	font-size: 0.84rem;
	border-collapse: separate;
	border-spacing: 0;
}

.psk-precios-panel .psk-precios-grilla .psk-precios-table,
.psk-lista-precios .psk-precios-grilla .psk-precios-table{
	min-width: 1100px;
}

.psk-precios-panel .psk-precios-table thead th,
.psk-lista-precios .psk-precios-table thead th{
	position: sticky;
	top: 0;
	z-index: 2;
	padding: 10px 8px;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	vertical-align: middle;
	white-space: nowrap;
}

.psk-precios-panel .psk-precios-table .psk-th-corner,
.psk-precios-panel .psk-precios-table .psk-th-period,
.psk-lista-precios .psk-precios-table .psk-th-corner,
.psk-lista-precios .psk-precios-table .psk-th-period{
	background: linear-gradient(180deg, #003d6b 0%, #005696 100%) !important;
	color: #fff !important;
	border-bottom: none;
}

.psk-precios-panel .psk-precios-table .psk-th-period,
.psk-lista-precios .psk-precios-table .psk-th-period{
	font-size: 0.78rem;
	text-transform: none;
	letter-spacing: 0.01em;
	padding-top: 10px;
	padding-bottom: 10px;
	border-bottom: 3px solid var(--psk-col-accent, #0070b8);
	white-space: normal;
	text-align: center;
	vertical-align: top;
}

.psk-precios-panel .psk-precios-table thead tr:first-child th.psk-th-period,
.psk-lista-precios .psk-precios-table thead tr:first-child th.psk-th-period,
.psk-precios-panel .psk-precios-table thead tr:nth-child(2) th[class*="psk-col-"],
.psk-lista-precios .psk-precios-table thead tr:nth-child(2) th[class*="psk-col-"],
.psk-precios-panel .psk-precios-table tbody td[class*="psk-col-"],
.psk-lista-precios .psk-precios-table tbody td[class*="psk-col-"]{
	width: 120px;
	min-width: 120px;
	max-width: 120px;
}

.psk-precios-panel .psk-precios-table .psk-th-sistema,
.psk-precios-panel .psk-precios-table thead tr:nth-child(2) th.psk-th-sistema,
.psk-lista-precios .psk-precios-table .psk-th-sistema,
.psk-lista-precios .psk-precios-table thead tr:nth-child(2) th.psk-th-sistema{
	background: #fff !important;
	color: var(--psk-blue-dark) !important;
	box-shadow: inset 0 -1px 0 rgba(0, 86, 150, 0.1);
}

.psk-precios-panel .psk-precios-table thead tr:nth-child(2) th[class*="psk-col-"],
.psk-lista-precios .psk-precios-table thead tr:nth-child(2) th[class*="psk-col-"]{
	background: #f4f7fa !important;
	color: #003d6b !important;
	box-shadow: inset 0 3px 0 0 var(--psk-col-accent, #005696);
	border-bottom: 1px solid rgba(0, 86, 150, 0.08);
}

.psk-precios-panel .psk-precios-table .psk-col-pago-unico,
.psk-lista-precios .psk-precios-table .psk-col-pago-unico{ --psk-col-accent: #0070b8; --psk-col-soft: #f5faff; }
.psk-precios-panel .psk-precios-table .psk-col-tri-anual,
.psk-lista-precios .psk-precios-table .psk-col-tri-anual{ --psk-col-accent: #005696; --psk-col-soft: #f3f8fc; }
.psk-precios-panel .psk-precios-table .psk-col-bi-anual,
.psk-lista-precios .psk-precios-table .psk-col-bi-anual{ --psk-col-accent: #003d6b; --psk-col-soft: #f1f5f9; }
.psk-precios-panel .psk-precios-table .psk-col-anual,
.psk-lista-precios .psk-precios-table .psk-col-anual{ --psk-col-accent: #8cc63f; --psk-col-soft: #f7fbf0; }
.psk-precios-panel .psk-precios-table .psk-col-semestral,
.psk-lista-precios .psk-precios-table .psk-col-semestral{ --psk-col-accent: #0e7490; --psk-col-soft: #f2f9fb; }
.psk-precios-panel .psk-precios-table .psk-col-trimestral,
.psk-lista-precios .psk-precios-table .psk-col-trimestral{ --psk-col-accent: #4a6280; --psk-col-soft: #f4f6f9; }
.psk-precios-panel .psk-precios-table .psk-col-mensual,
.psk-lista-precios .psk-precios-table .psk-col-mensual{ --psk-col-accent: #64748b; --psk-col-soft: #f6f7f9; }

.psk-precios-panel .psk-precios-table thead tr:first-child th,
.psk-lista-precios .psk-precios-table thead tr:first-child th{
	top: 0;
	z-index: 3;
}

.psk-precios-panel .psk-precios-table thead tr:nth-child(2) th,
.psk-lista-precios .psk-precios-table thead tr:nth-child(2) th{
	top: 78px;
}

.psk-precios-panel .psk-precios-table tbody td,
.psk-lista-precios .psk-precios-table tbody td{
	padding: 6px 8px;
	vertical-align: middle;
	border-top: 1px solid rgba(0, 86, 150, 0.06);
}

.psk-precios-panel .psk-precios-table tbody td[class*="psk-col-"],
.psk-lista-precios .psk-precios-table tbody td[class*="psk-col-"]{
	background: var(--psk-col-soft, #fff) !important;
}

.psk-precios-panel .psk-precios-table tbody tr:hover td[class*="psk-col-"],
.psk-lista-precios .psk-precios-table tbody tr:hover td[class*="psk-col-"]{
	background: #fff !important;
	box-shadow: inset 0 0 0 1px rgba(0, 86, 150, 0.08);
}

.psk-precios-panel .psk-precios-table tbody tr:hover td[class*="psk-col-"] .form-control,
.psk-lista-precios .psk-precios-table tbody tr:hover td[class*="psk-col-"] .form-control{
	border-color: var(--psk-col-accent, var(--psk-blue));
}

.psk-precios-panel .psk-precios-table tbody tr th[colspan],
.psk-lista-precios .psk-precios-table tbody tr th[colspan]{
	background: linear-gradient(135deg, rgba(0, 86, 150, 0.08) 0%, rgba(140, 198, 63, 0.12) 100%) !important;
	color: var(--psk-blue-dark);
	font-size: 0.82rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: 10px 12px;
	position: sticky;
	left: 0;
	z-index: 1;
}

.psk-precios-panel .psk-precios-table:not(.psk-precios-table--con-checkbox) tbody td:first-child,
.psk-precios-panel .psk-precios-table:not(.psk-precios-table--con-checkbox) thead tr:nth-child(2) th.psk-th-sistema,
.psk-lista-precios .psk-precios-table:not(.psk-precios-table--con-checkbox) tbody td:first-child,
.psk-lista-precios .psk-precios-table:not(.psk-precios-table--con-checkbox) thead tr:nth-child(2) th.psk-th-sistema{
	position: sticky;
	left: 0;
	z-index: 1;
	background: #fff !important;
	box-shadow: 2px 0 8px rgba(0, 61, 107, 0.06);
	min-width: 220px;
	max-width: 280px;
	font-weight: 600;
	color: var(--psk-blue-dark);
}

.psk-precios-panel .psk-precios-table:not(.psk-precios-table--con-checkbox) thead tr:nth-child(2) th.psk-th-sistema,
.psk-lista-precios .psk-precios-table:not(.psk-precios-table--con-checkbox) thead tr:nth-child(2) th.psk-th-sistema{
	z-index: 4;
}

.psk-precios-panel .psk-precios-table .form-control,
.psk-lista-precios .psk-precios-table .form-control{
	min-height: 34px;
	padding: 6px 8px;
	font-size: 0.84rem;
	border-radius: 8px;
	border-color: rgba(0, 86, 150, 0.12);
	background: #fff;
}

.psk-precios-panel .psk-precios-table .form-control:focus,
.psk-lista-precios .psk-precios-table .form-control:focus{
	border-color: var(--psk-col-accent, var(--psk-blue));
	box-shadow: 0 0 0 3px rgba(0, 86, 150, 0.1);
}

.psk-precios-panel .psk-precios-table .psk-th-period .input-group,
.psk-lista-precios .psk-precios-table .psk-th-period .input-group{
	width: 100%;
	max-width: 120px;
	margin: 0 auto;
	border-radius: 8px;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.35);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}

.psk-precios-panel .psk-precios-table .psk-th-period .input-group .btn,
.psk-lista-precios .psk-precios-table .psk-th-period .input-group .btn{
	min-width: 36px;
	padding: 0 10px;
	font-weight: 700;
	border-radius: 0;
	background: rgba(255, 255, 255, 0.18) !important;
	border-color: rgba(255, 255, 255, 0.25) !important;
	color: #fff !important;
}

.psk-precios-panel .psk-precios-table .psk-th-period .input-group .btn:hover,
.psk-lista-precios .psk-precios-table .psk-th-period .input-group .btn:hover{
	background: rgba(255, 255, 255, 0.28) !important;
}

.psk-precios-panel .psk-precios-table .psk-th-period .input-group .form-control,
.psk-lista-precios .psk-precios-table .psk-th-period .input-group .form-control{
	border: none;
	box-shadow: none;
	min-height: 32px;
	background: #fff;
	color: var(--psk-blue-dark);
}

.psk-precios-panel .psk-precios-table thead .input-group,
.psk-lista-precios .psk-precios-table thead .input-group{
	width: 100%;
	max-width: 120px;
	margin: 0 auto;
	border-radius: 8px;
	overflow: hidden;
	border: 1px solid rgba(0, 86, 150, 0.15);
	box-shadow: none;
}

.psk-precios-panel .psk-precios-table thead .input-group .btn,
.psk-lista-precios .psk-precios-table thead .input-group .btn{
	min-width: 36px;
	padding: 0 10px;
	font-weight: 700;
	border-radius: 0;
}

.psk-precios-panel .psk-precios-table thead .input-group .form-control,
.psk-lista-precios .psk-precios-table thead .input-group .form-control{
	border: none;
	box-shadow: none;
	min-height: 32px;
	background: #fff;
}

.psk-precios-panel .psk-precios-table thead tr:nth-child(2) th:not([class*="psk-col-"]):not(.psk-th-sistema),
.psk-lista-precios .psk-precios-table thead tr:nth-child(2) th:not([class*="psk-col-"]):not(.psk-th-sistema){
	background: #fff !important;
	color: var(--psk-blue-dark) !important;
	box-shadow: inset 0 -1px 0 rgba(0, 86, 150, 0.1);
}

.psk-precios-panel .psk-precios-table--grilla-ofertas tbody td:not([class*="psk-col-"]):not(.psk-td-acciones),
.psk-lista-precios .psk-precios-table--grilla-ofertas tbody td:not([class*="psk-col-"]):not(.psk-td-acciones){
	background: #fff !important;
}

.psk-precios-panel .psk-precios-table--grilla-ofertas tbody tr:hover td:not([class*="psk-col-"]),
.psk-lista-precios .psk-precios-table--grilla-ofertas tbody tr:hover td:not([class*="psk-col-"]){
	background: #f8fafc !important;
}

.psk-precios-panel .psk-precios-table--grilla-ofertas thead tr:first-child th[colspan="5"],
.psk-lista-precios .psk-precios-table--grilla-ofertas thead tr:first-child th[colspan="5"]{
	text-align: left;
}

.psk-precios-panel .psk-precios-table.psk-precios-table--sin-fila-periodos thead tr:nth-child(2) th,
.psk-lista-precios .psk-precios-table.psk-precios-table--sin-fila-periodos thead tr:nth-child(2) th{
	top: 0;
}

.psk-precios-panel .psk-precios-table--con-checkbox thead tr:nth-child(2) th:first-child,
.psk-precios-panel .psk-precios-table--con-checkbox tbody td:first-child,
.psk-lista-precios .psk-precios-table--con-checkbox thead tr:nth-child(2) th:first-child,
.psk-lista-precios .psk-precios-table--con-checkbox tbody td:first-child{
	position: sticky;
	left: 0;
	z-index: 3;
	background: #fff !important;
	width: 50px;
	min-width: 50px;
	max-width: 50px;
	box-shadow: 2px 0 6px rgba(0, 61, 107, 0.06);
}

.psk-precios-panel .psk-precios-table--con-checkbox thead tr:nth-child(2) th:nth-child(2),
.psk-precios-panel .psk-precios-table--con-checkbox tbody td:nth-child(2),
.psk-lista-precios .psk-precios-table--con-checkbox thead tr:nth-child(2) th:nth-child(2),
.psk-lista-precios .psk-precios-table--con-checkbox tbody td:nth-child(2){
	position: sticky;
	left: 50px;
	z-index: 3;
	background: #fff !important;
	box-shadow: 2px 0 8px rgba(0, 61, 107, 0.06);
	min-width: 220px;
	max-width: 280px;
	font-weight: 600;
	color: var(--psk-blue-dark);
}

.psk-precios-panel .psk-precios-table--con-checkbox thead tr:nth-child(2) th:nth-child(2),
.psk-lista-precios .psk-precios-table--con-checkbox thead tr:nth-child(2) th:nth-child(2){
	z-index: 5;
}

@media (max-width: 767px){
	.psk-lista-precios-toolbar-top{
		flex-direction: column;
		align-items: stretch;
	}

	.psk-segment-control{
		width: 100%;
	}

	.psk-segment-control label{
		flex: 1;
		justify-content: center;
	}

	.psk-precios-grilla{
		max-height: none;
	}
}
