/**
 * Estilos del frontend del plugin Alopekes Campamento.
 * Pensados para integrarse con cualquier theme (Divi, Astra, etc.)
 * sin sobrescribir agresivamente los estilos del sitio.
 */

.wcamp-form-wrap {
	max-width: 720px;
	margin: 24px auto;
	padding: 24px;
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	box-shadow: 0 1px 3px rgba(0,0,0,.04);
	font-family: inherit;
}

.wcamp-form .wcamp-row {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin-bottom: 4px;
}

.wcamp-form .wcamp-row .wcamp-field {
	flex: 1 1 240px;
}

.wcamp-form .wcamp-field {
	margin-bottom: 16px;
	display: flex;
	flex-direction: column;
}

.wcamp-form label {
	font-weight: 600;
	margin-bottom: 6px;
	color: #1f2937;
	font-size: 14px;
}

.wcamp-form .req {
	color: #dc2626;
	margin-left: 2px;
}

.wcamp-form input[type="text"],
.wcamp-form input[type="email"],
.wcamp-form input[type="tel"],
.wcamp-form input[type="number"],
.wcamp-form input[type="password"] {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid #d1d5db;
	border-radius: 6px;
	font-size: 15px;
	background: #fff;
	box-sizing: border-box;
	transition: border-color .15s, box-shadow .15s;
}

.wcamp-form input:focus {
	outline: none;
	border-color: #1f3864;
	box-shadow: 0 0 0 3px rgba(31,56,100,.12);
}

.wcamp-form small {
	margin-top: 4px;
	color: #6b7280;
	font-size: 12px;
}

.wcamp-form .wcamp-field-check label {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-weight: 400;
	cursor: pointer;
}

.wcamp-form .wcamp-field-check input[type="checkbox"] {
	margin-top: 3px;
	flex: 0 0 auto;
}

/* El <span> que envuelve el texto del check debe ocupar el resto de la línea
   y mantener su contenido como un bloque de texto continuo (no como flex items). */
.wcamp-form .wcamp-field-check label > span {
	flex: 1 1 auto;
	line-height: 1.4;
}

.wcamp-form .wcamp-field-check label > span a {
	white-space: nowrap;
}

.wcamp-form .wcamp-actions {
	margin-top: 16px;
	display: flex;
	justify-content: flex-end;
}

.wcamp-btn {
	display: inline-block;
	padding: 12px 20px;
	border-radius: 6px;
	border: none;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	transition: background-color .15s, transform .05s;
}

.wcamp-btn-primary {
	background: #1f3864;
	color: #fff;
}

.wcamp-btn-primary:hover {
	background: #15264a;
	color: #fff;
}

.wcamp-btn-primary:active {
	transform: translateY(1px);
}

.wcamp-already {
	text-align: center;
	margin-top: 16px;
	font-size: 14px;
	color: #6b7280;
}

.wcamp-errors {
	background: #fef2f2;
	border: 1px solid #fecaca;
	color: #991b1b;
	padding: 12px 16px;
	border-radius: 6px;
	margin-bottom: 20px;
	font-size: 14px;
}

.wcamp-errors ul {
	margin: 8px 0 0 18px;
	padding: 0;
}

.wcamp-info {
	background: #eff6ff;
	border: 1px solid #bfdbfe;
	color: #1e40af;
	padding: 12px 16px;
	border-radius: 6px;
	margin: 16px 0;
}

.wcamp-success {
	text-align: center;
}

.wcamp-success h2 {
	color: #1f3864;
	margin-top: 0;
}

.wcamp-lostpass {
	text-align: center;
	margin-top: 12px;
	font-size: 14px;
}

/* Login form (wp_login_form) */
.wcamp-form-wrap .login-username,
.wcamp-form-wrap .login-password {
	margin-bottom: 14px;
}

.wcamp-form-wrap .login-username label,
.wcamp-form-wrap .login-password label {
	display: block;
	font-weight: 600;
	margin-bottom: 6px;
	color: #1f2937;
	font-size: 14px;
}

.wcamp-form-wrap .login-username input,
.wcamp-form-wrap .login-password input {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid #d1d5db;
	border-radius: 6px;
	font-size: 15px;
	box-sizing: border-box;
}

.wcamp-form-wrap .login-submit input[type="submit"] {
	background: #1f3864;
	color: #fff;
	border: none;
	padding: 12px 20px;
	border-radius: 6px;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
}

.wcamp-form-wrap .login-remember {
	margin: 8px 0;
	font-size: 14px;
}

/* ====== Panel del tutor ([wcamp_panel]) ====== */

.wcamp-panel {
	max-width: 880px;
	margin: 24px auto;
	font-family: inherit;
	color: #1f2937;
}

.wcamp-panel-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 16px;
	margin-bottom: 16px;
}

.wcamp-panel-header h2 {
	margin: 0 0 4px 0;
	color: #1f3864;
	font-size: 24px;
}

.wcamp-panel-sub {
	margin: 0;
	color: #6b7280;
	font-size: 14px;
}

.wcamp-link-logout {
	color: #6b7280;
	font-size: 14px;
	text-decoration: none;
}
.wcamp-link-logout:hover {
	color: #1f3864;
	text-decoration: underline;
}

.wcamp-panel .wcamp-card {
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	padding: 20px 22px;
	margin-bottom: 16px;
	box-shadow: 0 1px 3px rgba(0,0,0,.04);
}

.wcamp-panel .wcamp-card h3 {
	margin: 0 0 6px 0;
	color: #1f3864;
	font-size: 17px;
}

.wcamp-card-warn {
	background: #fef9c3 !important;
	border-color: #fde68a !important;
}

.wcamp-card-pending {
	border-style: dashed !important;
	background: #fafafa !important;
}

.wcamp-pending-note {
	background: #fff7ed;
	border: 1px solid #fed7aa;
	color: #9a3412;
	padding: 10px 12px;
	border-radius: 6px;
	font-size: 14px;
	margin-top: 12px;
}

.wcamp-state-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
}

.wcamp-state-help {
	margin: 0;
	color: #6b7280;
	font-size: 14px;
}

.wcamp-badge {
	display: inline-block;
	padding: 6px 14px;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 600;
	white-space: nowrap;
}

/* ===== Toast popup (notificaciones post-acción) ===== */

.wcamp-toast {
	position: fixed;
	top: 24px;
	right: 24px;
	z-index: 99999;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 18px 14px 16px;
	min-width: 280px;
	max-width: 420px;
	background: #ecfdf5;
	border: 1px solid #6ee7b7;
	color: #065f46;
	border-radius: 8px;
	box-shadow: 0 8px 24px rgba(0,0,0,.12);
	font-size: 14px;
	font-weight: 500;
	animation: wcamp-toast-in .35s ease-out;
}

.wcamp-toast-success {
	background: #ecfdf5;
	border-color: #6ee7b7;
	color: #065f46;
}

.wcamp-toast-error {
	background: #fef2f2;
	border-color: #fca5a5;
	color: #991b1b;
}

.wcamp-toast-icon {
	flex: 0 0 28px;
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	font-weight: 700;
	color: #fff;
	font-size: 14px;
}

.wcamp-toast-success .wcamp-toast-icon { background: #10b981; }
.wcamp-toast-error   .wcamp-toast-icon { background: #ef4444; }

.wcamp-toast-message {
	flex: 1 1 auto;
	line-height: 1.4;
}

.wcamp-toast-close {
	flex: 0 0 auto;
	background: none;
	border: 0;
	color: inherit;
	font-size: 22px;
	line-height: 1;
	padding: 0 4px;
	cursor: pointer;
	opacity: .6;
}

.wcamp-toast-close:hover {
	opacity: 1;
}

.wcamp-toast-hide {
	animation: wcamp-toast-out .3s ease-in forwards;
}

@keyframes wcamp-toast-in {
	from { transform: translateX(120%); opacity: 0; }
	to   { transform: translateX(0);    opacity: 1; }
}

@keyframes wcamp-toast-out {
	from { transform: translateX(0);    opacity: 1; }
	to   { transform: translateX(120%); opacity: 0; }
}

@media (max-width: 600px) {
	.wcamp-toast {
		top: 12px;
		right: 12px;
		left: 12px;
		min-width: 0;
		max-width: none;
	}
}

/* ===== Slots de subida ===== */

.wcamp-uploads {
	display: flex;
	flex-direction: column;
	gap: 14px;
	margin-top: 14px;
}

.wcamp-upload-slot {
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	padding: 14px 16px;
	background: #fff;
	transition: border-color .15s;
}

.wcamp-upload-slot.has-file {
	border-color: #d1d5db;
	background: #f9fafb;
}

.wcamp-upload-info strong {
	display: block;
	font-size: 15px;
	color: #1f3864;
	margin-bottom: 2px;
}

.wcamp-upload-info small {
	color: #6b7280;
	font-size: 12px;
	display: block;
	margin-bottom: 10px;
}

.wcamp-upload-empty {
	background: #fef3c7;
	color: #92400e;
	font-size: 13px;
	padding: 8px 10px;
	border-radius: 6px;
	margin-bottom: 10px;
}

.wcamp-upload-current {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	background: #ecfdf5;
	border: 1px solid #a7f3d0;
	border-radius: 6px;
	padding: 10px 12px;
	margin-bottom: 10px;
}

.wcamp-upload-check {
	flex: 0 0 24px;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: #10b981;
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 14px;
	margin-top: 1px;
}

.wcamp-upload-current-meta {
	flex: 1 1 auto;
	min-width: 0;
}

.wcamp-upload-current-meta a {
	font-weight: 600;
	color: #065f46;
	word-break: break-all;
}

.wcamp-upload-current-meta small {
	display: block;
	margin-top: 4px;
	color: #4b5563;
	font-size: 12px;
}

.wcamp-mini-badge {
	display: inline-block;
	padding: 2px 8px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 600;
	margin-left: 4px;
}

.wcamp-mini-pendiente { background: #fef3c7; color: #92400e; }
.wcamp-mini-ok        { background: #d1fae5; color: #065f46; }
.wcamp-mini-rechazado { background: #fee2e2; color: #991b1b; }

.wcamp-upload-form {
	display: flex;
	gap: 10px;
	align-items: center;
	flex-wrap: wrap;
}

.wcamp-upload-form input[type="file"] {
	flex: 1 1 240px;
	font-size: 13px;
	padding: 6px;
	border: 1px dashed #cbd5e1;
	border-radius: 6px;
	background: #fff;
	cursor: pointer;
}

.wcamp-upload-form input[type="file"]::file-selector-button {
	margin-right: 10px;
	padding: 6px 10px;
	border: 1px solid #cbd5e1;
	background: #f8fafc;
	border-radius: 4px;
	cursor: pointer;
	font-size: 13px;
}

.wcamp-success-msg {
	background: #d1fae5;
	border: 1px solid #6ee7b7;
	color: #065f46;
	padding: 10px 12px;
	border-radius: 6px;
	margin-bottom: 14px;
	font-size: 14px;
}

/* ===== Tarjetas de descarga de PDFs ===== */

.wcamp-downloads {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
	margin-top: 14px;
}

.wcamp-download {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 16px;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	background: #fff;
	text-decoration: none;
	color: #1f2937;
	transition: border-color .15s, box-shadow .15s, transform .05s;
}

.wcamp-download:hover {
	border-color: #1f3864;
	box-shadow: 0 2px 8px rgba(31,56,100,.10);
	color: #1f3864;
}

.wcamp-download:active {
	transform: translateY(1px);
}

.wcamp-download .wcamp-pdf-icon {
	color: #dc2626;
	flex: 0 0 auto;
}

.wcamp-download-meta {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.wcamp-download-meta strong {
	font-size: 15px;
	font-weight: 600;
	line-height: 1.2;
	color: inherit;
}

.wcamp-download-meta small {
	color: #6b7280;
	font-size: 12px;
	margin-top: 4px;
}

.wcamp-download-arrow {
	flex: 0 0 auto;
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: #f3f4f6;
	color: #1f3864;
	font-weight: 700;
}

.wcamp-download:hover .wcamp-download-arrow {
	background: #1f3864;
	color: #fff;
}

.wcamp-download-disabled {
	background: #f9fafb;
	color: #9ca3af;
	cursor: not-allowed;
	opacity: .85;
}

.wcamp-download-disabled .wcamp-pdf-icon {
	color: #d1d5db;
}

.wcamp-download-disabled:hover {
	border-color: #e5e7eb;
	box-shadow: none;
	color: #9ca3af;
}

@media (max-width: 600px) {
	.wcamp-downloads {
		grid-template-columns: 1fr;
	}
}

/* ===== Barra de progreso de documentos ===== */

.wcamp-progress {
	margin-top: 16px;
	padding-top: 14px;
	border-top: 1px solid #e5e7eb;
}

.wcamp-progress-header {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: 8px;
	flex-wrap: wrap;
	gap: 8px;
}

.wcamp-progress-count {
	color: #1f2937;
	font-size: 14px;
}

.wcamp-progress-count strong {
	color: #1f3864;
	font-size: 22px;
	font-weight: 700;
	margin: 0 2px;
}

.wcamp-progress-divider {
	color: #9ca3af;
	margin: 0 2px;
}

.wcamp-progress-percent {
	color: #6b7280;
	font-size: 13px;
	font-weight: 600;
}

.wcamp-progress-bar {
	height: 10px;
	background: #e5e7eb;
	border-radius: 999px;
	overflow: hidden;
}

.wcamp-progress-fill {
	height: 100%;
	background: linear-gradient(90deg, #2e74b5 0%, #1f3864 100%);
	border-radius: 999px;
	transition: width .35s ease;
}

.wcamp-progress.is-complete .wcamp-progress-fill {
	background: linear-gradient(90deg, #34d399 0%, #10b981 100%);
}

.wcamp-progress.is-complete .wcamp-progress-count strong {
	color: #065f46;
}

.wcamp-progress-note {
	margin: 10px 0 0 0;
	font-size: 13px;
	color: #6b7280;
}

.wcamp-progress.is-complete .wcamp-progress-note {
	color: #065f46;
}

/* ===== Banner de confirmación (con fecha/hora oficial) ===== */

.wcamp-confirmado-banner {
	margin-top: 16px;
	padding: 14px 16px;
	background: linear-gradient(90deg, #ecfdf5 0%, #f0fdf4 100%);
	border: 1px solid #86efac;
	border-left: 4px solid #10b981;
	border-radius: 8px;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.wcamp-confirmado-banner strong {
	color: #065f46;
	font-size: 14px;
}

.wcamp-confirmado-banner span {
	font-size: 18px;
	color: #047857;
	font-weight: 700;
}

.wcamp-confirmado-banner small {
	color: #4b5563;
	font-size: 12px;
	margin-top: 4px;
	line-height: 1.4;
}

.wcamp-state-pendiente   { background: #fef3c7; color: #92400e; }
.wcamp-state-subido      { background: #dbeafe; color: #1e40af; }
.wcamp-state-verificado  { background: #e0e7ff; color: #3730a3; }
.wcamp-state-incompleto  { background: #fee2e2; color: #991b1b; }
.wcamp-state-confirmado  { background: #d1fae5; color: #065f46; }
.wcamp-state-default     { background: #e5e7eb; color: #374151; }

.wcamp-data {
	display: grid;
	grid-template-columns: 200px 1fr;
	gap: 8px 16px;
	margin: 0;
}

.wcamp-data dt {
	color: #6b7280;
	font-weight: 600;
	font-size: 14px;
}
.wcamp-data dd {
	margin: 0;
	color: #1f2937;
	font-size: 14px;
}

.wcamp-btn-secondary {
	background: #fff;
	color: #1f3864;
	border: 1px solid #1f3864;
}
.wcamp-btn-secondary:hover {
	background: #f1f5f9;
	color: #1f3864;
}

.wcamp-panel-locked .wcamp-actions {
	justify-content: flex-start;
	gap: 10px;
	margin-top: 16px;
}

@media (max-width: 600px) {
	.wcamp-form-wrap {
		margin: 12px;
		padding: 16px;
	}
	.wcamp-form .wcamp-row {
		flex-direction: column;
	}
	.wcamp-panel {
		margin: 12px;
	}
	.wcamp-panel-header {
		flex-direction: column;
	}
	.wcamp-data {
		grid-template-columns: 1fr;
		gap: 0 0;
	}
	.wcamp-data dt {
		margin-top: 10px;
	}
}
