.kmutt-academic-calendar {
	--academic-orange: #f15a24;
	--academic-orange-dark: #d94a16;
	--academic-ink: #101828;
	--academic-muted: #667085;
	--academic-border: #e4e7ec;
	--academic-soft: #f8fafc;
	background: #fff;
	color: var(--academic-ink);
	font-family: inherit;
	font-size: 17.5px;
	padding-bottom: 40px;
}

.kmutt-academic-calendar *,
.kmutt-academic-calendar *::before,
.kmutt-academic-calendar *::after {
	box-sizing: border-box;
}

.kmutt-academic-calendar button,
.kmutt-academic-calendar input,
.kmutt-academic-calendar select {
	font: inherit;
}

.academic-calendar__breadcrumb {
	align-items: center;
	color: var(--academic-muted);
	display: flex;
	flex-wrap: wrap;
	font-size: 15.5px;
	gap: 8px;
	padding: 22px 0;
}

.academic-calendar__breadcrumb a {
	color: #344054 !important;
	text-decoration: none;
}

.academic-calendar__breadcrumb .material-icons {
	font-size: 17px;
}

.academic-calendar__breadcrumb strong {
	color: var(--academic-ink);
}

.academic-calendar__hero {
	align-items: center;
	display: grid;
	gap: 32px;
	grid-template-columns: minmax(0, 1.5fr) minmax(220px, .5fr);
	min-height: 180px;
	padding: 18px 0 24px;
}

.academic-calendar__hero h1 {
	font-size: clamp(45.5px, 5vw, 64px);
	font-weight: 900;
	letter-spacing: 0;
	line-height: 1.05;
	margin: 0 0 14px;
}

.academic-calendar__hero p {
	font-size: 24.5px;
	font-weight: 600;
	line-height: 1.4;
	margin: 0;
}

.academic-calendar__hero-art {
	align-items: center;
	background: linear-gradient(145deg, #fff7f1, #fff);
	border-radius: 8px;
	display: flex;
	height: 140px;
	justify-content: center;
	position: relative;
}

.academic-calendar__hero-art .material-icons:first-child {
	color: var(--academic-orange);
	font-size: 112px;
}

.academic-calendar__hero-art .material-icons:last-child {
	background: #fff;
	border: 5px solid #98a2b3;
	border-radius: 50%;
	bottom: 12px;
	color: #667085;
	font-size: 48px;
	padding: 4px;
	position: absolute;
	right: 24px;
}

.academic-calendar__filters {
	align-items: end;
	display: grid;
	gap: 24px;
	grid-template-columns: 150px minmax(320px, .8fr) 180px 120px;
	margin-bottom: 24px;
}

.academic-calendar__filters label,
.academic-calendar__filters fieldset {
	border: 0;
	display: grid;
	gap: 8px;
	margin: 0;
	min-width: 0;
	padding: 0;
}

.academic-calendar__filters label > span,
.academic-calendar__filters legend {
	color: #344054;
	font-size: 15.5px;
	font-weight: 800;
	margin: 0;
	padding: 0;
}

.academic-calendar__filters select {
	appearance: auto;
	background: #fff;
	border: 1px solid #d0d5dd;
	border-radius: 8px;
	color: var(--academic-ink);
	height: 48px;
	padding: 0 14px;
	width: 100%;
}

.academic-calendar__segments {
	display: flex;
}

.academic-calendar__segments button,
.academic-calendar__category-filters button {
	background: #f2f4f7;
	border: 1px solid transparent;
	color: #344054;
	font-size: 16.5px;
	font-weight: 700;
	min-height: 44px;
	padding: 8px 20px;
}

.academic-calendar__segments button + button {
	border-left-color: #e4e7ec;
}

.academic-calendar__segments button:first-child {
	border-radius: 8px 0 0 8px;
}

.academic-calendar__segments button:last-child {
	border-radius: 0 8px 8px 0;
}

.academic-calendar__segments button.is-active,
.academic-calendar__category-filters button.is-active {
	background: var(--academic-orange);
	color: #fff;
}

.academic-calendar__view-control .academic-calendar__segments button {
	align-items: center;
	display: inline-flex;
	justify-content: center;
	padding: 6px 12px;
}

.academic-calendar__summary,
.academic-calendar__panel {
	background: #fff;
	border: 1px solid var(--academic-border);
	border-radius: 8px;
	box-shadow: 0 4px 14px rgba(16, 24, 40, .035);
}

.academic-calendar__setup-notice {
	align-items: flex-start;
	background: #fffaeb;
	border: 1px solid #fedf89;
	border-radius: 8px;
	display: flex;
	gap: 14px;
	margin-bottom: 20px;
	padding: 18px 22px;
}

.academic-calendar__setup-notice > .material-icons {
	color: #b54708;
	font-size: 28px;
}

.academic-calendar__setup-notice h2 {
	font-size: 20.5px;
	font-weight: 900;
	margin: 0 0 5px;
}

.academic-calendar__setup-notice p {
	font-size: 17.5px;
	margin: 0;
}

.academic-calendar__summary {
	align-items: center;
	display: grid;
	gap: 24px;
	grid-template-columns: minmax(300px, 1.1fr) minmax(0, 2fr);
	margin-bottom: 20px;
	padding: 24px;
}

.academic-calendar__term {
	align-items: flex-start;
	display: flex;
	gap: 14px;
}

.academic-calendar__term > .material-icons {
	color: var(--academic-orange);
	font-size: 31.5px;
}

.academic-calendar__term h2,
.academic-calendar__panel > h2 {
	font-size: 25.5px;
	font-weight: 900;
	line-height: 1.25;
	margin: 0;
}

.academic-calendar__term h2 {
	color: var(--academic-orange);
}

.academic-calendar__term p {
	font-size: 17.5px;
	margin: 8px 0 0;
}

.academic-calendar__summary dl {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin: 0;
}

.academic-calendar__summary dl > div {
	border-left: 1px solid var(--academic-border);
	min-height: 76px;
	padding: 0 18px;
	text-align: center;
}

.academic-calendar__summary dt {
	font-size: 15.5px;
	font-weight: 700;
}

.academic-calendar__summary dd {
	font-size: 31.5px;
	font-weight: 900;
	line-height: 1.1;
	margin: 5px 0 0;
}

.academic-calendar__summary dd.academic-calendar__date-value {
	font-size: 18.5px;
	padding-top: 8px;
}

.academic-calendar__summary small {
	font-size: 15.5px;
}

.academic-calendar__layout {
	align-items: start;
	display: grid;
	gap: 20px;
	grid-template-columns: minmax(0, 2.15fr) minmax(280px, 1fr);
}

.academic-calendar__main,
.academic-calendar__aside {
	display: grid;
	gap: 20px;
}

.academic-calendar__panel {
	padding: 26px;
}

.academic-calendar__panel > h2 {
	align-items: center;
	display: flex;
	gap: 12px;
	margin-bottom: 22px;
}

.academic-calendar__panel > h2 .material-icons {
	font-size: 28px;
}

.academic-timeline__list {
	position: relative;
}

.academic-timeline__list::before {
	background: #e4e7ec;
	bottom: 32px;
	content: '';
	left: 18px;
	position: absolute;
	top: 24px;
	width: 2px;
}

.academic-timeline__item {
	align-items: center;
	display: grid;
	gap: 18px;
	grid-template-columns: 48px minmax(0, 1fr) minmax(145px, auto);
	min-height: 88px;
	position: relative;
}

.academic-timeline__marker {
	align-items: center;
	background: var(--tone, var(--academic-orange));
	border: 6px solid #fff;
	border-radius: 50%;
	color: #fff;
	display: flex;
	height: 48px;
	justify-content: center;
	position: relative;
	width: 48px;
	z-index: 1;
}

.academic-timeline__marker .material-icons {
	font-size: 25px;
}

.academic-timeline__item h3 {
	font-size: 20.5px;
	font-weight: 900;
	line-height: 1.3;
	margin: 0 0 4px;
}

.academic-timeline__item p {
	font-size: 17.5px;
	line-height: 1.45;
	margin: 0;
}

.academic-timeline__item time {
	background: var(--tone-soft, #fff1e8);
	border-radius: 8px;
	color: var(--tone-dark, var(--academic-orange-dark));
	font-size: 16.5px;
	font-weight: 800;
	padding: 13px 12px;
	text-align: center;
}

.academic-tone-registration { --tone: #f79009; --tone-soft: #fff4e5; --tone-dark: #b54708; }
.academic-tone-semester { --tone: #f15a24; --tone-soft: #fff1e8; --tone-dark: #c63f0d; }
.academic-tone-add-drop { --tone: #ed6c02; --tone-soft: #fff4dd; --tone-dark: #b54708; }
.academic-tone-withdraw { --tone: #1976d2; --tone-soft: #eaf3ff; --tone-dark: #175cd3; }
.academic-tone-exam { --tone: #7f56d9; --tone-soft: #f2edff; --tone-dark: #6941c6; }
.academic-tone-result { --tone: #f04438; --tone-soft: #fff0ee; --tone-dark: #d92d20; }
.academic-tone-holiday { --tone: #667085; --tone-soft: #f2f4f7; --tone-dark: #344054; }
.academic-tone-payment { --tone: #fdb022; --tone-soft: #fffaeb; --tone-dark: #b54708; }
.academic-tone-graduation { --tone: #e31b54; --tone-soft: #fff1f3; --tone-dark: #c01048; }
.academic-tone-internship { --tone: #0e9384; --tone-soft: #e6f9f5; --tone-dark: #087443; }
.academic-tone-evaluation { --tone: #0ba5ec; --tone-soft: #eaf8ff; --tone-dark: #026aa2; }
.academic-tone-advising { --tone: #65a30d; --tone-soft: #f3fbe8; --tone-dark: #3f6212; }
.academic-tone-petition { --tone: #9333ea; --tone-soft: #f7efff; --tone-dark: #7e22ce; }
.academic-tone-other { --tone: #98a2b3; --tone-soft: #f2f4f7; --tone-dark: #475467; }

.academic-calendar__status-box {
	background: linear-gradient(145deg, #f5fbf6, #eef8f0);
	border-radius: 8px;
	padding: 22px;
	text-align: center;
}

.academic-calendar__status-box time,
.academic-calendar__status-box strong,
.academic-calendar__status-box p,
.academic-calendar__status-box small {
	display: block;
}

.academic-calendar__status-box time,
.academic-calendar__status-box p,
.academic-calendar__status-box small {
	font-size: 15.5px;
}

.academic-calendar__status-box strong {
	border-bottom: 1px solid #d9e8dc;
	color: #17803d;
	font-size: 18.5px;
	margin: 14px 0;
	padding-bottom: 14px;
}

.academic-calendar__status-box h3 {
	font-size: 20.5px;
	font-weight: 900;
	margin: 6px 0;
}

.academic-calendar__status-box b {
	color: #17803d;
	display: inline-block;
	font-size: 45.5px;
	line-height: 1;
	margin-top: 10px;
}

.academic-calendar__downloads > a {
	align-items: center;
	border: 1px solid var(--academic-border);
	border-radius: 8px;
	color: var(--academic-ink) !important;
	display: grid;
	gap: 12px;
	grid-template-columns: 46px minmax(0, 1fr) 24px;
	margin-top: 10px;
	padding: 14px;
	text-decoration: none;
}

.academic-calendar__downloads > a:hover {
	border-color: var(--academic-orange);
}

.academic-calendar__file-icon {
	align-items: center;
	background: #fee4e2;
	border-radius: 6px;
	color: #d92d20;
	display: flex;
	font-size: 13.5px;
	font-weight: 900;
	height: 46px;
	justify-content: center;
}

.academic-calendar__file-icon--excel {
	background: #dcfae6;
	color: #087443;
	font-size: 11px;
}

.academic-calendar__downloads strong,
.academic-calendar__downloads small {
	display: block;
}

.academic-calendar__downloads strong {
	font-size: 17.5px;
	line-height: 1.35;
}

.academic-calendar__downloads small {
	color: var(--academic-muted);
	font-size: 15.5px;
	margin-top: 3px;
}

.academic-calendar__faq-item + .academic-calendar__faq-item {
	border-top: 1px solid var(--academic-border);
}

.academic-calendar__faq-item button {
	align-items: center;
	background: transparent;
	border: 0;
	color: var(--academic-ink);
	display: flex;
	font-size: 17.5px;
	font-weight: 700;
	justify-content: space-between;
	min-height: 50px;
	padding: 10px 0;
	text-align: left;
	width: 100%;
}

.academic-calendar__faq-item button .material-icons {
	transition: transform .2s ease;
}

.academic-calendar__faq-item button[aria-expanded='true'] .material-icons {
	transform: rotate(90deg);
}

.academic-calendar__faq-item > div {
	color: #475467;
	font-size: 16.5px;
	line-height: 1.5;
	padding: 0 0 16px;
}

.academic-calendar__category-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 18px;
}

.academic-calendar__category-filters button {
	border-radius: 8px;
	font-size: 15.5px;
	min-height: 40px;
	padding: 7px 14px;
}

.academic-calendar__table-wrap {
	overflow-x: auto;
}

.academic-calendar__schedule table {
	border-collapse: collapse;
	font-size: 16.5px;
	width: 100%;
}

.academic-calendar__schedule th {
	background: #fff1e8;
	font-size: 15.5px;
	font-weight: 900;
	text-align: left;
}

.academic-calendar__schedule th,
.academic-calendar__schedule td {
	border-bottom: 1px solid var(--academic-border);
	padding: 13px 12px;
	vertical-align: top;
}

.academic-calendar__schedule td strong,
.academic-calendar__schedule td small {
	display: block;
}

.academic-calendar__schedule td small {
	color: var(--academic-muted);
	font-size: 15.5px;
	line-height: 1.4;
	margin-top: 3px;
}

.academic-calendar__badge {
	background: var(--tone-soft, #f2f4f7);
	border-radius: 6px;
	color: var(--tone-dark, #344054);
	display: inline-block;
	font-size: 13.5px;
	font-weight: 800;
	padding: 5px 9px;
}

.academic-calendar__empty {
	background: var(--academic-soft);
	color: var(--academic-muted);
	margin: 16px 0 0;
	padding: 24px;
	text-align: center;
}

.academic-calendar__note {
	align-items: center;
	color: #475467;
	display: flex;
	font-size: 15.5px;
	justify-content: space-between;
	padding-top: 24px;
}

.academic-calendar__note p {
	margin: 0;
}

.kmutt-academic-calendar [hidden] {
	display: none !important;
}

.kmutt-academic-calendar.is-compact .academic-timeline__item p,
.kmutt-academic-calendar.is-compact .academic-calendar__schedule td small {
	display: none;
}

.kmutt-academic-calendar.is-compact .academic-timeline__item {
	min-height: 68px;
}

@media (max-width: 991px) {
	.academic-calendar__hero {
		grid-template-columns: minmax(0, 1fr) 180px;
	}

	.academic-calendar__hero-art {
		height: 120px;
	}

	.academic-calendar__hero-art .material-icons:first-child {
		font-size: 88px;
	}

	.academic-calendar__filters {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.academic-calendar__summary {
		grid-template-columns: 1fr;
	}

	.academic-calendar__summary dl > div:first-child {
		border-left: 0;
	}

	.academic-calendar__layout {
		grid-template-columns: 1fr;
	}

	.academic-calendar__aside {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.academic-calendar__faq {
		grid-column: 1 / -1;
	}
}

@media (max-width: 767px) {
	.kmutt-academic-calendar {
		font-size: 17.5px;
	}

	.academic-calendar__breadcrumb {
		padding: 16px 0;
	}

	.academic-calendar__hero {
		display: block;
		min-height: 0;
		padding: 12px 0 22px;
	}

	.academic-calendar__hero h1 {
		font-size: 38px;
	}

	.academic-calendar__hero p {
		font-size: 20.5px;
	}

	.academic-calendar__hero-art {
		display: none;
	}

	.academic-calendar__filters {
		gap: 16px;
		grid-template-columns: 1fr;
	}

	.academic-calendar__segments {
		display: grid;
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.academic-calendar__segments button {
		padding: 7px;
	}

	.academic-calendar__summary,
	.academic-calendar__panel {
		padding: 20px;
	}

	.academic-calendar__summary dl {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.academic-calendar__summary dl > div {
		border-bottom: 1px solid var(--academic-border);
		padding: 14px 8px;
	}

	.academic-calendar__summary dl > div:nth-child(odd) {
		border-left: 0;
	}

	.academic-calendar__term h2,
	.academic-calendar__panel > h2 {
		font-size: 23.5px;
	}

	.academic-timeline__item {
		align-items: start;
		gap: 12px;
		grid-template-columns: 46px minmax(0, 1fr);
		padding: 9px 0;
	}

	.academic-timeline__item time {
		grid-column: 2;
		justify-self: start;
	}

	.academic-calendar__aside {
		grid-template-columns: 1fr;
	}

	.academic-calendar__faq {
		grid-column: auto;
	}

	.academic-calendar__table-wrap {
		overflow: visible;
	}

	.academic-calendar__schedule thead {
		display: none;
	}

	.academic-calendar__schedule table,
	.academic-calendar__schedule tbody,
	.academic-calendar__schedule tr,
	.academic-calendar__schedule td {
		display: block;
		width: 100%;
	}

	.academic-calendar__schedule tr {
		border: 1px solid var(--academic-border);
		border-radius: 8px;
		margin-bottom: 12px;
		padding: 10px 14px;
	}

	.academic-calendar__schedule td {
		border: 0;
		display: grid;
		gap: 12px;
		grid-template-columns: 92px minmax(0, 1fr);
		padding: 7px 0;
	}

	.academic-calendar__schedule td::before {
		color: var(--academic-muted);
		content: attr(data-label);
		font-size: 15.5px;
		font-weight: 800;
	}

	.academic-calendar__note {
		align-items: flex-start;
		flex-direction: column;
		gap: 8px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.kmutt-academic-calendar *,
	.kmutt-academic-calendar *::before,
	.kmutt-academic-calendar *::after {
		scroll-behavior: auto !important;
		transition: none !important;
	}
}
