/* ABP Engage Tracker — Frontend Checklist Styles */

.abp-fe {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	color: #1d2327;
	max-width: 720px;
	margin: 0 auto;
	padding: 0 12px 40px;
}

.abp-fe-header {
	padding: 16px 0 8px;
	border-bottom: 2px solid #0073aa;
	margin-bottom: 20px;
}
.abp-fe-header h2 {
	margin: 0;
	font-size: 1.4rem;
	color: #0073aa;
}

/* ---- Notices ---- */
.abp-notice {
	padding: 12px 16px;
	border-radius: 6px;
	margin: 16px 0;
	font-size: 0.95rem;
}
.abp-notice-warning { background: #fff3cd; border-left: 4px solid #ffc107; color: #856404; }
.abp-notice-error   { background: #f8d7da; border-left: 4px solid #dc3545; color: #721c24; }

/* ---- Post Selector ---- */
.abp-fe-post-select {
	background: #f0f4f8;
	padding: 16px;
	border-radius: 8px;
	margin-bottom: 20px;
}
.abp-fe-post-select label { display: block; margin-bottom: 8px; font-size: 0.9rem; }
.abp-fe-post-select select {
	width: 100%;
	padding: 10px 12px;
	font-size: 1rem;
	border: 1px solid #c3c4c7;
	border-radius: 6px;
	background: #fff;
	box-sizing: border-box;
}
.abp-link-btn {
	display: inline-block;
	background: #0073aa;
	color: #fff;
	padding: 7px 14px;
	border-radius: 5px;
	text-decoration: none;
	font-size: 0.85rem;
}
.abp-link-btn:hover { background: #005f8d; color: #fff; }

/* ---- Filters ---- */
.abp-fe-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 16px;
}
.abp-fe-filters input[type="search"],
.abp-fe-filters select {
	flex: 1 1 160px;
	padding: 9px 12px;
	font-size: 0.9rem;
	border: 1px solid #c3c4c7;
	border-radius: 6px;
	box-sizing: border-box;
}

/* ---- Employee Cards ---- */
.abp-emp-list { display: flex; flex-direction: column; gap: 12px; }

.abp-emp-card {
	background: #fff;
	border: 1px solid #e0e0e0;
	border-radius: 10px;
	padding: 14px 16px;
	box-shadow: 0 1px 4px rgba(0,0,0,.06);
	transition: border-color .2s;
}
.abp-emp-card.abp-emp-liked    { border-left: 4px solid #1a7a3c; }
.abp-emp-card.abp-emp-na       { border-left: 4px solid #f0ad4e; }
.abp-emp-card.abp-emp-pending  { border-left: 4px solid #c3c4c7; }

.abp-emp-info {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 8px;
	margin-bottom: 12px;
}
.abp-emp-name {
	font-size: 1rem;
	font-weight: 700;
	flex: 1 1 auto;
}
.abp-emp-dept, .abp-emp-desk {
	font-size: 0.8rem;
	color: #666;
}
.abp-emp-checked {
	font-size: 0.75rem;
	color: #1a7a3c;
	margin-left: auto;
}

/* ---- Actions Row ---- */
.abp-emp-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
}

.abp-check-label {
	display: flex;
	align-items: center;
	gap: 5px;
	font-size: 0.88rem;
	font-weight: 500;
	cursor: pointer;
	user-select: none;
	padding: 6px 10px;
	border: 1px solid #ddd;
	border-radius: 6px;
	background: #f9f9f9;
	transition: background .15s, border-color .15s;
}
.abp-check-label input[type="checkbox"] { width: 16px; height: 16px; cursor: pointer; }
.abp-check-label:has(input:checked)     { border-color: #0073aa; background: #e8f3fb; }

.abp-check-like:has(input:checked)    { border-color: #1a7a3c; background: #d4edda; }
.abp-check-na:has(input:checked)      { border-color: #e6a817; background: #fff3cd; }

.abp-na-reason-wrap { flex: 1 1 140px; }
.abp-na-reason {
	width: 100%;
	padding: 7px 10px;
	font-size: 0.85rem;
	border: 1px solid #c3c4c7;
	border-radius: 6px;
	box-sizing: border-box;
}

.abp-note-wrap { flex: 1 1 180px; }
.abp-note {
	width: 100%;
	padding: 7px 10px;
	font-size: 0.85rem;
	border: 1px solid #c3c4c7;
	border-radius: 6px;
	box-sizing: border-box;
}

.abp-save-btn {
	padding: 8px 18px !important;
	font-size: 0.88rem !important;
	background: #0073aa !important;
	color: #fff !important;
	border: none !important;
	border-radius: 6px !important;
	cursor: pointer !important;
	white-space: nowrap;
}
.abp-save-btn:hover { background: #005f8d !important; }
.abp-save-btn:disabled { background: #aaa !important; cursor: not-allowed !important; }

.abp-save-msg {
	font-size: 0.82rem;
	font-weight: 600;
}
.abp-save-msg.ok  { color: #1a7a3c; }
.abp-save-msg.err { color: #b32d2e; }

/* ---- Hidden utility ---- */
.abp-hidden { display: none !important; }

/* ---- Mobile ---- */
@media (max-width: 500px) {
	.abp-emp-actions { gap: 8px; }
	.abp-check-label { padding: 5px 8px; font-size: 0.82rem; }
	.abp-save-btn { width: 100%; text-align: center; }
	.abp-note-wrap, .abp-na-reason-wrap { flex: 1 1 100%; }
}
