/**
 * Fee Structure — semester fee table.
 *
 * @package DBCTE_Tura
 */

.fee-page {
	padding-top: 0;
	padding-bottom: clamp(2.5rem, 6vw, 4rem);
	background: linear-gradient(180deg, #f1f5f9 0%, #f8fafc 40%, #ffffff 100%);
}

.fee-page.section {
	padding-top: 0;
}

.fee-page__hero {
	margin: 0 calc(50% - 50vw) 0;
	width: 100vw;
	padding: clamp(1.85rem, 4vw, 2.75rem) 1.25rem;
	background:
		radial-gradient(ellipse 65% 70% at 85% 15%, color-mix(in srgb, var(--dbcte-hub-sky) 18%, transparent) 0%, transparent 50%),
		linear-gradient(155deg, var(--dbcte-primary) 0%, color-mix(in srgb, var(--dbcte-primary) 85%, #0c1929 15%) 100%);
	color: #fff;
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	box-shadow: 0 10px 36px rgba(15, 23, 42, 0.1);
}

.fee-page__hero-inner {
	max-width: min(100%, 52rem);
	margin: 0 auto;
	text-align: center;
}

.fee-page__title {
	margin: 0;
	font-size: clamp(1.55rem, 3.6vw, 2.05rem);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -0.02em;
	text-shadow: 0 2px 14px rgba(0, 0, 0, 0.12);
}

.fee-page__shell {
	max-width: min(100%, 56rem);
	margin: 0 auto;
	padding: clamp(1.75rem, 4vw, 2.5rem) 1rem 0;
}

.fee-page__masthead {
	margin: 0 0 1.75rem;
	padding: 1.35rem 1.25rem;
	text-align: center;
	background: #fff;
	border: 1px solid rgba(30, 58, 138, 0.1);
	border-radius: var(--dbcte-radius);
	box-shadow: 0 6px 28px rgba(30, 58, 138, 0.07);
}

.fee-page__org {
	margin: 0 0 0.5rem;
	font-size: clamp(0.88rem, 2vw, 0.98rem);
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1.35;
	color: var(--dbcte-primary);
}

.fee-page__subtitle {
	margin: 0 0 0.85rem;
	font-size: clamp(1rem, 2.2vw, 1.15rem);
	font-weight: 700;
	line-height: 1.35;
	color: var(--dbcte-text);
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.fee-page__section-title {
	margin: 0;
	font-size: clamp(0.92rem, 2vw, 1.02rem);
	font-weight: 700;
	color: var(--dbcte-muted);
	text-transform: capitalize;
	letter-spacing: 0.02em;
}

.fee-table-wrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	border-radius: var(--dbcte-radius);
	border: 1px solid rgba(30, 58, 138, 0.12);
	background: #fff;
	box-shadow: 0 8px 32px rgba(30, 58, 138, 0.08);
}

.fee-table {
	width: 100%;
	min-width: 44rem;
	border-collapse: collapse;
	font-size: 0.82rem;
	line-height: 1.45;
}

.fee-table th,
.fee-table td {
	padding: 0.65rem 0.7rem;
	text-align: left;
	vertical-align: top;
	border: 1px solid #e2e8f0;
}

.fee-table thead th {
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #5b21b6;
	background: linear-gradient(180deg, #f5f3ff 0%, #ede9fe 100%);
	white-space: nowrap;
}

.fee-table tbody td:first-child {
	font-weight: 700;
	text-align: center;
	font-variant-numeric: tabular-nums;
	color: var(--dbcte-primary);
	width: 3rem;
	background: rgba(30, 58, 138, 0.04);
}

.fee-table tbody td:nth-child(3),
.fee-table tbody td:nth-child(5),
.fee-table tfoot td {
	font-weight: 600;
	font-variant-numeric: tabular-nums;
	text-align: right;
	white-space: nowrap;
}

.fee-table tbody tr:nth-child(even) td {
	background: rgba(248, 250, 252, 0.9);
}

.fee-table tbody tr:hover td {
	background: rgba(0, 168, 225, 0.05);
}

.fee-table tfoot td:first-child {
	font-weight: 700;
	text-align: center;
	color: var(--dbcte-primary);
	background: rgba(30, 58, 138, 0.08);
}

.fee-table tfoot th,
.fee-table tfoot td {
	background: rgba(30, 58, 138, 0.06);
	border-top: 2px solid #c4b5fd;
}

.fee-table tfoot td strong {
	font-size: 1.02em;
	color: var(--dbcte-primary);
}

@media (max-width: 640px) {
	.fee-table {
		font-size: 0.76rem;
	}

	.fee-table th,
	.fee-table td {
		padding: 0.5rem 0.45rem;
	}
}
