/**
 * Riwaq Sessions & Payroll Pro
 * Public CSS (Student Portal)
 */
:root {
	--rspl-primary: #106442;
	--rspl-secondary: #f0f0f0;
	--rspl-text: #333;
	--rspl-border: #ddd;
}

.rspl-portal-wrap {
	font-family: 'Cairo', sans-serif;
	color: var(--rspl-text);
	max-width: 900px;
	margin: 20px auto;
	direction: rtl;
	text-align: right;
}

/* (بطاقات الإحصائيات) */
.rspl-portal-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 15px;
	margin-top: 15px;
}
.rspl-portal-card {
	background: #fff;
	border: 1px solid var(--rspl-border);
	border-radius: 5px;
	padding: 20px;
	box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}
.rspl-portal-card .rspl-card-label {
	font-size: 14px;
	font-weight: 600;
	color: #555;
}
.rspl-portal-card .rspl-card-value {
	font-size: 32px;
	font-weight: 700;
	color: var(--rspl-primary);
	margin-top: 5px;
}

/* (جدول الحصص) */
.rspl-portal-table-wrap {
	overflow-x: auto;
}
.rspl-portal-table {
	width: 100%;
	border-collapse: collapse;
	margin-top: 15px;
	background: #fff;
	border: 1px solid var(--rspl-border);
}
.rspl-portal-table th,
.rspl-portal-table td {
	padding: 12px 15px;
	border: 1px solid var(--rspl-border);
}
.rspl-portal-table th {
	background-color: var(--rspl-secondary);
	font-weight: 700;
	text-align: right;
}

/* (تصميم الهاتف) */
@media screen and (max-width: 782px) {
	.rspl-portal-table thead {
		display: none;
	}
	.rspl-portal-table,
	.rspl-portal-table tbody,
	.rspl-portal-table tr,
	.rspl-portal-table td {
		display: block;
		width: 100%;
	}
	.rspl-portal-table tr {
		margin-bottom: 10px;
		border: 1px solid var(--rspl-border);
	}
	.rspl-portal-table td {
		border: none;
		border-bottom: 1px dotted var(--rspl-border);
		position: relative;
		padding-left: 50%;
		text-align: left;
	}
	.rspl-portal-table td:before {
		content: attr(data-label);
		position: absolute;
		left: 10px;
		width: 45%;
		padding-right: 10px;
		white-space: nowrap;
		font-weight: 700;
		text-align: right;
	}
}