.hts-instructor {
	--hts-instructor-text: #121212;
	--hts-instructor-muted: #8d8c86;
	--hts-instructor-line: #ece8df;
	--hts-instructor-line-strong: #ded8ca;
	--hts-instructor-accent: #f3d400;
	--hts-instructor-shadow: 0 26px 60px rgba(24, 27, 33, 0.08);
	font-family: "Manrope", sans-serif;
	color: var(--hts-instructor-text);
	background:
		radial-gradient(circle at top right, rgba(243, 212, 0, 0.1), transparent 16%),
		linear-gradient(180deg, #f8f6f1 0%, #f4f2ed 100%);
}

.hts-instructor,
.hts-instructor * {
	box-sizing: border-box;
}

.hts-instructor button,
.hts-instructor a {
	font: inherit;
}

.hts-instructor__top-ribbon {
	padding: 10px 20px;
	background: #4f5155;
	color: #ffffff;
	font-size: 0.9rem;
	text-align: center;
}

.hts-instructor__site-header {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 22px;
	width: min(1280px, calc(100% - 40px));
	margin: 0 auto;
	padding: 18px 0 12px;
}

.hts-instructor__brand {
	color: var(--hts-instructor-text);
	font-family: "Sora", sans-serif;
	font-size: 1.95rem;
	font-weight: 700;
	text-decoration: none;
	letter-spacing: -0.05em;
}

.hts-instructor__main-nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 26px;
}

.hts-instructor__main-nav a,
.hts-instructor__header-cta {
	color: var(--hts-instructor-text);
	text-decoration: none;
	font-size: 0.98rem;
}

.hts-instructor__main-nav a.is-active {
	font-weight: 800;
}

.hts-instructor__header-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0 16px;
	border-radius: 999px;
	background: linear-gradient(135deg, #f8dd1d 0%, #efcb00 100%);
	font-weight: 800;
}

.hts-instructor__page-shell {
	width: min(1280px, calc(100% - 40px));
	margin: 0 auto 40px;
}

.hts-instructor__hero-panel {
	display: grid;
	grid-template-columns: 1fr 1.8fr 1fr;
	align-items: end;
	min-height: 320px;
	padding: 26px 0 0;
	overflow: hidden;
}

.hts-instructor__hero-quote {
	align-self: center;
	padding-right: 24px;
}

.hts-instructor__hero-quote p {
	max-width: 230px;
	margin: 0 auto;
	font-size: 1.05rem;
	line-height: 1.35;
	text-align: center;
}

.hts-instructor__hero-copy {
	position: relative;
	padding: 26px 0 42px;
	text-align: center;
}

.hts-instructor__hero-shadow-name {
	position: absolute;
	left: 50%;
	top: 0;
	transform: translateX(-50%);
	color: #ebe9e2;
	font-family: "Sora", sans-serif;
	font-size: clamp(5.5rem, 12vw, 9.5rem);
	font-weight: 700;
	line-height: 0.9;
	letter-spacing: -0.06em;
	pointer-events: none;
}

.hts-instructor__hero-tag,
.hts-instructor__hero-bio {
	position: relative;
	z-index: 1;
}

.hts-instructor__hero-tag {
	margin: 62px 0 8px;
	color: var(--hts-instructor-muted);
	font-size: 0.95rem;
	text-transform: uppercase;
	letter-spacing: 0.14em;
}

.hts-instructor__hero-copy h2 {
	position: relative;
	z-index: 1;
	margin: 0 0 12px;
	font-family: "Sora", sans-serif;
	font-size: clamp(2.8rem, 5vw, 4.2rem);
	font-weight: 700;
	letter-spacing: -0.05em;
}

.hts-instructor__hero-bio {
	max-width: 540px;
	margin: 0 auto;
	color: #4f4f4a;
	font-size: 1rem;
	line-height: 1.7;
}

.hts-instructor__hero-portrait {
	position: relative;
	min-height: 300px;
}

.hts-instructor__portrait-backdrop {
	position: absolute;
	right: -28px;
	bottom: -62px;
	width: 320px;
	height: 320px;
	border-radius: 50%;
	background:
		radial-gradient(circle at 40% 35%, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0) 36%),
		linear-gradient(135deg, #f1be9f 0%, #d8835f 30%, #3b2724 64%, #121212 100%);
	box-shadow: var(--hts-instructor-shadow);
}

.hts-instructor__portrait-core {
	position: absolute;
	right: 34px;
	bottom: 0;
	width: 250px;
	height: 250px;
	border-radius: 48% 52% 42% 58%;
	background:
		radial-gradient(circle at 58% 28%, rgba(255, 245, 236, 0.7), transparent 26%),
		linear-gradient(180deg, #3d2a27 0%, #171312 100%);
}

.hts-instructor__portrait-core::before {
	content: "";
	position: absolute;
	left: 68px;
	top: 46px;
	width: 110px;
	height: 130px;
	border-radius: 46% 46% 44% 44%;
	background: linear-gradient(180deg, #f7c5a8 0%, #d98f6a 100%);
}

.hts-instructor__portrait-core::after {
	content: "";
	position: absolute;
	left: 36px;
	top: 18px;
	width: 176px;
	height: 156px;
	border-radius: 50%;
	border-top: 30px solid #111111;
	border-left: 18px solid #111111;
	border-right: 18px solid #111111;
}

.hts-instructor__portrait-mark {
	position: absolute;
	right: -4px;
	bottom: 14px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: linear-gradient(135deg, #f8dd1d 0%, #efcb00 100%);
	color: #161616;
	font-family: "Sora", sans-serif;
	font-size: 1rem;
	font-weight: 700;
}

.hts-instructor__schedule-section {
	overflow: hidden;
	border: 1px solid var(--hts-instructor-line);
	border-radius: 24px;
	background: rgba(255, 255, 255, 0.84);
	box-shadow: var(--hts-instructor-shadow);
	backdrop-filter: blur(10px);
}

.hts-instructor__schedule-toolbar {
	display: grid;
	grid-template-columns: 52px 1fr 52px;
	align-items: center;
	padding: 18px 20px;
	border-bottom: 1px solid var(--hts-instructor-line);
}

.hts-instructor__week-label {
	margin: 0;
	text-align: center;
	font-size: 1.1rem;
	font-weight: 600;
}

.hts-instructor__week-nav {
	width: 40px;
	height: 40px;
	border: 1px solid var(--hts-instructor-line-strong);
	border-radius: 50%;
	background: #ffffff;
	color: var(--hts-instructor-text);
	font-size: 1.5rem;
	line-height: 1;
	cursor: pointer;
	transition: transform 0.16s ease, border-color 0.16s ease, background-color 0.16s ease;
}

.hts-instructor__week-nav:hover {
	transform: translateY(-1px);
	border-color: #cfc8b9;
	background: #faf8f2;
}

.hts-instructor__schedule-scroll {
	overflow-x: auto;
}

.hts-instructor__schedule-grid {
	display: grid;
	grid-template-columns: repeat(8, minmax(190px, 1fr));
	min-width: 1280px;
}

.hts-instructor__day-column {
	min-height: 420px;
	border-right: 1px solid var(--hts-instructor-line);
	background: rgba(255, 255, 255, 0.58);
}

.hts-instructor__day-column:last-child {
	border-right: 0;
}

.hts-instructor__day-head {
	display: block;
	width: 100%;
	padding: 18px 18px 16px;
	border: 0;
	border-bottom: 1px solid var(--hts-instructor-line);
	background: transparent;
	text-align: left;
	cursor: pointer;
}

.hts-instructor__day-head span {
	display: block;
}

.hts-instructor__day-name {
	margin-bottom: 8px;
	color: #b5b3ab;
	font-size: 0.92rem;
}

.hts-instructor__day-number {
	font-family: "Sora", sans-serif;
	font-size: 1.35rem;
	font-weight: 700;
}

.hts-instructor__day-column.is-selected .hts-instructor__day-head {
	position: relative;
}

.hts-instructor__day-column.is-selected .hts-instructor__day-head::after {
	content: "";
	position: absolute;
	left: 18px;
	bottom: 10px;
	width: 24px;
	height: 4px;
	border-radius: 999px;
	background: #2f2f2d;
}

.hts-instructor__day-column.is-selected .hts-instructor__day-name,
.hts-instructor__day-column.is-selected .hts-instructor__day-number {
	color: #161616;
}

.hts-instructor__day-body {
	padding: 18px;
}

.hts-instructor__no-session {
	margin: 44px 0 0;
	color: #bfbcb3;
	font-size: 0.95rem;
	font-weight: 600;
}

.hts-instructor__session-card {
	padding: 14px 0 0;
}

.hts-instructor__session-card + .hts-instructor__session-card {
	margin-top: 18px;
}

.hts-instructor__session-time {
	display: block;
	margin-bottom: 8px;
	font-size: 0.9rem;
	font-weight: 700;
}

.hts-instructor__session-card h3 {
	margin: 0 0 8px;
	font-family: "Sora", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.2;
	text-transform: uppercase;
}

.hts-instructor__session-location {
	margin: 0 0 14px;
	color: var(--hts-instructor-muted);
	font-size: 1rem;
	font-weight: 700;
}

.hts-instructor__session-meta {
	margin: 0 0 14px;
	color: #5d5b55;
	font-size: 0.92rem;
	line-height: 1.5;
}

.hts-instructor__reserve-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 92px;
	min-height: 34px;
	padding: 0 16px;
	border: 0;
	border-radius: 10px;
	background: linear-gradient(135deg, #f8dd1d 0%, #efcb00 100%);
	color: #131313;
	font-size: 0.92rem;
	font-weight: 800;
	cursor: pointer;
	transition: transform 0.16s ease, filter 0.16s ease;
}

.hts-instructor__reserve-button:hover {
	transform: translateY(-1px);
	filter: saturate(1.03);
}

@media (max-width: 980px) {
	.hts-instructor__site-header {
		grid-template-columns: 1fr;
		justify-items: center;
	}

	.hts-instructor__hero-panel {
		grid-template-columns: 1fr;
		gap: 12px;
		padding-bottom: 24px;
	}

	.hts-instructor__hero-quote,
	.hts-instructor__hero-copy {
		padding-right: 0;
	}

	.hts-instructor__hero-quote p {
		max-width: 100%;
	}

	.hts-instructor__hero-portrait {
		min-height: 240px;
	}

	.hts-instructor__portrait-backdrop {
		position: relative;
		right: auto;
		bottom: auto;
		margin: 0 auto;
	}

	.hts-instructor__portrait-core {
		right: 50%;
		transform: translateX(50%);
	}
}

@media (max-width: 640px) {
	.hts-instructor__top-ribbon {
		font-size: 0.8rem;
	}

	.hts-instructor__page-shell,
	.hts-instructor__site-header {
		width: min(100%, calc(100% - 20px));
	}

	.hts-instructor__main-nav {
		gap: 14px 18px;
	}

	.hts-instructor__hero-shadow-name {
		font-size: 4.8rem;
	}

	.hts-instructor__schedule-toolbar {
		padding-inline: 12px;
	}

	.hts-instructor__schedule-grid {
		grid-template-columns: repeat(8, minmax(170px, 1fr));
		min-width: 1100px;
	}
}
