/* TutorStarter Child: Tutor LMS frontend dashboard custom skin */

body .tutor-frontend-dashboard {
	/* Pull colors from TutorStarter Customizer (Colors Settings) */
	--kb-body-bg: var(--body-bg-color, #f6f7fb);
	--kb-body-text: var(--body-text-color, #0f172a);
	--kb-primary: var(--link-color, #1950d1);
	/* For learner UI, use Inter (body font) everywhere to avoid extra font swap */
	--heading-font: var(--body-font, inherit);

	/* Spacing scale (used across custom dashboard UI) */
	--kb-space-1: 8px;
	--kb-space-2: 12px;
	--kb-space-3: 16px;
	--kb-space-4: 20px;
	--kb-space-5: 24px;
	--kb-space-6: 32px;

	/* Sticky offsets */
	--kb-header-offset: 0px;
	--kb-sticky-top: calc(var(--kb-space-5) + var(--kb-header-offset));

	background: var(--kb-body-bg);
	color: var(--kb-body-text);
	font-family: var(--body-font, inherit);
	font-size: var(--body-font-size, 16px);
	line-height: var(--body-font-lineheight, 1.7em);
	font-weight: var(--body-font-weight, 400);

	/* Align Tutor LMS CSS variables with theme colors (dashboard scope only) */
	--tutor-body-color: var(--kb-body-text);
	--tutor-color-primary: var(--kb-primary);
}

/* Account for WP Admin Bar when logged in */
body.admin-bar .tutor-frontend-dashboard {
	--kb-admin-bar: var(--wp-admin--admin-bar--height, 32px);
	--kb-sticky-top: calc(var(--kb-space-5) + var(--kb-header-offset) + var(--kb-admin-bar));
}

body .tutor-frontend-dashboard .tutor-container {
	max-width: 1320px;
}

/* Make dashboard chrome feel more "app-like" */
body .tutor-frontend-dashboard .tutor-dashboard-content {
	background: transparent;
}

/* Optional: hide site header/footer on dashboard (app-like) */
body.tutor-frontend-dashboard header,
body.tutor-frontend-dashboard footer {
	display: none !important;
}

body .tutor-frontend-dashboard .tutor-frontend-dashboard-header {
	margin-bottom: var(--kb-space-4);
	display: none !important;
}

/* Hide Tutor Pro Notifications bell button (we show items under Calendar instead) */
body .tutor-frontend-dashboard .btn-offcanvas-open.tutor-iconic-btn {
	display: none !important;
}

/* Hide Tutor mobile footer menu (we use topbar hamburger) */
body .tutor-frontend-dashboard #tutor-dashboard-footer-mobile {
	display: none !important;
}

/* Remove Tutor LMS decorative lines (pseudo elements) */
body .tutor-dashboard .tutor-frontend-dashboard-header::after,
body .tutor-dashboard .tutor-frontend-dashboard-maincontent ul.tutor-dashboard-permalinks::before,
body .tutor-dashboard-permalinks::before,
body .tutor-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks a::before {
	content: none !important;
	display: none !important;
}

/* Left menu panel */
body .tutor-frontend-dashboard .tutor-dashboard-left-menu {
	position: sticky;
	top: var(--kb-sticky-top);
	align-self: flex-start;
}

body .tutor-frontend-dashboard .tutor-dashboard-left-menu > ul {
	background: #fff;
	border-radius: 18px;
	box-shadow: 0 10px 30px rgba(20, 20, 43, 0.06);
	padding: 20px 10px;
	max-height: calc(100vh - var(--kb-sticky-top) - var(--kb-space-5));
	overflow: auto;
	overscroll-behavior: contain;
	-webkit-overflow-scrolling: touch;
}

body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks {
	margin: 0 10px;
	padding: 12px 0;
	display: grid;
	gap: 4px;
}

body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-menu-item-link {
	border-radius: 14px;
	padding: 11px 14px;
	display: flex;
	align-items: center;
	gap: 12px;
	min-height: 48px;
	color: var(--kb-body-text);
}

body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-menu-item-link:hover {
	background: transparent;
	color: inherit;
}

/* Hard-disable any hover/active background from Tutor's own stylesheet */
body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks li a:hover,
body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks li a:focus,
body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks li a:active {
	background: transparent !important;
	box-shadow: none !important;
	filter: none !important;
}

body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks li:not(.active) a:hover,
body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks li:not(.active) a:focus {
	color: var(--kb-body-text) !important;
}

body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks li.active a:hover,
body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks li.active a:focus {
	color: var(--kb-primary) !important;
}

body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-menu-item.active .tutor-dashboard-menu-item-link {
	background: transparent;
	color: var(--kb-primary);
	font-weight: 700;
}

body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-menu-item-text {
	margin-left: 0 !important;
	line-height: 1.3;
}

body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-menu-item-icon {
	width: 30px;
	height: 30px;
	border-radius: 10px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 30px;
	background: rgba(15, 23, 42, 0.05);
	font-size: 18px;
}

body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-menu-divider {
	margin: 10px 14px;
	opacity: 0.25;
}

/* Our custom dashboard layout */
.kb-tutor-dashboard {
	margin-top: 6px;
}

.kb-td-topbar {
	display: grid;
	grid-template-columns: 1fr minmax(280px, 520px);
	gap: var(--kb-space-4);
	align-items: center;
	margin-bottom: var(--kb-space-5);
}

.kb-td-topbar__actions {
	display: flex;
	align-items: center;
	gap: 10px;
}

.kb-td-menu-toggle {
	display: none;
	width: 44px;
	height: 44px;
	border-radius: 12px;
	border: 1px solid rgba(15, 23, 42, 0.10);
	background: #fff;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 4px;
	cursor: pointer;
	box-shadow: 0 8px 24px rgba(20, 20, 43, 0.04);
	position: relative;
}

.kb-td-menu-toggle > span {
	width: 16px;
	height: 2px;
	border-radius: 99px;
	background: var(--kb-body-text);
	opacity: 0.85;
	display: block;
	transition: transform 0.2s ease, opacity 0.2s ease;
	transform-origin: center;
}

.kb-td-menu-close {
	display: none;
}

.kb-td-menu-close-item {
	display: none;
}

body.kb-td-menu-open .kb-td-menu-toggle > span:nth-child(1) {
	transform: translateY(6px) rotate(45deg);
}

body.kb-td-menu-open .kb-td-menu-toggle > span:nth-child(2) {
	opacity: 0;
}

body.kb-td-menu-open .kb-td-menu-toggle > span:nth-child(3) {
	transform: translateY(-6px) rotate(-45deg);
}

.kb-td-greeting__hello {
	color: var(--kb-body-text);
	opacity: 0.6;
	font-size: 0.875em;
	line-height: var(--body-font-lineheight, 1.7em);
}

.kb-td-greeting__name {
	color: var(--kb-body-text);
	font-family: var(--heading-font, var(--body-font, inherit));
	font-weight: var(--h4-font-weight, 700);
	font-size: var(--h4-font-size, 26px);
	line-height: var(--h4-font-lineheight, 1.7em);
	margin-top: 2px;
}

.kb-td-search {
	position: relative;
	flex: 1 1 auto;
}

.kb-td-search__input {
	width: 100%;
	height: 48px;
	border-radius: 16px;
	border: 1px solid rgba(15, 23, 42, 0.10);
	background: #fff;
	box-shadow: 0 10px 30px rgba(20, 20, 43, 0.04);
	padding: 0 46px 0 var(--kb-space-3);
	outline: none;
}

.kb-td-search__input:focus {
	border-color: var(--kb-primary);
	box-shadow: 0 10px 30px rgba(20, 20, 43, 0.05), 0 0 0 4px rgba(0, 0, 0, 0.06);
}

.kb-td-search__btn {
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	width: 34px;
	height: 34px;
	border-radius: 12px;
	border: 0;
	background: rgba(15, 23, 42, 0.06);
	cursor: pointer;
}

.kb-td-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 360px;
	gap: var(--kb-space-5);
}

.kb-td-main {
	min-width: 0;
	display: grid;
	gap: var(--kb-space-5);
	align-content: start;
}
.kb-td-aside {
	min-width: 0;
}

.kb-td-section__head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
	margin: 0 0 var(--kb-space-3);
}

.kb-td-section__title {
	font-family: var(--heading-font, var(--body-font, inherit));
	font-weight: var(--h5-font-weight, 700);
	color: var(--kb-body-text);
	font-size: var(--h5-font-size, 20px);
	line-height: var(--h5-font-lineheight, 1.6em);
}

.kb-td-section__link {
	color: var(--kb-primary);
	text-decoration: none;
	font-weight: 600;
	font-size: 13px;
}

.kb-td-card {
	background: #fff;
	border-radius: 18px;
	box-shadow: 0 10px 30px rgba(20, 20, 43, 0.06);
	border: 1px solid rgba(15, 23, 42, 0.06);
}

.kb-td-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 40px;
	padding: 0 16px;
	border-radius: 14px;
	font-weight: 700;
	text-decoration: none;
}

.kb-td-btn--primary {
	background: var(--kb-primary);
	color: #fff;
}

.kb-td-btn--primary:hover {
	filter: brightness(1.05);
	color: #fff;
}

/* Featured card */
.kb-td-featured-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--kb-space-1);
	align-items: stretch;
}

.kb-td-featured-card {
	overflow: hidden;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.kb-td-featured-card__media {
	display: block;
	position: relative;
	aspect-ratio: 16 / 9;
	background: #fff;
	padding: var(--kb-space-1);
	box-sizing: border-box;
}

.kb-td-featured-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	border-radius: 8px;
}

.kb-td-chip {
	position: absolute;
	top: 12px;
	left: 12px;
	background: rgba(255, 255, 255, 0.88);
	backdrop-filter: blur(8px);
	border-radius: 999px;
	padding: 6px 10px;
	font-size: 12px;
	font-weight: 700;
	color: var(--kb-body-text);
}

.kb-td-featured-card__body {
	padding: var(--kb-space-1);
	display: flex;
	flex-direction: column;
	flex: 1;
}

.kb-td-featured-card__title {
	font-size: 12px;
	font-weight: 700;
	line-height: 1.2;
	color: var(--kb-body-text);
	margin-bottom: var(--kb-space-2);
}

.kb-td-featured-card__title a {
	color: inherit;
	text-decoration: none;
}

.kb-td-featured-card__price {
	font-weight: 700;
	font-size: 12px;
	line-height: 1.1;
	color: var(--kb-body-text);
	margin: 2px 0 var(--kb-space-3);
}

.kb-td-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 4px;
}

.kb-td-featured-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: auto;
}

.kb-td-instructor {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

.kb-td-featured-card--program .kb-td-featured-card__footer {
	flex-direction: column;
	align-items: stretch;
}

.kb-td-featured-card--program .kb-td-featured-card__footer .kb-td-instructor {
	justify-content: flex-start;
}

.kb-td-featured-card--program .kb-td-featured-card__footer .kb-td-btn--primary {
	width: 100%;
	height: 38px;
	font-size: 10px;
	letter-spacing: 0.2px;
	border-radius: 12px;
	line-height: 1.1;
	background: #f00069;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	text-transform: uppercase;
}

.kb-td-featured-card--program .kb-td-featured-card__footer .kb-td-btn--primary:hover {
	filter: brightness(1.02);
	color: #fff;
}

.kb-td-instructor__avatar img,
.kb-td-instructor__avatar .tutor-avatar {
	border-radius: 999px !important;
}

.kb-td-avatar-fallback {
	width: 28px;
	height: 28px;
	border-radius: 999px;
	display: inline-grid;
	place-items: center;
	background: rgba(15, 23, 42, 0.10);
	color: var(--kb-body-text);
	font-weight: 700;
	font-size: 12px;
}

.kb-td-instructor__name {
	color: var(--kb-body-text);
	font-weight: 700;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 180px;
}

/* List */
.kb-td-list {
	display: grid;
	gap: var(--kb-space-3);
}

.kb-td-list-item {
	display: grid;
	grid-template-columns: 74px minmax(0, 1fr) 40px;
	align-items: center;
	gap: 12px;
	padding: var(--kb-space-1) var(--kb-space-1);
}

.kb-td-list-item__thumb img {
	width: 74px;
	height: 56px;
	border-radius: 8px;
	object-fit: cover;
	display: block;
}

.kb-td-list-item__title {
	font-weight: 700;
	color: var(--kb-body-text);
	font-size: 14px;
	margin-bottom: 8px;
}

.kb-td-list-item__title a {
	color: inherit;
	text-decoration: none;
}

.kb-td-progress {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 10px;
	align-items: center;
}

.kb-td-progress__bar {
	height: 10px;
	border-radius: 999px;
	background: rgba(15, 23, 42, 0.06);
	overflow: hidden;
}

.kb-td-progress__fill {
	display: block;
	height: 100%;
	width: var(--kb-progress, 0%);
	background: var(--kb-primary);
	border-radius: 999px;
}

.kb-td-progress__pct {
	color: var(--kb-body-text);
	opacity: 0.65;
	font-weight: 700;
	font-size: 12px;
}

.kb-td-list-item__chev {
	width: 36px;
	height: 36px;
	border-radius: 14px;
	background: rgba(15, 23, 42, 0.05);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	color: var(--kb-body-text);
}

/* Aside panels */
.kb-td-panel {
	padding: var(--kb-space-4);
}

/* Tutor Pro Calendar widget (dashboard home embed) */
.kb-td-panel--calendar {
	padding: var(--kb-space-3);
}
.kb-td-panel--calendar #tutor_calendar_wrapper {
	background: transparent !important;
}
.kb-td-panel--calendar .kb-td-panel__head {
	margin-bottom: 10px;
}
.kb-td-panel--calendar .kb-td-panel__day {
	font-size: 14px;
}
.kb-td-panel--calendar .kb-td-panel__date {
	font-size: 13px;
}

.kb-td-panel--calendar .kb-td-calendar-embed {
	/* Calendar addon includes its own paddings; keep embed block flush */
}

.kb-td-panel--calendar .tutor-fs-5.tutor-fw-medium.tutor-color-black.tutor-mb-16 {
	display: none !important; /* Hide "Calendar" heading from addon */
}

.kb-td-panel--calendar #tutor_calendar_wrapper {
	min-height: 0;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-sticky-wrapper {
	margin-bottom: var(--kb-space-3);
	height: auto !important;
	width: auto !important;
	border: 0 !important;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-wrapper {
	position: static !important;
	top: auto !important;
	left: auto !important;
	width: 100% !important;
	margin-bottom: var(--kb-space-3);
	padding: var(--kb-space-3) var(--kb-space-3) var(--kb-space-3);
	box-shadow: none !important;
	border: 0 !important;
	background: transparent !important;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-wrapper.is-sticky {
	position: static !important;
}
.kb-td-panel--calendar .tutor-calendar-wrapper {
	border-radius: 16px;
	border-color: rgba(15, 23, 42, 0.08);
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-top {
	margin-bottom: 14px;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-dropdown .tutor-calendar-dropdown-label {
	font-size: 14px;
	font-weight: 700;
	padding: 8px 10px;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-custom-calendar {
	row-gap: 14px;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-custom-calendar .tutor-calendar-heading,
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-custom-calendar .tutor-calendar-body {
	display: grid !important;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	gap: 8px;
	justify-content: initial !important;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-custom-calendar .tutor-calendar-heading > div {
	width: auto !important;
	margin: 0 !important;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-custom-calendar .tutor-calendar-body > div {
	width: auto !important;
	margin: 0 !important;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-custom-calendar .tutor-calendar-heading > div:nth-child(n+8) {
	display: none !important;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-custom-calendar .tutor-calendar-body .space {
	display: none !important;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-custom-calendar .tutor-calendar-date a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	margin: 0 auto;
	border-radius: 999px;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-custom-calendar .tutor-calendar-heading > div {
	color: var(--kb-body-text);
	opacity: 0.55;
	font-weight: 700;
	font-size: 12px;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-custom-calendar .tutor-calendar-body > div {
	font-size: 13px;
	font-weight: 700;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-date.today a {
	background: var(--kb-primary);
	color: #fff;
	border-radius: 999px;
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.kb-td-panel--calendar .tutor-calendar-events-wrapper {
	border-radius: 16px;
	border-color: rgba(15, 23, 42, 0.08);
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-events-wrapper {
	overflow: hidden;
	box-shadow: none !important;
	border: 0 !important;
	background: transparent !important;
}

/* Spacing between sidebar cards */
.kb-td-aside {
	display: grid;
	gap: var(--kb-space-4);
	align-content: start;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-events-wrapper .tutor-empty-state {
	padding: 14px !important;
}
.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-events-wrapper .tutor-empty-state img {
	max-width: 220px;
	width: 100%;
}
.kb-td-panel--calendar .tutor-calendar-dropdown .tutor-calendar-dropdown-label {
	border-radius: 12px;
}

/* Upcoming list under calendar */
.kb-td-upcoming {
	margin-top: var(--kb-space-3);
	padding-top: var(--kb-space-3);
	border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.kb-td-upcoming__head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 10px;
}

.kb-td-upcoming__title {
	font-weight: 700;
	font-size: 16px;
	color: var(--kb-body-text);
}

.kb-td-upcoming__link {
	color: var(--kb-primary);
	font-weight: 700;
	font-size: 13px;
	text-decoration: none;
}

.kb-td-upcoming__list {
	display: grid;
	gap: 10px;
}

.kb-td-upcoming__item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 12px;
	border-radius: 14px;
	background: #fff;
	border: 1px solid rgba(15, 23, 42, 0.08);
}

.kb-td-upcoming__item-title {
	font-weight: 700;
	font-size: 13px;
	color: var(--kb-body-text);
}

.kb-td-upcoming__item-title a {
	color: inherit;
	text-decoration: none;
}

.kb-td-upcoming__item-when {
	margin-top: 2px;
	font-size: 12px;
	color: var(--kb-body-text);
	opacity: 0.6;
}

.kb-td-upcoming__dot {
	width: 10px;
	height: 10px;
	border-radius: 999px;
	background: var(--kb-primary);
	flex: none;
}

.kb-td-upcoming__empty {
	padding: 10px 12px;
	border-radius: 14px;
	background: #fff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	color: var(--kb-body-text);
	opacity: 0.65;
	font-weight: 700;
	font-size: 13px;
}

.kb-td-panel__head {
	margin-bottom: 12px;
}

.kb-td-panel__head--row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}

.kb-td-panel__day {
	font-weight: 700;
	color: var(--kb-body-text);
}

.kb-td-panel__date {
	color: var(--kb-body-text);
	opacity: 0.65;
	font-size: 13px;
	margin-top: 2px;
}

.kb-td-panel__title {
	font-weight: 700;
	color: var(--kb-body-text);
}

.kb-td-panel__pill {
	font-size: 12px;
	font-weight: 700;
	color: var(--kb-body-text);
	background: rgba(15, 23, 42, 0.06);
	border-radius: 999px;
	padding: 6px 10px;
}

/* Calendar */
.kb-td-calendar__title {
	text-align: center;
	font-weight: 700;
	margin-bottom: 10px;
	color: var(--kb-body-text);
}

.kb-td-calendar__dow {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 8px;
	color: var(--kb-body-text);
	opacity: 0.55;
	font-weight: 700;
	font-size: 12px;
	text-align: center;
	margin-bottom: 10px;
}

.kb-td-calendar__grid {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 8px;
}

.kb-td-calendar__cell {
	height: 34px;
	display: grid;
	place-items: center;
	border-radius: 999px;
	color: var(--kb-body-text);
	font-weight: 700;
	font-size: 12px;
}

.kb-td-calendar__cell--empty {
	opacity: 0;
}

.kb-td-calendar__cell--today {
	background: var(--kb-primary);
	color: #fff;
}

@supports (color: color-mix(in oklab, white, black)) {
	.kb-td-search__input:focus {
		box-shadow: 0 10px 30px rgba(20, 20, 43, 0.05), 0 0 0 4px color-mix(in oklab, var(--kb-primary), transparent 86%);
	}

	.kb-td-progress__fill {
		background: linear-gradient(90deg, color-mix(in oklab, var(--kb-primary), #fff 35%), var(--kb-primary));
	}

	.kb-td-calendar__cell--today {
		background: color-mix(in oklab, var(--kb-primary), #fff 70%);
		color: var(--kb-body-text);
	}

	.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-date.today a {
		background: color-mix(in oklab, var(--kb-primary), #fff 70%);
		color: var(--kb-body-text);
	}

	.kb-td-panel__pill {
		background: color-mix(in oklab, var(--kb-primary), transparent 90%);
	}

	.kb-td-search__btn {
		background: color-mix(in oklab, var(--kb-primary), transparent 90%);
	}

	.kb-td-list-item__chev {
		background: color-mix(in oklab, var(--kb-primary), transparent 92%);
	}

	.kb-td-score {
		background: color-mix(in oklab, var(--kb-primary), #fff 92%);
		border-color: color-mix(in oklab, var(--kb-primary), transparent 75%);
	}

}

/* Gauge */
.kb-td-gauge {
	position: relative;
	height: 200px;
	display: grid;
	place-items: center;
	margin: 4px 0 8px;
}

.kb-td-gauge__ring {
	width: 190px;
	height: 190px;
	border-radius: 999px;
	background:
		conic-gradient(
			#10b981 calc(var(--kb-pct-completed, 0) * 1%),
			var(--kb-primary) 0 calc((var(--kb-pct-completed, 0) + var(--kb-pct-active, 0)) * 1%),
			#ef4444 0
		);
	-webkit-mask: radial-gradient(circle 68px at 50% 50%, transparent 0 68px, #000 69px);
	mask: radial-gradient(circle 68px at 50% 50%, transparent 0 68px, #000 69px);
}

.kb-td-gauge__center {
	position: absolute;
	text-align: center;
}

.kb-td-gauge__value {
	font-size: 44px;
	font-weight: 700;
	color: var(--kb-body-text);
	line-height: 1;
}

.kb-td-gauge__label {
	color: var(--kb-body-text);
	opacity: 0.65;
	font-weight: 700;
	margin-top: 6px;
}

.kb-td-legend {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
	font-size: 12px;
	color: var(--kb-body-text);
	opacity: 0.65;
	font-weight: 700;
}

.kb-td-legend__item {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	white-space: nowrap;
}

.kb-td-legend__dot {
	width: 10px;
	height: 10px;
	border-radius: 999px;
	display: inline-block;
}

.kb-td-legend__dot--remaining {
	background: #ef4444;
}

.kb-td-legend__dot--active {
	background: var(--kb-primary);
}

.kb-td-legend__dot--completed {
	background: #10b981;
}

/* Completed list */
.kb-td-list--compact {
	gap: 10px;
}

.kb-td-completed-item {
	display: grid;
	grid-template-columns: 58px minmax(0, 1fr) 80px;
	gap: 12px;
	align-items: center;
	padding: 10px 12px;
}

.kb-td-completed-item__thumb img {
	width: 58px;
	height: 44px;
	border-radius: 14px;
	object-fit: cover;
	display: block;
}

.kb-td-completed-item__title {
	font-weight: 700;
	color: var(--kb-body-text);
	font-size: 14px;
}

.kb-td-completed-item__title a {
	color: inherit;
	text-decoration: none;
}

.kb-td-completed-item__date {
	color: var(--kb-body-text);
	opacity: 0.6;
	font-size: 12px;
	margin-top: 2px;
}

.kb-td-score {
	border-radius: 16px;
	background: #fff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	padding: 8px 10px;
	text-align: center;
}

.kb-td-score__label {
	color: var(--kb-body-text);
	opacity: 0.65;
	font-weight: 700;
	font-size: 12px;
}

.kb-td-score__value {
	color: var(--kb-body-text);
	font-weight: 700;
	font-size: 22px;
	line-height: 1.1;
}

.kb-td-empty {
	padding: 14px;
}

@media (max-width: 1024px) {
	.kb-td-layout {
		grid-template-columns: 1fr;
	}
	.kb-td-topbar {
		grid-template-columns: 1fr;
	}
	.kb-td-featured-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.kb-td-featured-grid > *:nth-child(n + 3) {
		display: none !important;
	}
}

@media (max-width: 640px) {
	.kb-td-featured-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.kb-td-featured-card__media {
		aspect-ratio: 16 / 10;
	}
	.kb-td-list-item {
		grid-template-columns: 64px minmax(0, 1fr) 36px;
	}
	.kb-td-list-item__thumb img {
		width: 64px;
		height: 50px;
	}
}

/* Responsive layout polishing */
@media (max-width: 1280px) {
	body .tutor-frontend-dashboard .tutor-container {
		max-width: 100%;
		padding-left: 14px;
		padding-right: 14px;
	}

	.kb-td-layout {
		grid-template-columns: minmax(0, 1fr) 320px;
		gap: var(--kb-space-4);
	}
}

@media (max-width: 1024px) {
	body .tutor-frontend-dashboard .tutor-frontend-dashboard-maincontent {
		row-gap: var(--kb-space-3);
	}

	body .tutor-frontend-dashboard .tutor-frontend-dashboard-maincontent > .tutor-col-md-4.tutor-col-lg-3,
	body .tutor-frontend-dashboard .tutor-frontend-dashboard-maincontent > .tutor-col-md-8.tutor-col-lg-9 {
		flex: 0 0 100%;
		max-width: 100%;
	}

	/* Content first */
	body .tutor-frontend-dashboard .tutor-frontend-dashboard-maincontent > .tutor-col-md-8.tutor-col-lg-9 {
		order: 1;
	}

	/* Keep menu column in DOM for accessibility but hide layout slot */
	body .tutor-frontend-dashboard .tutor-frontend-dashboard-maincontent > .tutor-col-md-4.tutor-col-lg-3 {
		order: 2;
		flex: 0 0 100%;
		max-width: 100%;
	}

	.kb-td-menu-toggle {
		display: inline-flex;
		flex: 0 0 44px;
		position: relative;
		z-index: 10070;
	}

	body .tutor-frontend-dashboard .tutor-dashboard-left-menu {
		display: block !important;
		position: fixed;
		top: 0;
		left: 0;
		bottom: 0;
		width: min(340px, 86vw);
		max-width: min(340px, 86vw) !important;
		height: 100dvh !important;
		min-height: 100dvh !important;
		padding: 12px;
		margin-top: 0;
		z-index: 2147483000;
		transform: translateX(-105%);
		transition: transform 0.25s ease;
		background: transparent;
		overflow: hidden;
		visibility: hidden;
		opacity: 0;
		pointer-events: auto;
	}
	body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks .kb-td-menu-close-item {
		list-style: none;
		display: flex;
		justify-content: flex-end;
		margin: 8px 12px 8px;
	}
	body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks .kb-td-menu-close {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		position: static;
		margin: 0;
		width: 40px;
		height: 40px;
		border: 0;
		border-radius: 0;
		background: transparent;
		color: var(--kb-body-text);
		font-size: 32px;
		line-height: 1;
		cursor: pointer;
		z-index: 2;
	}

	body.admin-bar .tutor-frontend-dashboard .tutor-dashboard-left-menu {
		top: var(--wp-admin--admin-bar--height, 32px);
		height: calc(100dvh - var(--wp-admin--admin-bar--height, 32px)) !important;
		min-height: calc(100dvh - var(--wp-admin--admin-bar--height, 32px)) !important;
		bottom: auto;
	}

	body .tutor-frontend-dashboard.kb-td-menu-open .tutor-dashboard-left-menu {
		transform: translateX(0);
		visibility: visible;
		opacity: 1;
	}
	body .tutor-dashboard.is-sidebar-expanded .tutor-dashboard-left-menu {
		transform: translateX(0);
		visibility: visible;
		opacity: 1;
	}
	body .tutor-frontend-dashboard .tutor-dashboard-left-menu.kb-open {
		transform: translateX(0) !important;
		visibility: visible !important;
		opacity: 1 !important;
	}
	body.kb-td-menu-open .tutor-frontend-dashboard .tutor-dashboard-left-menu {
		transform: translateX(0);
		visibility: visible;
		opacity: 1;
	}

	body .tutor-frontend-dashboard .tutor-dashboard-left-menu > ul {
		display: block;
		overflow: auto;
		max-height: none;
		white-space: normal;
		height: 100%;
		padding-top: 8px;
	}

	body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-menu-item {
		flex: initial;
	}

	body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-menu-item-link {
		padding: 10px 12px;
		border-radius: 12px;
	}

	.kb-td-topbar {
		margin-bottom: var(--kb-space-4);
	}

	.kb-td-topbar__actions {
		width: 100%;
	}

	.kb-td-layout {
		grid-template-columns: 1fr;
	}

	.kb-td-aside {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: var(--kb-space-3);
	}

	.kb-td-panel--calendar {
		grid-column: 1 / -1;
	}

	body .tutor-frontend-dashboard::after {
		content: "";
		position: fixed;
		inset: 0;
		background: rgba(15, 23, 42, 0.34);
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.2s ease;
		z-index: 2147482900;
	}

	body .tutor-frontend-dashboard.kb-td-menu-open::after {
		opacity: 1;
		visibility: visible;
	}
	body.kb-td-menu-open .tutor-frontend-dashboard::after {
		opacity: 1;
		visibility: visible;
	}
}

@media (max-width: 767px) {
	body .tutor-frontend-dashboard .tutor-container {
		padding-left: 10px;
		padding-right: 10px;
	}

	body .tutor-frontend-dashboard .tutor-dashboard-left-menu {
		width: min(320px, 92vw) !important;
		max-width: min(320px, 92vw) !important;
		padding: 10px !important;
	}

	body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-permalinks .kb-td-menu-close-item {
		margin: 0 8px 6px;
	}

	body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-menu-item-link {
		min-height: 44px;
		padding: 9px 10px;
		border-radius: 10px;
	}

	body .tutor-frontend-dashboard .tutor-dashboard-left-menu .tutor-dashboard-menu-item-icon {
		width: 28px;
		height: 28px;
		flex: 0 0 28px;
		font-size: 17px;
	}

	.kb-td-topbar {
		gap: 10px;
	}

	.kb-td-greeting__name {
		font-size: 22px;
	}

	.kb-td-search__input {
		height: 44px;
		border-radius: 14px;
		padding-left: 14px;
	}

	.kb-td-main {
		gap: var(--kb-space-4);
	}

	.kb-td-section__head {
		margin-bottom: 10px;
	}

	.kb-td-card,
	.kb-td-panel,
	.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-wrapper,
	.kb-td-panel--calendar #tutor_calendar_wrapper .tutor-calendar-events-wrapper,
	.kb-td-upcoming__item {
		border-radius: 14px;
	}

	.kb-td-featured-card__body {
		padding: 10px;
	}

	.kb-td-featured-card__meta {
		display: flex;
		flex-wrap: wrap;
		gap: 6px 12px;
	}

	.kb-td-list-item {
		grid-template-columns: 58px minmax(0, 1fr) 34px;
		gap: 10px;
	}

	.kb-td-list-item__thumb img {
		width: 58px;
		height: 46px;
	}

	.kb-td-completed-item {
		grid-template-columns: 52px minmax(0, 1fr);
	}

	.kb-td-score {
		grid-column: 1 / -1;
	}

	.kb-td-aside {
		grid-template-columns: 1fr;
	}

	.kb-td-gauge {
		height: 176px;
	}

	.kb-td-gauge__ring {
		width: 168px;
		height: 168px;
		-webkit-mask: radial-gradient(circle 58px at 50% 50%, transparent 0 58px, #000 59px);
		mask: radial-gradient(circle 58px at 50% 50%, transparent 0 58px, #000 59px);
	}
}
