/**
* Kozaru Honbu - Frontend Styles
*
* File: assets/css/frontend.css
*
* Public and logged-in portal styling. Admin screens load admin.css separately;
* frontend shortcode pages should not have to carry the whole WordPress admin
* wardrobe around.
*/

/* =========================================================
Kozaru Honbu - Registrations v0.2.2.2
========================================================= */

.kozaru-registration-student-choice {
	align-items: flex-start;
	background: #f6f7f7;
	border-radius: 6px;
	padding: 8px 10px;
}

.kozaru-registration-student-choice input[type="checkbox"] {
	margin-top: 2px;
}

.kozaru-registration-box {
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 8px;
	margin: 16px 0;
	padding: 16px;
}

.kozaru-registration-form fieldset {
	border: 1px solid #dcdcde;
	border-radius: 8px;
	margin: 12px 0;
	padding: 12px;
}

.kozaru-registration-form legend {
	font-weight: 700;
	padding: 0 6px;
}

.kozaru-status-registered {
	background: #edfaef;
	color: #116329;
}

.kozaru-status-waitlisted {
	background: #fff8e5;
	color: #7a4f00;
}

.kozaru-status-attended {
	background: #e7f5ff;
	color: #0a4b78;
}

.kozaru-status-no_show {
	background: #fcf0f1;
	color: #8a2424;
}

@media screen and (max-width: 782px) {
	.kozaru-registration-form .button {
		text-align: center;
		width: 100%;
	}
}

/* =========================================================
Kozaru Honbu - Calendar Display v0.2.3.1
========================================================= */

.kozaru-calendar-shortcode label span {
	display: block;
	font-weight: 600;
	margin-bottom: 4px;
}

.kozaru-calendar-shortcode,
.kozaru-calendar-selected-registration,
.kozaru-calendar-event-list {
	box-sizing: border-box;
}

.kozaru-calendar-shortcode {
	margin: 20px 0;
}

.kozaru-calendar-shortcode h2 {
	margin-bottom: 8px;
}

.kozaru-calendar-range-summary {
	color: #646970;
	font-size: 14px;
	margin: 0 0 16px;
}

.kozaru-calendar-selected-registration {
	margin: 0 0 22px;
}

.kozaru-calendar-event-list {
	display: grid;
	gap: 14px;
}

.kozaru-calendar-event-card {
	align-items: stretch;
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 10px;
	display: grid;
	grid-template-columns: minmax(110px, 150px) minmax(0, 1fr) auto;
	gap: 14px;
	padding: 16px;
}

.kozaru-calendar-event-date {
	background: #f6f7f7;
	border-radius: 8px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 12px;
	text-align: center;
}

.kozaru-calendar-event-date strong {
	font-size: 18px;
	line-height: 1.2;
}

.kozaru-calendar-event-date span {
	color: #646970;
	font-size: 13px;
	margin-top: 6px;
}

.kozaru-calendar-event-main h3 {
	font-size: 18px;
	line-height: 1.25;
	margin: 0 0 8px;
}

.kozaru-calendar-event-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 12px;
	margin-bottom: 10px;
}

.kozaru-calendar-event-meta span {
	color: #50575e;
	font-size: 13px;
}

.kozaru-calendar-event-registration {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	font-size: 14px;
}

.kozaru-calendar-event-excluded {
	background: #fff8e5;
	border-left: 3px solid #dba617;
	color: #6f4d00;
	font-size: 13px;
	margin-top: 10px;
	padding: 8px 10px;
}

.kozaru-calendar-event-actions {
	align-items: center;
	display: flex;
}

.kozaru-button {
	align-items: center;
	background: #2271b1;
	border: 1px solid #2271b1;
	border-radius: 6px;
	color: #fff;
	display: inline-flex;
	font-size: 14px;
	font-weight: 600;
	justify-content: center;
	line-height: 1.2;
	padding: 9px 14px;
	text-decoration: none;
}

.kozaru-button:focus,
.kozaru-button:hover {
	background: #135e96;
	border-color: #135e96;
	color: #fff;
	text-decoration: none;
}

.kozaru-notice {
	border-radius: 8px;
	margin: 12px 0;
	padding: 12px 14px;
}

.kozaru-notice-info {
	background: #f0f6fc;
	border: 1px solid #c5d9ed;
	color: #0a4b78;
}

.kozaru-notice-warning {
	background: #fff8e5;
	border: 1px solid #f0d98c;
	color: #6f4d00;
}

.kozaru-notice-error {
	background: #fcf0f1;
	border: 1px solid #f1b8bd;
	color: #8a2424;
}

@media screen and (max-width: 782px) {
	.kozaru-calendar-event-card {
		grid-template-columns: 1fr;
	}

	.kozaru-calendar-event-actions {
		display: grid;
		grid-template-columns: 1fr;
	}

	.kozaru-calendar-event-actions .kozaru-button {
		text-align: center;
		width: 100%;
	}

	.kozaru-calendar-event-date {
		align-items: flex-start;
		text-align: left;
	}
}

/* =========================================================
Kozaru Honbu - Calendar Display v0.2.3.5 controls/actions
========================================================= */

.kozaru-status-open {
	background: #edfaef;
	color: #0a6b1d;
}

.kozaru-status-today {
	background: #f0f6fc;
	color: #0a4b78;
}

.kozaru-status-full {
	background: #fff8e5;
	color: #7a4d00;
}

.kozaru-status-past,
.kozaru-status-excluded {
	background: #f0f0f1;
	color: #50575e;
}

/* =========================================================
Kozaru Honbu - Frontend Portal v0.2.4.x
========================================================= */

.kozaru-frontend-wrap {
	box-sizing: border-box;
	margin: 0 auto 24px;
	max-width: 1100px;
	width: 100%;
}

.kozaru-frontend-wrap *,
.kozaru-frontend-wrap *::before,
.kozaru-frontend-wrap *::after {
	box-sizing: border-box;
}

.kozaru-frontend-wrap h2 {
	margin-top: 0;
}

.kozaru-portal-card-grid,
.kozaru-frontend-card-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	margin: 18px 0;
}

.kozaru-portal-card,
.kozaru-frontend-card {
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 12px;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
	color: #1d2327;
	display: block;
	padding: 18px;
	text-decoration: none;
}

.kozaru-portal-card:hover,
.kozaru-portal-card:focus {
	border-color: #2271b1;
	box-shadow: 0 6px 18px rgba(34, 113, 177, 0.14);
	color: #1d2327;
	text-decoration: none;
	transform: translateY(-1px);
}

.kozaru-portal-card strong {
	display: block;
	font-size: 1.05rem;
	margin-bottom: 8px;
}

.kozaru-portal-card span {
	color: #50575e;
	display: block;
	font-size: 0.94rem;
	line-height: 1.45;
}

.kozaru-frontend-card h3 {
	font-size: 1.1rem;
	line-height: 1.3;
	margin: 0 0 12px;
}

.kozaru-frontend-meta-list {
	display: grid;
	gap: 8px 14px;
	grid-template-columns: minmax(120px, 0.7fr) minmax(0, 1.3fr);
	margin: 0;
}

.kozaru-frontend-meta-list dt {
	color: #646970;
	font-weight: 600;
	margin: 0;
}

.kozaru-frontend-meta-list dd {
	margin: 0;
}

.kozaru-frontend-card-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 14px;
}

.kozaru-button.kozaru-button-secondary {
	background: #f6f7f7;
	border-color: #c3c4c7;
	color: #1d2327;
}

.kozaru-button.kozaru-button-secondary:hover,
.kozaru-button.kozaru-button-secondary:focus {
	background: #fff;
	border-color: #2271b1;
	color: #135e96;
}

.kozaru-frontend-reason-list,
.kozaru-frontend-submission-list {
	margin: 14px 0 0 18px;
}

.kozaru-frontend-reason-list li,
.kozaru-frontend-submission-list li {
	margin-bottom: 8px;
}

.kozaru-frontend-submission-list strong,
.kozaru-frontend-submission-list small {
	display: block;
}

.kozaru-frontend-submission-list .kozaru-status {
	display: inline-flex;
	margin: 6px 0;
}

.kozaru-status-revoked,
.kozaru-status-expired,
.kozaru-status-cancelled {
	background: #fcf0f1;
	color: #8a2424;
}

.kozaru-status-active,
.kozaru-status-submitted,
.kozaru-status-approved {
	background: #edfaef;
	color: #0a6b1d;
}

@media screen and (max-width: 782px) {
	.kozaru-frontend-meta-list {
		grid-template-columns: 1fr;
	}

	.kozaru-frontend-meta-list dt {
		margin-top: 8px;
	}

	.kozaru-frontend-card-actions,
	.kozaru-frontend-card-actions .kozaru-button {
		display: grid;
		grid-template-columns: 1fr;
		width: 100%;
	}
}

/* =========================================================
Kozaru Honbu - Frontend My Details v0.2.4.6
========================================================= */

.kozaru-my-details-hero {
	display: grid;
	gap: 18px;
}

.kozaru-my-details-identity {
	align-items: flex-start;
	display: flex;
	gap: 18px;
	justify-content: space-between;
}

.kozaru-my-details-identity h3 {
	font-size: 1.45rem;
	margin: 0;
}

.kozaru-my-details-eyebrow {
	color: #646970;
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	margin: 0 0 5px;
	text-transform: uppercase;
}

.kozaru-my-details-primary-meta {
	border-top: 1px solid #f0f0f1;
	padding-top: 14px;
}

.kozaru-my-details-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	margin-top: 16px;
}

.kozaru-my-details-section {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.kozaru-my-details-section h3 {
	margin-bottom: 0;
}

.kozaru-my-details-status-line {
	margin: 0;
}

.kozaru-my-details-submission-list {
	border-top: 1px solid #f0f0f1;
	margin-left: 0;
	padding-left: 0;
	padding-top: 12px;
}

.kozaru-my-details-submission-list li {
	list-style: none;
}

@media screen and (max-width: 782px) {
	.kozaru-my-details-identity {
		align-items: flex-start;
		flex-direction: column;
	}

	.kozaru-my-details-grid {
		grid-template-columns: 1fr;
	}
}

/* =========================================================
Kozaru Honbu - Frontend Student List v0.2.4.6
========================================================= */

.kozaru-student-list-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	margin: 18px 0;
}

.kozaru-student-list-card {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.kozaru-student-list-card-header {
	align-items: flex-start;
	display: flex;
	gap: 14px;
	justify-content: space-between;
}

.kozaru-student-list-card-header h3 {
	margin-bottom: 4px;
}

.kozaru-student-list-title {
	color: #646970;
	font-size: 0.92rem;
	font-weight: 600;
	margin: 0;
}

.kozaru-student-list-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.kozaru-status-role {
	background: #f6f7f7;
	color: #1d2327;
}

.kozaru-student-obi {
	align-items: center;
	display: flex;
	flex: 0 0 auto;
	flex-direction: column;
	gap: 3px;
	min-width: 178px;
	text-align: center;
}

.kozaru-student-obi .kozaru-obi-preview {
	margin: 0;
	transform: scale(0.95);
	transform-origin: center;
}

.kozaru-student-obi-label {
	color: #50575e;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.2;
}

.kozaru-student-obi-empty {
	align-items: flex-end;
	min-width: 120px;
}

.kozaru-student-obi-empty .kozaru-student-obi-label {
	background: #f6f7f7;
	border: 1px solid #dcdcde;
	border-radius: 999px;
	padding: 6px 9px;
}

.kozaru-student-list-meta {
	border-top: 1px solid #f0f0f1;
	padding-top: 12px;
}

.kozaru-student-list-actions {
	border-top: 1px solid #f0f0f1;
	padding-top: 14px;
}

@media screen and (max-width: 782px) {
	.kozaru-student-list-grid {
		grid-template-columns: 1fr;
	}

	.kozaru-student-list-card-header {
		align-items: flex-start;
		flex-direction: column;
	}

	.kozaru-student-obi {
		align-items: flex-start;
		min-width: 0;
		text-align: left;
		width: 100%;
	}

	.kozaru-student-obi .kozaru-obi-preview {
		transform-origin: left center;
	}
}

/* =========================================================
Kozaru Honbu - Frontend Student Command Centre v0.2.4.8
========================================================= */

.kozaru-student-command-centre,
.kozaru-login-wrap,
.kozaru-command-page {
	max-width: 1120px;
}

.kozaru-command-hero {
	background: linear-gradient(135deg, #101010, #242424);
	border-top: 8px solid #d82132;
	border-radius: 28px;
	box-shadow: 0 18px 40px rgba(0, 0, 0, 0.14);
	color: #fff;
	margin: 0 0 24px;
	padding: 30px;
}

.kozaru-command-hero h2 {
	color: #fff;
	font-size: clamp(2rem, 5vw, 3.6rem);
	line-height: 1.02;
	margin: 0 0 12px;
}

.kozaru-command-hero p {
	color: rgba(255, 255, 255, 0.78);
	font-size: 1.05rem;
	line-height: 1.55;
	margin: 0;
	max-width: 720px;
}

.kozaru-command-eyebrow {
	color: #646970;
	font-size: 0.8rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	margin: 0 0 8px;
	text-transform: uppercase;
}

.kozaru-command-hero .kozaru-command-eyebrow {
	color: #fff;
	opacity: 0.75;
}

.kozaru-command-grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.kozaru-command-card {
	border-radius: 24px;
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.06);
	padding: 24px;
}

.kozaru-command-card h3,
.kozaru-command-card h4 {
	font-size: clamp(1.45rem, 3vw, 2.25rem);
	line-height: 1.05;
	margin: 0 0 18px;
}

.kozaru-command-card-header {
	align-items: flex-start;
	display: flex;
	gap: 16px;
	justify-content: space-between;
	margin-bottom: 18px;
}

.kozaru-command-card-profile {
	grid-column: span 2;
}

.kozaru-command-stat-row {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	margin: 0 0 18px;
}

.kozaru-command-stat-row span {
	background: #f6f7f7;
	border: 1px solid #e3e5e8;
	border-radius: 16px;
	display: block;
	font-size: 0.86rem;
	font-weight: 700;
	padding: 12px;
	text-transform: uppercase;
}

.kozaru-command-stat-row strong {
	display: block;
	font-size: 1.8rem;
	line-height: 1;
	margin-bottom: 4px;
	text-transform: none;
}

.kozaru-command-stat-list {
	display: grid;
	gap: 10px 16px;
	grid-template-columns: minmax(130px, 0.8fr) minmax(0, 1.2fr);
	margin: 0 0 18px;
}

.kozaru-command-stat-list dt {
	color: #646970;
	font-weight: 800;
	letter-spacing: 0.04em;
	margin: 0;
	text-transform: uppercase;
}

.kozaru-command-stat-list dd {
	font-weight: 700;
	margin: 0;
}

.kozaru-command-list {
	display: grid;
	gap: 12px;
	margin: 0 0 18px;
}

.kozaru-command-list-item {
	align-items: center;
	background: #f6f7f7;
	border-left: 6px solid #d82132;
	border-radius: 16px;
	display: flex;
	gap: 12px;
	justify-content: space-between;
	padding: 14px 16px;
}

.kozaru-command-list-item strong,
.kozaru-command-list-item small {
	display: block;
}

.kozaru-command-list-item small {
	color: #646970;
	font-size: 0.88rem;
	line-height: 1.45;
	margin-top: 4px;
}

.kozaru-command-mini-link {
	color: #d82132;
	font-size: 0.86rem;
	font-weight: 800;
	text-decoration: none;
	white-space: nowrap;
}

.kozaru-command-mini-link:hover,
.kozaru-command-mini-link:focus {
	text-decoration: underline;
}

.kozaru-command-list-actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: flex-end;
}

.kozaru-command-empty {
	color: #50575e;
	font-size: 1rem;
	line-height: 1.5;
	margin: 0 0 18px;
}

.kozaru-inline-form {
	display: inline-flex;
	margin: 0;
}

.kozaru-button.kozaru-button-danger,
.kozaru-button-danger {
	background: #fcf0f1;
	border-color: #cc1818;
	color: #8a2424;
}

.kozaru-button.kozaru-button-danger:hover,
.kozaru-button.kozaru-button-danger:focus,
.kozaru-button-danger:hover,
.kozaru-button-danger:focus {
	background: #fff;
	border-color: #8a2424;
	color: #8a2424;
}

.kozaru-status-not_submitted {
	background: #f0f0f1;
	color: #50575e;
}

.kozaru-status-registered {
	background: #edfaef;
	color: #0a6b1d;
}

.kozaru-status-waitlisted {
	background: #fff8e5;
	color: #7a4d00;
}

.kozaru-notice-success {
	background: #edfaef;
	border-left-color: #00a32a;
}

.kozaru-login-wrap {
	display: grid;
	gap: 18px;
}

.kozaru-login-form-card .login-username,
.kozaru-login-form-card .login-password,
.kozaru-login-form-card .login-remember,
.kozaru-login-form-card .login-submit {
	margin: 0 0 14px;
}

.kozaru-login-form-card label {
	display: block;
	font-weight: 700;
	margin-bottom: 6px;
}

.kozaru-login-form-card input[type="text"],
.kozaru-login-form-card input[type="password"] {
	border: 1px solid #c3c4c7;
	border-radius: 10px;
	box-sizing: border-box;
	font-size: 1rem;
	min-height: 44px;
	padding: 8px 12px;
	width: 100%;
}

.kozaru-login-links {
	margin-bottom: 0;
}

.kozaru-forms-manager {
	display: grid;
	gap: 18px;
}

.kozaru-form-status-item {
	align-items: flex-start;
	flex-wrap: wrap;
}

.kozaru-self-service-form {
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 20px;
	display: grid;
	gap: 14px;
	padding: 20px;
}

.kozaru-self-service-form h4 {
	margin-bottom: 0;
}

.kozaru-consent-text {
	background: #f6f7f7;
	border: 1px solid #e3e5e8;
	border-radius: 14px;
	padding: 14px;
}

.kozaru-form-field {
	display: grid;
	gap: 6px;
}

.kozaru-form-field span {
	font-weight: 800;
}

.kozaru-form-field em {
	color: #646970;
	font-style: normal;
	font-weight: 600;
}

.kozaru-form-field input[type="text"],
.kozaru-form-field input[type="email"],
.kozaru-form-field input[type="date"],
.kozaru-form-field select,
.kozaru-form-field textarea {
	border: 1px solid #c3c4c7;
	border-radius: 10px;
	box-sizing: border-box;
	font-size: 1rem;
	min-height: 42px;
	padding: 8px 12px;
	width: 100%;
}

.kozaru-form-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 4px 0 0;
}

@media screen and (max-width: 782px) {
	.kozaru-command-hero {
		border-radius: 24px;
		padding: 24px;
	}

	.kozaru-command-grid {
		grid-template-columns: 1fr;
	}

	.kozaru-command-card-profile {
		grid-column: auto;
	}

	.kozaru-command-card-header {
		flex-direction: column;
	}

	.kozaru-command-stat-list {
		grid-template-columns: 1fr;
	}

	.kozaru-command-list-item {
		align-items: flex-start;
		flex-direction: column;
	}

	.kozaru-command-list-actions,
	.kozaru-command-list-actions .kozaru-button,
	.kozaru-command-list-actions .kozaru-inline-form,
	.kozaru-command-list-actions .kozaru-inline-form button,
	.kozaru-form-actions,
	.kozaru-form-actions .kozaru-button,
	.kozaru-login-form-card .button {
		display: grid;
		width: 100%;
	}
}

/* =========================================================
Kozaru Honbu - Frontend Linked Item Details v0.2.4.8
========================================================= */

.kozaru-command-item-main {
	min-width: 0;
}

.kozaru-command-item-title {
	color: #1d2327;
	text-decoration: none;
}

.kozaru-command-item-title:hover,
.kozaru-command-item-title:focus {
	color: #d82132;
	text-decoration: underline;
}

.kozaru-command-list-item .kozaru-status {
	text-decoration: none;
	white-space: nowrap;
}

.kozaru-command-list-item .kozaru-status:hover,
.kozaru-command-list-item .kozaru-status:focus {
	filter: brightness(0.97);
	text-decoration: none;
}

.kozaru-item-detail-card {
	display: grid;
	gap: 16px;
}

.kozaru-item-detail-card h3 {
	margin-bottom: 4px;
}

.kozaru-item-detail-meta {
	margin-bottom: 0;
}

.kozaru-item-action-panel {
	border-top: 1px solid #f0f0f1;
	display: grid;
	gap: 12px;
	padding-top: 16px;
}

.kozaru-item-detail-note {
	background: #f6f7f7;
	border: 1px solid #e3e5e8;
	border-radius: 16px;
	line-height: 1.55;
	padding: 14px 16px;
}

.kozaru-location-meta {
	display: grid;
	gap: 6px;
}

.kozaru-location-name {
	display: block;
	font-weight: 750;
}

.kozaru-location-address-link,
.kozaru-location-address-text {
	display: inline-block;
	font-size: 0.96em;
	font-weight: 550;
	line-height: 1.45;
	overflow-wrap: anywhere;
}

.kozaru-location-address-link {
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.14em;
}

.kozaru-item-detail-note strong {
	display: block;
	margin-bottom: 6px;
}

.kozaru-item-detail-actions {
	align-items: center;
}

.kozaru-item-back-link {
	margin-top: 18px;
}

.kozaru-status-full {
	background: #fcf0f1;
	color: #8a2424;
}

@media screen and (max-width: 782px) {
	.kozaru-command-list-item .kozaru-status,
	.kozaru-command-list-item .kozaru-command-mini-link {
		align-self: flex-start;
	}

	.kozaru-item-detail-actions,
	.kozaru-item-detail-actions .kozaru-button,
	.kozaru-item-detail-actions .kozaru-inline-form,
	.kozaru-item-detail-actions .kozaru-inline-form button {
		display: grid;
		width: 100%;
	}
}

/* =========================================================
Kozaru Honbu - Frontend UI Polish v0.2.4.9
---------------------------------------------------------
Cosmetic pass only. The Obi Builder/obi rendering rules above are left alone.
========================================================= */

.kozaru-frontend-wrap,
.kozaru-calendar-shortcode,
.kozaru-registration-box {
	--kozaru-ui-ink: #08091f;
	--kozaru-ui-muted: #606779;
	--kozaru-ui-soft: #f5f6fb;
	--kozaru-ui-panel: #ffffff;
	--kozaru-ui-line: #dde1ea;
	--kozaru-ui-red: #d82132;
	--kozaru-ui-blue: #2479b8;
	--kozaru-ui-shadow: 0 18px 45px rgba(8, 9, 31, 0.08);
	color: var(--kozaru-ui-ink);
}

body.kozaru-frontend-generated-page .entry-title,
body.kozaru-frontend-generated-page .wp-block-post-title,
body.kozaru-frontend-generated-page h1.entry-title {
	display: none !important;
}

.kozaru-frontend-wrap,
.kozaru-calendar-shortcode {
	box-sizing: border-box;
	margin: 0 auto clamp(24px, 4vw, 48px);
	max-width: 1120px;
	padding: clamp(8px, 2vw, 20px);
	width: 100%;
}

.kozaru-frontend-wrap *,
.kozaru-frontend-wrap *::before,
.kozaru-frontend-wrap *::after,
.kozaru-calendar-shortcode *,
.kozaru-calendar-shortcode *::before,
.kozaru-calendar-shortcode *::after,
.kozaru-registration-box *,
.kozaru-registration-box *::before,
.kozaru-registration-box *::after {
	box-sizing: border-box;
}

.kozaru-frontend-wrap h2,
.kozaru-calendar-shortcode h2 {
	color: var(--kozaru-ui-ink);
	font-size: clamp(2.05rem, 7vw, 4rem);
	font-weight: 850;
	letter-spacing: -0.06em;
	line-height: 0.98;
	margin: 0 0 clamp(18px, 3vw, 28px);
}

.kozaru-command-hero {
	background:
	radial-gradient(circle at 90% 0%, rgba(216, 33, 50, 0.38), transparent 34%),
	linear-gradient(135deg, #09091f 0%, #191b31 55%, #252944 100%);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-left: 7px solid var(--kozaru-ui-red);
	border-radius: clamp(22px, 5vw, 34px);
	box-shadow: 0 24px 60px rgba(8, 9, 31, 0.2);
	color: #ffffff;
	margin: 0 0 clamp(18px, 3vw, 28px);
	min-height: 0;
	padding: clamp(24px, 5vw, 42px);
}

.kozaru-command-hero h2 {
	color: #ffffff;
	font-size: clamp(2.35rem, 8vw, 5rem);
	letter-spacing: -0.075em;
	line-height: 0.95;
	margin: 0 0 14px;
}

.kozaru-command-hero p {
	color: rgba(255, 255, 255, 0.78);
	font-size: clamp(1rem, 2.2vw, 1.16rem);
	line-height: 1.55;
	margin: 0;
}

.kozaru-command-eyebrow,
.kozaru-my-details-eyebrow {
	color: var(--kozaru-ui-muted);
	font-size: 0.78rem;
	font-weight: 850;
	letter-spacing: 0.085em;
	line-height: 1.2;
	margin: 0 0 8px;
	text-transform: uppercase;
}

.kozaru-command-hero .kozaru-command-eyebrow {
	color: rgba(255, 255, 255, 0.72);
}

.kozaru-command-grid,
.kozaru-frontend-card-grid,
.kozaru-portal-card-grid,
.kozaru-my-details-grid,
.kozaru-student-list-grid {
	display: grid;
	gap: clamp(14px, 2.4vw, 22px);
}

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

.kozaru-frontend-card-grid,
.kozaru-portal-card-grid,
.kozaru-my-details-grid,
.kozaru-student-list-grid {
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 290px), 1fr));
	margin: clamp(14px, 2.4vw, 22px) 0;
}

.kozaru-frontend-card,
.kozaru-portal-card,
.kozaru-registration-box,
.kozaru-calendar-event-card {
	background: var(--kozaru-ui-panel);
	border: 1px solid var(--kozaru-ui-line);
	border-radius: clamp(20px, 4vw, 30px);
	box-shadow: var(--kozaru-ui-shadow);
	color: var(--kozaru-ui-ink);
	padding: clamp(18px, 3vw, 28px);
}

.kozaru-command-card-profile {
	grid-column: span 2;
}

.kozaru-command-card,
.kozaru-my-details-section,
.kozaru-item-detail-card {
	display: grid;
	gap: clamp(14px, 2vw, 20px);
}

.kozaru-command-card h3,
.kozaru-command-card h4,
.kozaru-frontend-card h3,
.kozaru-registration-box h3,
.kozaru-calendar-event-main h3 {
	color: var(--kozaru-ui-ink);
	font-size: clamp(1.35rem, 4vw, 2.2rem);
	font-weight: 850;
	letter-spacing: -0.045em;
	line-height: 1.05;
	margin: 0;
}

.kozaru-command-card-header,
.kozaru-my-details-identity,
.kozaru-student-list-card-header {
	align-items: flex-start;
	display: flex;
	gap: 18px;
	justify-content: space-between;
}

.kozaru-command-stat-row {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
	margin: 0;
}

.kozaru-command-stat-row span {
	background: linear-gradient(180deg, #ffffff, var(--kozaru-ui-soft));
	border: 1px solid var(--kozaru-ui-line);
	border-radius: 20px;
	color: var(--kozaru-ui-muted);
	display: block;
	font-size: 0.75rem;
	font-weight: 850;
	letter-spacing: 0.035em;
	padding: 14px;
	text-transform: uppercase;
}

.kozaru-command-stat-row strong {
	color: var(--kozaru-ui-ink);
	display: block;
	font-size: clamp(1.8rem, 5vw, 2.6rem);
	font-weight: 900;
	letter-spacing: -0.06em;
	line-height: 0.9;
	margin-bottom: 7px;
	text-transform: none;
}

.kozaru-command-stat-list,
.kozaru-frontend-meta-list,
.kozaru-item-detail-meta {
	display: grid;
	gap: 12px 18px;
	grid-template-columns: minmax(128px, 0.75fr) minmax(0, 1.25fr);
	margin: 0;
}

.kozaru-command-stat-list dt,
.kozaru-frontend-meta-list dt,
.kozaru-item-detail-meta dt {
	color: var(--kozaru-ui-muted);
	font-size: 0.82rem;
	font-weight: 850;
	letter-spacing: 0.04em;
	margin: 0;
	text-transform: uppercase;
}

.kozaru-command-stat-list dd,
.kozaru-frontend-meta-list dd,
.kozaru-item-detail-meta dd {
	color: var(--kozaru-ui-ink);
	font-weight: 650;
	margin: 0;
	min-width: 0;
}

.kozaru-command-list,
.kozaru-attendance-detail-list,
.kozaru-command-booking-list,
.kozaru-forms-status-list {
	display: grid;
	gap: 12px;
	margin: 0;
}

.kozaru-command-list-item {
	align-items: center;
	background: linear-gradient(180deg, #ffffff, #f8f9fc);
	border: 1px solid var(--kozaru-ui-line);
	border-left: 7px solid var(--kozaru-ui-red);
	border-radius: 22px;
	display: flex;
	gap: 14px;
	justify-content: space-between;
	min-width: 0;
	padding: 15px 17px;
}

.kozaru-command-item-main {
	min-width: 0;
}

.kozaru-command-list-item strong,
.kozaru-command-list-item small {
	display: block;
}

.kozaru-command-list-item small,
.kozaru-calendar-range-summary,
.kozaru-calendar-event-meta span,
.kozaru-calendar-event-registration,
.kozaru-command-empty {
	color: var(--kozaru-ui-muted);
}

.kozaru-command-item-title,
.kozaru-calendar-event-main h3 a {
	color: var(--kozaru-ui-ink);
	text-decoration: none;
}

.kozaru-command-item-title:hover,
.kozaru-command-item-title:focus,
.kozaru-calendar-event-main h3 a:hover,
.kozaru-calendar-event-main h3 a:focus {
	color: var(--kozaru-ui-red);
	text-decoration: none;
}

.kozaru-button,
.kozaru-registration-form .button,
.kozaru-login-form-card .button {
	align-items: center;
	appearance: none;
	background: var(--kozaru-ui-blue);
	border: 1px solid var(--kozaru-ui-blue);
	border-radius: 14px;
	box-shadow: 0 10px 24px rgba(36, 121, 184, 0.18);
	color: #ffffff !important;
	display: inline-flex;
	font-size: 0.96rem;
	font-weight: 850;
	gap: 6px;
	justify-content: center;
	line-height: 1.15;
	min-height: 44px;
	padding: 11px 16px;
	text-decoration: none;
	transition: transform 120ms ease, box-shadow 120ms ease, background-color 120ms ease, border-color 120ms ease;
}

.kozaru-button:hover,
.kozaru-button:focus,
.kozaru-registration-form .button:hover,
.kozaru-registration-form .button:focus,
.kozaru-login-form-card .button:hover,
.kozaru-login-form-card .button:focus {
	background: #155f95;
	border-color: #155f95;
	box-shadow: 0 14px 30px rgba(36, 121, 184, 0.24);
	color: #ffffff !important;
	text-decoration: none;
	transform: translateY(-1px);
}

.kozaru-button.kozaru-button-secondary,
.kozaru-calendar-event-actions .kozaru-button-secondary {
	background: #ffffff;
	border-color: var(--kozaru-ui-line);
	box-shadow: none;
	color: var(--kozaru-ui-ink) !important;
}

.kozaru-button.kozaru-button-secondary:hover,
.kozaru-button.kozaru-button-secondary:focus {
	background: var(--kozaru-ui-soft);
	border-color: var(--kozaru-ui-blue);
	color: var(--kozaru-ui-blue) !important;
}

.kozaru-button.kozaru-button-danger,
.kozaru-button-danger {
	background: #fff3f4;
	border-color: #f0b7bd;
	box-shadow: none;
	color: #9d1728 !important;
}

.kozaru-status {
	align-items: center;
	border: 1px solid transparent;
	border-radius: 999px;
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 850;
	letter-spacing: 0.015em;
	line-height: 1.1;
	padding: 7px 10px;
	text-decoration: none;
	white-space: nowrap;
}

.kozaru-status-active,
.kozaru-status-approved,
.kozaru-status-submitted,
.kozaru-status-registered,
.kozaru-status-open {
	background: #eaf8ee;
	border-color: #c9eed3;
	color: #0f6b2b;
}

.kozaru-status-not_submitted,
.kozaru-status-past,
.kozaru-status-excluded,
.kozaru-status-role {
	background: #f0f2f6;
	border-color: #e2e6ee;
	color: #5e6575;
}

.kozaru-status-waitlisted,
.kozaru-status-full,
.kozaru-status-today {
	background: #fff7df;
	border-color: #f3dfa6;
	color: #7a4d00;
}

.kozaru-status-revoked,
.kozaru-status-expired,
.kozaru-status-cancelled,
.kozaru-status-no_show {
	background: #fff0f2;
	border-color: #f0b8be;
	color: #982033;
}

.kozaru-calendar-event-list {
	display: grid;
	gap: clamp(14px, 2.4vw, 22px);
}

.kozaru-calendar-event-card {
	align-items: stretch;
	display: grid;
	gap: clamp(14px, 2vw, 22px);
	grid-template-columns: minmax(128px, 160px) minmax(0, 1fr) auto;
}

.kozaru-calendar-event-date {
	align-items: flex-start;
	background: linear-gradient(180deg, #ffffff, var(--kozaru-ui-soft));
	border: 1px solid var(--kozaru-ui-line);
	border-radius: 20px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 16px;
	text-align: left;
}

.kozaru-calendar-event-date strong {
	color: var(--kozaru-ui-ink);
	font-size: clamp(1.2rem, 4vw, 1.7rem);
	font-weight: 900;
	letter-spacing: -0.045em;
	line-height: 1;
}

.kozaru-calendar-event-date span {
	color: var(--kozaru-ui-muted);
	font-weight: 650;
	margin-top: 9px;
}

.kozaru-calendar-event-meta,
.kozaru-calendar-event-registration {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 14px;
}

.kozaru-calendar-event-registration {
	font-weight: 650;
	margin-top: 12px;
}

.kozaru-calendar-event-actions {
	align-items: center;
	display: flex;
	justify-content: flex-end;
}

.kozaru-calendar-event-actions .kozaru-status {
	min-height: 44px;
	padding-inline: 15px;
}

.kozaru-registration-box {
	margin: clamp(16px, 3vw, 26px) 0;
}

.kozaru-registration-box > p {
	color: var(--kozaru-ui-muted);
	font-weight: 650;
	margin: 10px 0 0;
}

.kozaru-registration-form,
.kozaru-self-service-form,
.kozaru-login-form-card form {
	display: grid;
	gap: 16px;
}

.kozaru-registration-form fieldset,
.kozaru-self-service-form {
	background: #ffffff;
	border: 1px solid var(--kozaru-ui-line);
	border-radius: 14px;
	padding: clamp(16px, 3vw, 22px);
}

.kozaru-registration-form legend {
	color: var(--kozaru-ui-ink);
	font-size: 0.95rem;
	font-weight: 850;
	padding: 0 8px;
}

.kozaru-form-field,
.kozaru-registration-form label,
.kozaru-login-form-card label {
	color: var(--kozaru-ui-ink);
	display: grid;
	font-weight: 800;
	gap: 7px;
}

.kozaru-form-field em {
	color: var(--kozaru-ui-muted);
	font-style: normal;
	font-weight: 650;
}

.kozaru-form-field input[type="text"],
.kozaru-form-field input[type="email"],
.kozaru-form-field input[type="tel"],
.kozaru-form-field input[type="date"],
.kozaru-form-field select,
.kozaru-form-field textarea,
.kozaru-registration-form input[type="text"],
.kozaru-registration-form input[type="email"],
.kozaru-registration-form input[type="date"],
.kozaru-registration-form select,
.kozaru-registration-form textarea,
.kozaru-login-form-card input[type="text"],
.kozaru-login-form-card input[type="password"] {
	background: #ffffff;
	border: 1px solid #cfd5e2;
	border-radius: 14px;
	box-shadow: inset 0 1px 0 rgba(8, 9, 31, 0.03);
	color: var(--kozaru-ui-ink);
	font-size: 1rem;
	line-height: 1.3;
	min-height: 46px;
	padding: 10px 13px;
	width: 100%;
}

.kozaru-form-field textarea,
.kozaru-registration-form textarea {
	min-height: 110px;
	resize: vertical;
}

.kozaru-checkbox-field,
.kozaru-frontend-checkbox-field,
.kozaru-registration-student-choice {
	align-items: flex-start;
	display: flex;
	gap: 10px;
}

.kozaru-checkbox-field input[type="checkbox"],
.kozaru-frontend-checkbox-field input[type="checkbox"] {
	flex: 0 0 auto;
	margin-top: 3px;
}

.kozaru-form-status-item {
	align-items: center;
}

.kozaru-consent-text,
.kozaru-item-detail-note {
	background: var(--kozaru-ui-soft);
	border: 1px solid var(--kozaru-ui-line);
	border-radius: 20px;
	color: var(--kozaru-ui-ink);
	line-height: 1.6;
	padding: 16px;
}

.kozaru-notice {
	border: 1px solid transparent;
	border-radius: 18px;
	line-height: 1.5;
	margin: 14px 0;
	padding: 13px 15px;
}

.kozaru-notice p,
.kozaru-notice ul {
	margin-bottom: 0;
	margin-top: 0;
}

.kozaru-notice-info {
	background: #eef6ff;
	border-color: #cce4fa;
	color: #174c75;
}

.kozaru-notice-warning {
	background: #fff8e5;
	border-color: #edd896;
	color: #6f4d00;
}

.kozaru-notice-error {
	background: #fff0f2;
	border-color: #efb8be;
	color: #982033;
}

.kozaru-notice-success {
	background: #eaf8ee;
	border-color: #c9eed3;
	color: #0f6b2b;
}

@media screen and (max-width: 782px) {
	.kozaru-frontend-wrap,
	.kozaru-calendar-shortcode {
		padding-left: 0;
		padding-right: 0;
	}

	.kozaru-command-grid,
	.kozaru-command-card-profile,
	.kozaru-calendar-event-card,
	.kozaru-command-stat-list,
	.kozaru-frontend-meta-list,
	.kozaru-item-detail-meta {
		grid-column: auto;
		grid-template-columns: 1fr;
	}

	.kozaru-command-card-header,
	.kozaru-my-details-identity,
	.kozaru-student-list-card-header,
	.kozaru-command-list-item,
	.kozaru-form-status-item {
		align-items: stretch;
		flex-direction: column;
	}

	.kozaru-command-list-actions,
	.kozaru-command-list-actions .kozaru-button,
	.kozaru-command-list-actions .kozaru-inline-form,
	.kozaru-command-list-actions .kozaru-inline-form button,
	.kozaru-form-actions,
	.kozaru-form-actions .kozaru-button,
	.kozaru-calendar-event-actions,
	.kozaru-calendar-event-actions .kozaru-button,
	.kozaru-calendar-event-actions .kozaru-status,
	.kozaru-registration-form .button,
	.kozaru-login-form-card .button {
		display: grid;
		justify-content: stretch;
		text-align: center;
		width: 100%;
	}

	.kozaru-command-list-item .kozaru-status,
	.kozaru-command-mini-link {
		align-self: flex-start;
	}

	.kozaru-command-card,
	.kozaru-frontend-card,
	.kozaru-registration-box,
	.kozaru-calendar-event-card {
		border-radius: 22px;
	}
}

/* =========================================================
Kozaru frontend managed-students workspace (v0.2.5.9)
One visible student, preloaded tab panels, no query-string reload circus.
Obi rendering is intentionally untouched.
========================================================= */

.kozaru-my-managed-students {
	--kozaru-managed-card-min: min(100%, 260px);
}

.kozaru-managed-students-summary {
	margin-bottom: clamp(14px, 2.4vw, 22px);
}

.kozaru-managed-student-picker {
	background: #ffffff;
	border: 1px solid var(--kozaru-ui-line);
	border-radius: 18px;
	box-shadow: none;
	display: grid;
	gap: clamp(14px, 2.4vw, 20px);
	margin-bottom: clamp(14px, 2.4vw, 22px);
	padding: clamp(16px, 3vw, 24px);
}

.kozaru-managed-student-picker-heading {
	align-items: start;
	display: flex;
	gap: 16px;
	justify-content: space-between;
}

.kozaru-managed-student-picker-heading h3 {
	margin: 0;
}

.kozaru-managed-student-picker-heading .kozaru-command-empty {
	margin: 0;
	max-width: 540px;
}

.kozaru-managed-student-picker-grid {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(var(--kozaru-managed-card-min), 1fr));
}

.kozaru-managed-student-picker-card {
	appearance: none;
	background: #ffffff;
	border: 1px solid var(--kozaru-ui-line);
	border-radius: 14px;
	box-shadow: none;
	color: var(--kozaru-ui-ink);
	cursor: pointer;
	display: grid;
	gap: 6px;
	line-height: 1.25;
	padding: 14px 16px;
	text-align: left;
	transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease, background 160ms ease;
	width: 100%;
}

.kozaru-managed-student-picker-card:hover,
.kozaru-managed-student-picker-card:focus-visible {
	border-color: rgba(18, 25, 38, 0.32);
	box-shadow: none;
	transform: none;
}

.kozaru-managed-student-picker-card.is-active {
	background: var(--kozaru-ui-ink);
	border-color: var(--kozaru-ui-ink);
	box-shadow: none;
	color: #ffffff;
}

.kozaru-managed-student-picker-card.is-active .kozaru-command-eyebrow,
.kozaru-managed-student-picker-card.is-active small {
	color: rgba(255, 255, 255, 0.74);
}

.kozaru-managed-student-picker-card strong {
	font-size: 1.03rem;
}

.kozaru-managed-student-picker-card small {
	color: var(--kozaru-ui-muted);
	font-weight: 800;
}

.kozaru-managed-student-workspaces {
	display: grid;
	gap: clamp(14px, 2.4vw, 22px);
}

.kozaru-managed-student-workspace {
	align-content: start;
}

.kozaru-managed-student-workspace[hidden],
.kozaru-managed-tab-panel[hidden] {
	display: none !important;
}

.kozaru-managed-student-detail-header {
	align-items: flex-start;
}

.kozaru-managed-student-title {
	color: var(--kozaru-ui-muted);
	font-size: 0.95rem;
	font-weight: 800;
	line-height: 1.35;
	margin: 8px 0 0;
}

.kozaru-managed-student-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 9px;
	margin-top: 4px;
}

.kozaru-managed-student-tabs .kozaru-button {
	min-height: 40px;
}

.kozaru-button.kozaru-button-active,
.kozaru-managed-tab-button.is-active {
	background: var(--kozaru-ui-ink);
	border-color: var(--kozaru-ui-ink);
	box-shadow: none;
	color: #ffffff !important;
}

.kozaru-managed-tab-panels {
	display: grid;
	gap: clamp(14px, 2.4vw, 20px);
}

.kozaru-managed-tab-panel {
	animation: kozaruManagedTabFade 160ms ease-out;
}

.kozaru-managed-student-workspace .kozaru-notice {
	margin: 0;
}

.kozaru-managed-student-detail-meta {
	background: linear-gradient(180deg, #ffffff, var(--kozaru-ui-soft));
	border: 1px solid var(--kozaru-ui-line);
	border-radius: 22px;
	padding: clamp(14px, 2.4vw, 20px);
}

.kozaru-status-trial {
	background: #eef6ff;
	border-color: #cce4fa;
	color: #174c75;
}

.kozaru-status-paused {
	background: #f0f2f6;
	border-color: #e2e6ee;
	color: #5e6575;
}

@keyframes kozaruManagedTabFade {
	from {
		opacity: 0;
		transform: translateY(4px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media screen and (max-width: 782px) {
	.kozaru-managed-student-picker-heading,
	.kozaru-managed-student-tabs,
	.kozaru-managed-student-tabs .kozaru-button {
		display: grid;
		justify-content: stretch;
		text-align: center;
		width: 100%;
	}

	.kozaru-managed-student-picker-card {
		text-align: left;
	}
}

/* =========================================================
Kozaru frontend managed-student context selector (v0.2.5.3)
Groundwork only: stores current student context for later flows.
Obi rendering is intentionally untouched.
========================================================= */

.kozaru-student-context-selector {
	display: grid;
	gap: clamp(12px, 2vw, 18px);
	margin: clamp(14px, 2.4vw, 22px) 0;
}

.kozaru-student-context-current {
	align-items: flex-start;
	display: flex;
	gap: 16px;
	justify-content: space-between;
}

.kozaru-student-context-current h3 {
	margin: 0;
}

.kozaru-student-context-meta {
	color: var(--kozaru-ui-muted);
	font-size: 0.95rem;
	font-weight: 800;
	line-height: 1.35;
	margin: 8px 0 0;
}

.kozaru-student-context-form {
	align-items: end;
	display: grid;
	gap: 12px;
	grid-template-columns: minmax(0, 1fr) auto;
}

.kozaru-student-context-form label {
	display: grid;
	gap: 7px;
	min-width: 0;
}

.kozaru-student-context-form label > span {
	color: var(--kozaru-ui-muted);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.kozaru-student-context-form select {
	background: #ffffff;
	border: 1px solid var(--kozaru-ui-line);
	border-radius: 14px;
	box-shadow: 0 10px 26px rgba(18, 25, 38, 0.06);
	font-size: 1rem;
	min-height: 44px;
	padding: 8px 12px;
	width: 100%;
}

.kozaru-student-context-actions {
	margin: 0;
}

.kozaru-context-selector-page .kozaru-student-context-selector {
	margin-top: 0;
}

@media screen and (max-width: 782px) {
	.kozaru-student-context-current,
	.kozaru-student-context-form {
		display: grid;
		grid-template-columns: 1fr;
	}

	.kozaru-student-context-form .kozaru-button,
	.kozaru-student-context-actions .kozaru-button {
		justify-content: center;
		text-align: center;
		width: 100%;
	}
}

/* =========================================================
Kozaru frontend skin reset / layout pass (v0.2.5.9)
---------------------------------------------------------
Keep the frontend portal wide, neutral, and easy for the
client site/theme to skin. Obi rendering above is untouched.
========================================================= */

body.kozaru-frontend-generated-page .site,
body.kozaru-frontend-generated-page .site-main,
body.kozaru-frontend-generated-page .content-area,
body.kozaru-frontend-generated-page .entry-content,
body.kozaru-frontend-generated-page .wp-block-post-content,
body.kozaru-frontend-generated-page main {
	max-width: none;
}

body.kozaru-frontend-generated-page .entry-content > *,
body.kozaru-frontend-generated-page .wp-block-post-content > * {
	max-width: none;
}

.kozaru-frontend-wrap,
.kozaru-calendar-shortcode,
.kozaru-registration-box {
	--kozaru-ui-ink: #1d2327;
	--kozaru-ui-muted: #646970;
	--kozaru-ui-soft: #f6f7f7;
	--kozaru-ui-panel: #ffffff;
	--kozaru-ui-line: #dcdcde;
	--kozaru-ui-red: #b91c1c;
	--kozaru-ui-blue: #2271b1;
	--kozaru-ui-shadow: none;
}

.kozaru-frontend-wrap,
.kozaru-calendar-shortcode {
	margin-left: auto;
	margin-right: auto;
	max-width: none;
	padding-left: clamp(12px, 3vw, 36px);
	padding-right: clamp(12px, 3vw, 36px);
	width: min(100%, 1560px);
}

.kozaru-frontend-wrap h2,
.kozaru-calendar-shortcode h2,
.kozaru-command-hero h2 {
	font-size: clamp(1.85rem, 3.4vw, 3rem);
	font-weight: 750;
	letter-spacing: -0.035em;
	line-height: 1.05;
}

.kozaru-command-hero {
	background: var(--kozaru-ui-panel);
	border: 1px solid var(--kozaru-ui-line);
	border-left: 4px solid var(--kozaru-ui-blue);
	border-radius: 18px;
	box-shadow: none;
	color: var(--kozaru-ui-ink);
	padding: clamp(18px, 3vw, 30px);
}

.kozaru-command-hero h2,
.kozaru-command-hero p,
.kozaru-command-hero .kozaru-command-eyebrow {
	color: var(--kozaru-ui-ink);
}

.kozaru-command-hero p,
.kozaru-calendar-range-summary,
.kozaru-calendar-event-meta span,
.kozaru-calendar-event-registration,
.kozaru-command-empty,
.kozaru-managed-student-title,
.kozaru-managed-student-picker-card small {
	color: var(--kozaru-ui-muted);
}

.kozaru-frontend-card,
.kozaru-portal-card,
.kozaru-command-card,
.kozaru-my-details-section,
.kozaru-item-detail-card,
.kozaru-registration-box,
.kozaru-calendar-event-card,
.kozaru-managed-student-picker,
.kozaru-managed-student-picker-card,
.kozaru-managed-student-detail-meta,
.kozaru-registration-form fieldset,
.kozaru-self-service-form,
.kozaru-consent-text,
.kozaru-item-detail-note,
.kozaru-command-list-item,
.kozaru-command-stat-row span {
	background: var(--kozaru-ui-panel);
	border-color: var(--kozaru-ui-line);
	border-radius: 14px;
	box-shadow: none;
}

.kozaru-command-list-item {
	border-left: 4px solid var(--kozaru-ui-line);
}

.kozaru-command-card h3,
.kozaru-command-card h4,
.kozaru-frontend-card h3,
.kozaru-registration-box h3,
.kozaru-calendar-event-main h3 {
	font-size: clamp(1.2rem, 2.3vw, 1.65rem);
	font-weight: 750;
	letter-spacing: -0.025em;
	line-height: 1.2;
}

.kozaru-command-stat-row span,
.kozaru-command-stat-list dt,
.kozaru-frontend-meta-list dt,
.kozaru-item-detail-meta dt,
.kozaru-command-eyebrow,
.kozaru-my-details-eyebrow {
	font-weight: 700;
	letter-spacing: 0.035em;
}

.kozaru-command-stat-row strong {
	font-size: clamp(1.45rem, 3vw, 2rem);
	font-weight: 800;
	letter-spacing: -0.035em;
}

.kozaru-portal-card:hover,
.kozaru-portal-card:focus,
.kozaru-managed-student-picker-card:hover,
.kozaru-managed-student-picker-card:focus-visible,
.kozaru-button:hover,
.kozaru-button:focus {
	box-shadow: none;
	transform: none;
}

.kozaru-managed-student-picker-card.is-active,
.kozaru-button.kozaru-button-active,
.kozaru-managed-tab-button.is-active {
	background: var(--kozaru-ui-soft);
	border-color: var(--kozaru-ui-blue);
	box-shadow: none;
	color: var(--kozaru-ui-ink) !important;
}

.kozaru-managed-student-picker-card.is-active .kozaru-command-eyebrow,
.kozaru-managed-student-picker-card.is-active small {
	color: var(--kozaru-ui-muted);
}

.kozaru-button,
.kozaru-button.kozaru-button-secondary,
.kozaru-registration-form .button,
.kozaru-login-form-card .button {
	border-radius: 10px;
	box-shadow: none;
}

.kozaru-managed-tab-panel {
	animation: none;
}

@media screen and (min-width: 960px) {
	body.kozaru-frontend-generated-page .entry-content,
	body.kozaru-frontend-generated-page .wp-block-post-content {
		width: 100%;
	}

	.kozaru-command-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.kozaru-command-card-profile {
		grid-column: span 3;
	}
}

/* =========================================================
Kozaru Honbu - Frontend Layout Refinement v0.2.5.9
---------------------------------------------------------
Keeps generated pages usable on wide themes, makes the student directory
less ridiculous on desktop, and keeps action/detail pages functional without
adding more visual noise. Obi rendering remains untouched.
========================================================= */

body.kozaru-frontend-generated-page .entry-content,
body.kozaru-frontend-generated-page .wp-block-post-content,
body.kozaru-frontend-generated-page .is-layout-constrained,
body.kozaru-frontend-generated-page .is-layout-flow {
	max-width: none !important;
}

body.kozaru-frontend-generated-page .entry-content > .kozaru-frontend-wrap,
body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-frontend-wrap,
body.kozaru-frontend-generated-page .entry-content > .kozaru-calendar-shortcode,
body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-calendar-shortcode,
body.kozaru-frontend-generated-page .entry-content > .kozaru-registration-box,
body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-registration-box {
	margin-left: 50% !important;
	margin-right: 0 !important;
	max-width: min(1560px, calc(100vw - 32px)) !important;
	transform: translateX(-50%);
	width: min(1560px, calc(100vw - 32px)) !important;
}

.kozaru-student-list .kozaru-student-list-grid {
	align-items: stretch;
	grid-template-columns: 1fr;
}

.kozaru-student-list .kozaru-student-list-card {
	min-height: 0;
}

.kozaru-student-list .kozaru-student-list-card-header {
	align-items: center;
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
}

.kozaru-student-list .kozaru-student-list-card-header > div {
	min-width: 0;
}

.kozaru-student-list .kozaru-student-list-card-header h3 {
	font-size: clamp(1.35rem, 2.2vw, 2rem);
	line-height: 1.08;
	margin: 0 0 6px;
}

.kozaru-student-list .kozaru-student-obi {
	align-items: flex-end;
	min-width: 210px;
	text-align: right;
}

.kozaru-student-list .kozaru-student-obi .kozaru-obi-preview {
	transform: scale(0.9);
	transform-origin: right center;
}

.kozaru-registration-landing,
.kozaru-activity-grid {
	margin-bottom: clamp(18px, 3vw, 32px);
}

.kozaru-registration-landing > p:first-of-type {
	color: var(--kozaru-ui-muted);
	margin-top: 6px;
}

.kozaru-registration-landing-list {
	margin-top: 18px;
}

@media screen and (min-width: 980px) {
	.kozaru-student-list .kozaru-student-list-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 782px) {
	body.kozaru-frontend-generated-page .entry-content > .kozaru-frontend-wrap,
	body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-frontend-wrap,
	body.kozaru-frontend-generated-page .entry-content > .kozaru-calendar-shortcode,
	body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-calendar-shortcode,
	body.kozaru-frontend-generated-page .entry-content > .kozaru-registration-box,
	body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-registration-box {
		margin-left: 0 !important;
		transform: none;
		width: 100% !important;
	}

	.kozaru-student-list .kozaru-student-list-card-header {
		align-items: flex-start;
		grid-template-columns: 1fr;
	}

	.kozaru-student-list .kozaru-student-obi {
		align-items: flex-start;
		min-width: 0;
		text-align: left;
	}

	.kozaru-student-list .kozaru-student-obi .kozaru-obi-preview {
		transform-origin: left center;
	}
}

/* v0.2.5.9: frontend form action cleanup */
.kozaru-command-list-actions .kozaru-inline-form,
.kozaru-forms-status-list .kozaru-inline-form {
	border-top: 0;
	margin-top: 0;
	padding-top: 0;
}

/* v0.2.5.9: consolidated portal tabs */
.kozaru-managed-grading-meta,
.kozaru-managed-grading-reasons {
	margin-top: 12px;
}

.kozaru-managed-tab-panel .kozaru-activity-grid {
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
}

/* =========================================================
Kozaru Honbu - Student Portal Refinement v0.2.5.9
---------------------------------------------------------
Keeps the consolidated portal neutral, wider, and less weird on desktop.
Obi rendering remains untouched.
========================================================= */

body.kozaru-frontend-generated-page .entry-content > .kozaru-frontend-wrap,
body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-frontend-wrap,
body.kozaru-frontend-generated-page .entry-content > .kozaru-calendar-shortcode,
body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-calendar-shortcode,
body.kozaru-frontend-generated-page .entry-content > .kozaru-registration-box,
body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-registration-box {
	max-width: min(1800px, calc(100vw - 24px)) !important;
	width: min(1800px, calc(100vw - 24px)) !important;
}

.kozaru-my-managed-students {
	width: min(100%, 1800px);
}

.kozaru-my-managed-students .kozaru-command-hero {
	margin-bottom: clamp(14px, 2.4vw, 22px);
}

.kozaru-managed-students-summary {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
}

.kozaru-managed-student-picker {
	padding: clamp(14px, 2.4vw, 20px);
}

.kozaru-managed-student-picker-heading {
	align-items: end;
}

.kozaru-managed-student-workspace {
	padding: clamp(16px, 2.8vw, 28px);
}

.kozaru-managed-student-detail-header {
	gap: clamp(16px, 3vw, 32px);
	margin-bottom: clamp(14px, 2vw, 20px);
}

.kozaru-managed-student-tabs {
	border-bottom: 1px solid var(--kozaru-ui-line);
	margin: 0 0 clamp(16px, 2.4vw, 22px);
	padding-bottom: 12px;
}

.kozaru-managed-tab-panels {
	min-width: 0;
}

.kozaru-managed-tab-panel > .kozaru-command-grid,
.kozaru-managed-tab-panel .kozaru-activity-grid {
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 340px), 1fr));
}

.kozaru-managed-tab-panel .kozaru-activity-grid .kozaru-command-card-profile,
.kozaru-managed-tab-panel .kozaru-activity-grid .kozaru-activity-overview-card {
	grid-column: auto;
}

.kozaru-activity-overview-card {
	min-height: 0;
}

.kozaru-managed-student-detail-meta {
	background: var(--kozaru-ui-panel);
}

@media screen and (min-width: 1040px) {
	.kozaru-managed-student-detail-header {
		align-items: flex-start;
		display: grid;
		grid-template-columns: minmax(0, 1fr) minmax(220px, 360px);
	}

	.kozaru-managed-student-detail-header .kozaru-student-obi {
		justify-self: end;
		max-width: 360px;
	}
}

@media screen and (min-width: 1280px) {
	.kozaru-managed-tab-panel > .kozaru-command-grid,
	.kozaru-managed-tab-panel .kozaru-activity-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media screen and (max-width: 782px) {
	.kozaru-managed-student-workspace {
		padding: clamp(14px, 4vw, 18px);
	}

	.kozaru-managed-student-tabs {
		border-bottom: 0;
		padding-bottom: 0;
	}
}

/* =========================================================
Kozaru Honbu - Managed Registration Flow v0.2.5.12
---------------------------------------------------------
Adds functional registration actions inside the consolidated student portal.
Neutral on purpose; client themes can dress it up without wrestling a circus.
========================================================= */

.kozaru-managed-student-registration {
	display: grid;
	gap: 16px;
}

.kozaru-managed-registration-heading {
	align-items: start;
	display: grid;
	gap: 12px;
	grid-template-columns: minmax(0, 1fr);
}

.kozaru-managed-registration-heading h4 {
	font-size: clamp(1.1rem, 1.8vw, 1.45rem);
	line-height: 1.2;
	margin: 0;
}

.kozaru-managed-registration-list {
	gap: 10px;
}

.kozaru-managed-registration-item {
	align-items: start;
	gap: 14px;
}

.kozaru-managed-registration-actions {
	align-items: flex-start;
	display: flex;
	justify-content: flex-end;
	min-width: min(100%, 220px);
}

.kozaru-managed-registration-form {
	align-items: flex-end;
	display: grid;
	gap: 8px;
	justify-items: end;
	width: 100%;
}

.kozaru-managed-registration-note {
	width: min(100%, 260px);
}

.kozaru-managed-registration-note summary {
	cursor: pointer;
	font-size: 0.85rem;
	font-weight: 700;
}

.kozaru-managed-registration-note textarea {
	margin-top: 6px;
	min-height: 68px;
	width: 100%;
}

.kozaru-registration-student-single {
	align-items: center;
	background: var(--kozaru-ui-panel);
	border: 1px solid var(--kozaru-ui-line);
	border-radius: var(--kozaru-ui-radius-sm);
	display: flex;
	gap: 10px;
	justify-content: space-between;
	padding: 10px 12px;
}

@media screen and (min-width: 960px) {
	.kozaru-managed-registration-heading {
		align-items: end;
		grid-template-columns: minmax(0, 1fr) minmax(260px, 420px);
	}
}

@media screen and (max-width: 782px) {
	.kozaru-managed-registration-item,
	.kozaru-managed-registration-actions,
	.kozaru-managed-registration-form {
		align-items: stretch;
		justify-content: stretch;
		justify-items: stretch;
	}

	.kozaru-managed-registration-note {
		width: 100%;
	}
}

/* -------------------------------------------------------------------------
Kozaru Honbu - Student Profile Photos v0.2.5.19
------------------------------------------------------------------------- */
.kozaru-profile-photo {
	align-items: center;
	background: #f6f7f7;
	border: 1px solid #dcdcde;
	border-radius: 999px;
	box-sizing: border-box;
	color: #1d2327;
	display: inline-flex;
	font-weight: 800;
	justify-content: center;
	overflow: hidden;
	text-transform: uppercase;
}

.kozaru-profile-photo img,
.kozaru-profile-photo-image {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.kozaru-profile-photo-fallback span {
	line-height: 1;
}

.kozaru-profile-photo-hero {
	font-size: 1.5rem;
	height: 96px;
	width: 96px;
}

.kozaru-profile-photo-card {
	flex: 0 0 54px;
	font-size: 1rem;
	height: 54px;
	width: 54px;
}

.kozaru-profile-photo-mini {
	flex: 0 0 42px;
	font-size: 0.82rem;
	height: 42px;
	width: 42px;
}

.kozaru-student-list-card-identity,
.kozaru-profile-identity-cluster,
.kozaru-command-identity-cluster,
.kozaru-managed-student-picker-identity {
	align-items: center;
	display: flex;
	gap: 12px;
}

.kozaru-command-identity-cluster h3,
.kozaru-student-list-card-identity h3 {
	margin-bottom: 0;
}

.kozaru-managed-student-picker-identity > span:last-child {
	display: grid;
	gap: 2px;
}

.kozaru-managed-student-picker-card.is-active .kozaru-profile-photo {
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.32);
	color: #fff;
}

@media screen and (max-width: 600px) {
	.kozaru-profile-photo-hero {
		font-size: 1.25rem;
		height: 76px;
		width: 76px;
	}

	.kozaru-profile-identity-cluster,
	.kozaru-command-identity-cluster {
		align-items: flex-start;
	}
}

/* -------------------------------------------------------------------------
Kozaru Honbu - Frontend Managed Student Photo Uploads v0.2.5.19
------------------------------------------------------------------------- */
.kozaru-managed-profile-photo-panel {
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 16px;
	box-shadow: 0 8px 22px rgba(15, 23, 42, 0.05);
	display: grid;
	gap: 14px;
	margin-bottom: 18px;
	padding: 16px;
}

.kozaru-managed-profile-photo-current {
	align-items: center;
	display: flex;
	gap: 16px;
}

.kozaru-managed-profile-photo-current h4,
.kozaru-managed-profile-photo-current p {
	margin: 0;
}

.kozaru-managed-profile-photo-current .kozaru-command-empty {
	margin-top: 4px;
}

.kozaru-managed-profile-photo-form {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.kozaru-managed-profile-photo-form label {
	font-weight: 700;
}

.kozaru-managed-profile-photo-form input[type="file"] {
	max-width: 100%;
}

.kozaru-managed-profile-photo-remove-form {
	margin-top: -4px;
}

@media screen and (max-width: 600px) {
	.kozaru-managed-profile-photo-current,
	.kozaru-managed-profile-photo-form {
		align-items: flex-start;
		flex-direction: column;
	}
}

/* -------------------------------------------------------------------------
Kozaru Honbu - Public Instructor Cards v0.2.5.21
------------------------------------------------------------------------- */
.kozaru-instructor-directory {
	max-width: 1180px;
}

.kozaru-instructor-directory-hero {
	background: var(--kozaru-ui-soft, #f6f7f7);
	border: 1px solid var(--kozaru-ui-line, #dcdcde);
	border-radius: 18px;
	margin: 0 0 22px;
	padding: clamp(20px, 4vw, 34px);
}

.kozaru-instructor-directory-hero h2 {
	font-size: clamp(2rem, 5vw, 3.2rem);
	font-weight: 850;
	letter-spacing: -0.045em;
	line-height: 1.05;
	margin: 0 0 10px;
}

.kozaru-instructor-directory-hero p {
	color: var(--kozaru-ui-muted, #50575e);
	font-size: 1.05rem;
	line-height: 1.55;
	margin: 0;
	max-width: 760px;
}

.kozaru-instructor-card-grid {
	display: grid;
	gap: 22px;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	margin: 20px 0;
}

.kozaru-instructor-card {
	display: grid;
	gap: 20px;
	grid-template-columns: 150px minmax(0, 1fr);
	min-height: 260px;
	padding: clamp(20px, 3vw, 28px);
}

.kozaru-instructor-card-media {
	align-items: flex-start;
	display: flex;
	justify-content: center;
}

.kozaru-profile-photo-instructor {
	box-shadow: 0 14px 34px rgba(17, 24, 39, 0.10);
	font-size: 2.4rem;
	height: 140px;
	width: 140px;
}

.kozaru-instructor-card-body {
	min-width: 0;
}

.kozaru-instructor-card .kozaru-command-eyebrow {
	margin: 0 0 8px;
}

.kozaru-instructor-card h3 {
	font-size: clamp(1.55rem, 3vw, 2.1rem);
	margin: 0 0 8px;
}

.kozaru-instructor-card-title,
.kozaru-instructor-card-rank {
	color: var(--kozaru-ui-muted, #50575e);
	font-weight: 700;
	margin: 0 0 6px;
}

.kozaru-instructor-card-rank {
	font-size: 0.94rem;
}

.kozaru-instructor-card-obi {
	margin: 12px 0 0;
}

.kozaru-instructor-card-obi .kozaru-student-obi {
	align-items: flex-start;
	min-width: 0;
	text-align: left;
}

.kozaru-instructor-card-obi .kozaru-student-obi .kozaru-obi-preview {
	transform: scale(0.9);
	transform-origin: left center;
}

.kozaru-instructor-card-bio {
	border-top: 1px solid var(--kozaru-ui-line, #dcdcde);
	color: var(--kozaru-ui-ink, #1d2327);
	line-height: 1.62;
	margin-top: 16px;
	padding-top: 16px;
}

.kozaru-instructor-card-bio p {
	margin: 0 0 12px;
}

.kozaru-instructor-card-bio p:last-child {
	margin-bottom: 0;
}

.kozaru-instructor-card-bio-expandable summary {
	cursor: pointer;
	display: block;
	list-style: none;
}

.kozaru-instructor-card-bio-expandable summary::-webkit-details-marker {
	display: none;
}

.kozaru-instructor-bio-preview {
	display: block;
	margin-bottom: 10px;
}

.kozaru-instructor-bio-toggle {
	align-items: center;
	background: var(--kozaru-ui-soft, #f6f7f7);
	border: 1px solid var(--kozaru-ui-line, #dcdcde);
	border-radius: 999px;
	color: var(--kozaru-ui-ink, #1d2327);
	display: inline-flex;
	font-size: 0.82rem;
	font-weight: 800;
	gap: 6px;
	line-height: 1;
	padding: 8px 11px;
}

.kozaru-instructor-bio-toggle::after {
	content: "↓";
	font-size: 0.8em;
}

.kozaru-instructor-bio-toggle-less {
	display: none;
	margin-top: 14px;
}

.kozaru-instructor-bio-toggle-less::after {
	content: "↑";
}

.kozaru-instructor-card-bio-expandable[open] .kozaru-instructor-bio-preview,
.kozaru-instructor-card-bio-expandable[open] .kozaru-instructor-bio-toggle-more {
	display: none;
}

.kozaru-instructor-card-bio-expandable[open] .kozaru-instructor-bio-toggle-less {
	display: inline-flex;
}

.kozaru-instructor-bio-full {
	margin-top: 0;
}

@media screen and (max-width: 782px) {
	.kozaru-instructor-card-grid {
		grid-template-columns: 1fr;
	}

	.kozaru-instructor-card {
		grid-template-columns: 1fr;
	}

	.kozaru-instructor-card-media {
		justify-content: flex-start;
	}

	.kozaru-profile-photo-instructor {
		height: 112px;
		width: 112px;
	}
}

/* Instructor accreditations - v0.2.5.22 */

.kozaru-status-due_90,
.kozaru-status-current,
.kozaru-status-no_expiry {
	background: #eef5ff;
	color: #0a4b78;
}

.kozaru-status-due_60 {
	background: #fff8e5;
	color: #7a4d00;
}

.kozaru-status-due_30 {
	background: #fff4f4;
	color: #8a2424;
}

.kozaru-status-expired,
.kozaru-status-revoked {
	background: #fcf0f1;
	color: #8a2424;
}

.kozaru-instructor-accreditation-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 14px 0 0;
}

.kozaru-accreditation-pill {
	align-items: center;
	background: #f6f7f7;
	border: 1px solid #dcdcde;
	border-radius: 999px;
	color: #1d2327;
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.01em;
	line-height: 1;
	padding: 7px 10px;
}

.kozaru-accreditation-pill-current,
.kozaru-accreditation-pill-no_expiry {
	background: #edfaef;
	border-color: #b8e8c0;
	color: #0a6b1d;
}

.kozaru-accreditation-pill-due_90,
.kozaru-accreditation-pill-due_60,
.kozaru-accreditation-pill-due_30 {
	background: #fff8e5;
	border-color: #f0c36d;
	color: #7a4d00;
}

/* =========================================================
Kozaru Honbu - Cleanup Layout Stabilisation v0.2.5.24
---------------------------------------------------------
Final layout guardrails after the v0.2.5 feature sprint. This keeps frontend
shortcode pages wide, prevents mobile overflow from nested cards/forms, and
leaves Obi rendering unchanged so the belt display remains stable.
========================================================= */

.kozaru-frontend-wrap,
.kozaru-frontend-wrap *,
.kozaru-calendar-shortcode,
.kozaru-calendar-shortcode *,
.kozaru-registration-box,
.kozaru-registration-box * {
	box-sizing: border-box;
}

.kozaru-frontend-wrap input[type="text"],
.kozaru-frontend-wrap input[type="email"],
.kozaru-frontend-wrap input[type="number"],
.kozaru-frontend-wrap input[type="date"],
.kozaru-frontend-wrap input[type="time"],
.kozaru-frontend-wrap input[type="url"],
.kozaru-frontend-wrap input[type="password"],
.kozaru-frontend-wrap select,
.kozaru-frontend-wrap textarea,
.kozaru-registration-box input[type="text"],
.kozaru-registration-box input[type="email"],
.kozaru-registration-box input[type="number"],
.kozaru-registration-box input[type="date"],
.kozaru-registration-box input[type="time"],
.kozaru-registration-box input[type="url"],
.kozaru-registration-box input[type="password"],
.kozaru-registration-box select,
.kozaru-registration-box textarea {
	max-width: 100%;
}

.kozaru-command-card,
.kozaru-frontend-card,
.kozaru-registration-box,
.kozaru-calendar-event-card,
.kozaru-instructor-card,
.kozaru-managed-student-picker-card,
.kozaru-managed-student-workspace,
.kozaru-managed-tab-panel {
	min-width: 0;
	overflow-wrap: anywhere;
}

body.kozaru-frontend-generated-page .entry-content > .kozaru-frontend-wrap,
body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-frontend-wrap,
body.kozaru-frontend-generated-page .entry-content > .kozaru-calendar-shortcode,
body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-calendar-shortcode,
body.kozaru-frontend-generated-page .entry-content > .kozaru-registration-box,
body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-registration-box {
	max-width: min(1800px, calc(100vw - 24px)) !important;
	width: min(1800px, calc(100vw - 24px)) !important;
}

.kozaru-instructor-card-grid,
.kozaru-command-grid,
.kozaru-frontend-card-grid,
.kozaru-portal-card-grid {
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
}

.kozaru-instructor-card-media,
.kozaru-student-list-card-header,
.kozaru-managed-student-detail-header,
.kozaru-profile-identity-cluster,
.kozaru-command-identity-cluster {
	min-width: 0;
}

.kozaru-table-scroll {
	overflow-x: auto;
}

@media screen and (max-width: 782px) {
	body.kozaru-frontend-generated-page .entry-content > .kozaru-frontend-wrap,
	body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-frontend-wrap,
	body.kozaru-frontend-generated-page .entry-content > .kozaru-calendar-shortcode,
	body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-calendar-shortcode,
	body.kozaru-frontend-generated-page .entry-content > .kozaru-registration-box,
	body.kozaru-frontend-generated-page .wp-block-post-content > .kozaru-registration-box {
		margin-left: auto !important;
		margin-right: auto !important;
		max-width: calc(100vw - 20px) !important;
		padding-left: 10px;
		padding-right: 10px;
		transform: none !important;
		width: calc(100vw - 20px) !important;
	}

	.kozaru-command-grid,
	.kozaru-frontend-card-grid,
	.kozaru-portal-card-grid,
	.kozaru-instructor-card-grid,
	.kozaru-my-details-grid,
	.kozaru-managed-students-summary {
		grid-template-columns: 1fr !important;
	}

	.kozaru-command-list-actions,
	.kozaru-form-actions,
	.kozaru-frontend-card-actions,
	.kozaru-calendar-event-actions,
	.kozaru-managed-registration-actions,
	.kozaru-item-detail-actions {
		align-items: stretch;
		flex-direction: column;
	}

	.kozaru-command-list-actions .kozaru-button,
	.kozaru-form-actions .kozaru-button,
	.kozaru-frontend-card-actions .kozaru-button,
	.kozaru-calendar-event-actions .kozaru-button,
	.kozaru-managed-registration-actions .kozaru-button,
	.kozaru-item-detail-actions .kozaru-button,
	.kozaru-command-list-actions .button,
	.kozaru-form-actions .button,
	.kozaru-frontend-card-actions .button,
	.kozaru-calendar-event-actions .button,
	.kozaru-managed-registration-actions .button,
	.kozaru-item-detail-actions .button {
		justify-content: center;
		text-align: center;
		width: 100%;
	}
}

/* =========================================================
Kozaru Honbu - Frontend Staff Interface v0.2.6.6
---------------------------------------------------------
Private instructor/dojo-manager screens. Same visual language as the student
command centre, tuned for operational tables, wide desktop use, and sane
mobile behaviour.
========================================================= */

.kozaru-staff-interface {
	margin-left: auto;
	margin-right: auto;
}

.kozaru-staff-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0 0 18px;
}

.kozaru-staff-tab {
	align-items: center;
	background: #f8fafc;
	border: 1px solid #d7dee8;
	border-radius: 999px;
	color: #1f2937;
	display: inline-flex;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.2;
	padding: 9px 13px;
	text-decoration: none;
}

.kozaru-staff-tab:hover,
.kozaru-staff-tab:focus,
.kozaru-staff-tab.is-active {
	background: #111827;
	border-color: #111827;
	color: #fff;
	outline: none;
	text-decoration: none;
}

.kozaru-staff-hero {
	margin-bottom: 18px;
}

.kozaru-staff-metric-row {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 180px), 1fr));
	margin: 0 0 18px;
}

.kozaru-staff-metric {
	background: #fff;
	border: 1px solid #d7dee8;
	border-radius: 16px;
	box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
	padding: 16px;
}

.kozaru-staff-metric strong {
	color: #111827;
	font-size: clamp(28px, 4vw, 42px);
	line-height: 1;
}

.kozaru-staff-metric span {
	color: #374151;
	font-weight: 800;
}

.kozaru-staff-metric small {
	color: #6b7280;
}

.kozaru-staff-layout-grid {
	align-items: start;
}

.kozaru-staff-card-header {
	align-items: flex-start;
	display: flex;
	gap: 12px;
	justify-content: space-between;
	margin-bottom: 14px;
}

.kozaru-staff-session-item {
	align-items: flex-start;
}

.kozaru-staff-session-item .kozaru-command-item-main span {
	display: block;
}

.kozaru-staff-table {
	min-width: 760px;
}

.kozaru-staff-grading-table {
	min-width: 980px;
}

.kozaru-staff-inline-form {
	display: grid;
	gap: 8px;
	min-width: 220px;
}

.kozaru-staff-inline-form select,
.kozaru-staff-inline-form textarea,
.kozaru-staff-inline-form button {
	width: 100%;
}

.kozaru-staff-reason-list {
	margin: 6px 0 0 18px;
}

.kozaru-staff-reason-list li {
	color: #6b7280;
	font-size: 12px;
	margin: 0 0 3px;
}

.kozaru-staff-search-form {
	align-items: end;
	display: grid;
	gap: 12px;
	grid-template-columns: minmax(0, 1fr) auto;
}

.kozaru-staff-search-form label {
	display: grid;
	gap: 6px;
}

.kozaru-staff-search-form input[type="search"] {
	max-width: 100%;
	width: 100%;
}

.kozaru-staff-action-card p:last-child {
	margin-bottom: 0;
}

@media screen and (min-width: 1100px) {
	.kozaru-staff-layout-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 782px) {
	.kozaru-staff-tabs {
		flex-wrap: nowrap;
		overflow-x: auto;
		padding-bottom: 4px;
		white-space: nowrap;
	}

	.kozaru-staff-tab {
		flex: 0 0 auto;
	}

	.kozaru-staff-card-header,
	.kozaru-staff-session-item {
		flex-direction: column;
	}

	.kozaru-staff-search-form {
		grid-template-columns: 1fr;
	}

	.kozaru-staff-search-form .kozaru-button,
	.kozaru-staff-search-form button {
		justify-content: center;
		width: 100%;
	}
}

/* 0.2.6.6 consolidated staff dashboard refinements */
.kozaru-staff-section-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 16px;
}

.kozaru-staff-section {
	margin: 24px 0 0;
	scroll-margin-top: 24px;
}

.kozaru-staff-section-header {
	align-items: flex-start;
	display: flex;
	gap: 16px;
	justify-content: space-between;
	margin: 0 0 14px;
}

.kozaru-staff-section-header h3 {
	font-size: clamp(22px, 3vw, 30px);
	line-height: 1.15;
	margin: 0 0 6px;
}

.kozaru-staff-section-header p:last-child {
	margin-bottom: 0;
}

.kozaru-staff-pill-row {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: 8px;
}

.kozaru-staff-count-pill {
	background: #eef2f7;
	border: 1px solid #d7dee8;
	border-radius: 999px;
	color: #374151;
	display: inline-flex;
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	padding: 6px 8px;
}

.kozaru-staff-count-pill-hot {
	background: #fff7ed;
	border-color: #fed7aa;
	color: #9a3412;
}

.kozaru-staff-create-grid {
	align-items: stretch;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
	margin-bottom: 16px;
}

.kozaru-staff-create-panel {
	background: #fff;
	border: 1px solid #d7dee8;
	border-radius: 16px;
	box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
	padding: 0;
}

.kozaru-staff-create-panel summary {
	cursor: pointer;
	font-weight: 900;
	padding: 16px 18px;
}

.kozaru-staff-create-panel[open] summary {
	border-bottom: 1px solid #e5e7eb;
}

.kozaru-staff-create-form {
	padding: 18px;
}

.kozaru-staff-checkbox-grid {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
	margin: 12px 0;
}

.kozaru-staff-trial-list .kozaru-command-list-item {
	border-left: 4px solid #fed7aa;
}

@media screen and (min-width: 1100px) {
	.kozaru-staff-interface {
		max-width: none;
		width: 100%;
	}
}

@media screen and (max-width: 782px) {
	.kozaru-staff-section-nav {
		flex-direction: column;
	}

	.kozaru-staff-section-nav .kozaru-button {
		justify-content: center;
		width: 100%;
	}

	.kozaru-staff-section-header {
		flex-direction: column;
	}

	.kozaru-staff-create-form {
		padding: 14px;
	}
}

/* =========================================================
Kozaru Honbu - Frontend Staff Dashboard Consolidation v0.2.6.6
---------------------------------------------------------
Two dashboards only: instructor and dojo manager. Sections live in-page.
========================================================= */

.kozaru-staff-section {
	scroll-margin-top: 90px;
}

.kozaru-staff-section + .kozaru-staff-section {
	margin-top: 28px;
}

.kozaru-staff-section-header {
	margin: 0 0 14px;
}

.kozaru-staff-section-header h2 {
	font-size: clamp(24px, 3vw, 34px);
	line-height: 1.15;
	margin: 0 0 6px;
}

.kozaru-staff-section-header p:last-child {
	color: #4b5563;
	margin-bottom: 0;
}

.kozaru-staff-overview-grid {
	margin-bottom: 24px;
}

.kozaru-staff-manager-actions {
	margin-bottom: 16px;
}

.kozaru-staff-button-row {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.kozaru-manager-action-grid .kozaru-frontend-card-actions {
	align-items: flex-start;
}

@media screen and (max-width: 782px) {
	.kozaru-staff-button-row {
		align-items: stretch;
		flex-direction: column;
	}

	.kozaru-staff-button-row .kozaru-button,
	.kozaru-staff-button-row .button {
		justify-content: center;
		width: 100%;
	}
}

/* Kozaru Honbu v0.2.6.6 - consolidated staff dashboard form layout */
.kozaru-staff-manager-form {
	margin-bottom: 16px;
}

.kozaru-staff-edit-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
}

.kozaru-staff-edit-grid label {
	display: grid;
	gap: 6px;
}

.kozaru-staff-edit-wide {
	grid-column: 1 / -1;
}

.kozaru-staff-checkbox-grid {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
}

.kozaru-staff-checkbox-grid label {
	align-items: center;
	display: flex;
	gap: 8px;
}

/* Kozaru Honbu v0.2.6.6 - staff dashboard tab behaviour */
.kozaru-staff-tab[aria-current="page"] {
	background: #111827;
	border-color: #111827;
	color: #fff;
}

.kozaru-staff-tab-panel {
	animation: kozaruStaffTabFade 0.16s ease-out;
}

@keyframes kozaruStaffTabFade {
	from {
		opacity: 0;
		transform: translateY(4px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* =========================================================
Kozaru Honbu - Email System Preview/Test + Contact Log v0.2.7.7
========================================================= */

/* -------------------------------------------------------------------------
Kozaru Honbu - Staff Email Workflows v0.2.7.7
------------------------------------------------------------------------- */
.kozaru-staff-student-detail-view,
.kozaru-staff-group-email-view {
	display: grid;
	gap: 1rem;
}

.kozaru-staff-student-heading {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.kozaru-staff-student-detail-grid,
.kozaru-staff-email-context-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1rem;
	margin-top: 1rem;
}

.kozaru-staff-email-form {
	display: grid;
	gap: 1rem;
}

.kozaru-staff-email-form label,
.kozaru-staff-email-context-grid label {
	display: grid;
	gap: 0.35rem;
	font-weight: 600;
}

.kozaru-staff-email-form input[type="text"],
.kozaru-staff-email-form select,
.kozaru-staff-email-form textarea,
.kozaru-staff-email-context-grid input[type="text"] {
	width: 100%;
	max-width: 100%;
}

.kozaru-staff-email-preview {
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 14px;
	padding: 1rem;
	background: rgba(0, 0, 0, 0.025);
	margin-top: 1rem;
}

.kozaru-staff-email-preview pre {
	white-space: pre-wrap;
	font-family: inherit;
	line-height: 1.55;
	margin: 0.75rem 0 0;
}

.kozaru-staff-email-send-confirm {
	margin-top: 1rem;
}

.kozaru-checkbox-row {
	display: flex !important;
	align-items: center;
	gap: 0.5rem;
	font-weight: 500 !important;
}

@media (max-width: 700px) {
	.kozaru-staff-student-heading {
		align-items: flex-start;
	}

	.kozaru-staff-student-detail-grid,
	.kozaru-staff-email-context-grid {
		grid-template-columns: 1fr;
	}
}

/* -------------------------------------------------------------------------
Kozaru Honbu - Staff Dashboard + Contact Log Polish v0.2.7.7
------------------------------------------------------------------------- */
.kozaru-staff-interface {
	max-width: min(1560px, calc(100vw - 32px));
	padding: 0 0 28px;
	width: 100%;
}

.kozaru-staff-tabs {
	align-items: center;
	background: rgba(255, 255, 255, 0.92);
	border: 1px solid #d7dee8;
	border-radius: 18px;
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.07);
	gap: 6px;
	margin: 0 0 20px;
	padding: 8px;
}

.kozaru-staff-tab {
	justify-content: center;
	min-height: 38px;
}

.kozaru-staff-section-header {
	background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
	border: 1px solid #d7dee8;
	border-radius: 20px;
	box-shadow: 0 10px 26px rgba(15, 23, 42, 0.06);
	display: block;
	margin: 0 0 18px;
	padding: clamp(18px, 2.4vw, 28px);
}

.kozaru-staff-section-header .kozaru-command-eyebrow {
	margin: 0 0 6px;
}

.kozaru-staff-section-header h2,
.kozaru-staff-section-header h3 {
	font-size: clamp(26px, 3vw, 42px);
	letter-spacing: -0.035em;
	line-height: 1.05;
	margin: 0 0 8px;
}

.kozaru-staff-section-header p:last-child {
	color: #4b5563;
	font-size: clamp(15px, 1.4vw, 18px);
	line-height: 1.45;
	max-width: 820px;
}

.kozaru-staff-metric-row,
.kozaru-staff-contact-summary-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 190px), 1fr));
	margin: 0 0 18px;
}

.kozaru-staff-contact-summary-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.kozaru-staff-follow-up-grid {
	align-items: start;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 420px), 1fr));
	margin-bottom: 18px;
}

.kozaru-staff-contact-log-section .kozaru-command-card-header,
.kozaru-staff-email-card .kozaru-command-card-header,
.kozaru-staff-contact-log-card .kozaru-command-card-header {
	align-items: flex-start;
	gap: 12px;
}

.kozaru-staff-contact-log-section .kozaru-command-card-header p,
.kozaru-staff-email-card .kozaru-command-card-header p,
.kozaru-staff-contact-log-card .kozaru-command-card-header p {
	margin-bottom: 0;
}

.kozaru-staff-contact-log-table,
.kozaru-staff-follow-up-table {
	min-width: 900px;
}

.kozaru-staff-follow-up-table .kozaru-button,
.kozaru-staff-contact-log-table .kozaru-button {
	white-space: nowrap;
}

.kozaru-staff-student-profile-card .kozaru-frontend-card-actions {
	border-top: 1px solid #e5e7eb;
	margin-top: 16px;
	padding-top: 16px;
}

.kozaru-staff-email-preview {
	background: #f8fafc;
	border-color: #d7dee8;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

@media screen and (min-width: 1200px) {
	.kozaru-staff-overview-grid {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	}

	.kozaru-staff-layout-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.kozaru-staff-section#kozaru-staff-section-students > .kozaru-command-card:last-child,
	.kozaru-staff-contact-log-section > .kozaru-staff-contact-log-card {
		grid-column: 1 / -1;
	}
}

@media screen and (max-width: 782px) {
	.kozaru-staff-interface {
		max-width: calc(100vw - 20px);
		padding-left: 0;
		padding-right: 0;
	}

	.kozaru-staff-tabs {
		border-radius: 14px;
		margin-left: 0;
		margin-right: 0;
		overflow-x: auto;
		padding: 6px;
	}

	.kozaru-staff-tab {
		font-size: 12px;
		min-width: max-content;
		padding: 9px 11px;
	}

	.kozaru-staff-section-header {
		border-radius: 16px;
		padding: 18px;
	}

	.kozaru-staff-section-header h2,
	.kozaru-staff-section-header h3 {
		font-size: 28px;
	}

	.kozaru-staff-contact-summary-grid,
	.kozaru-staff-follow-up-grid,
	.kozaru-staff-layout-grid {
		grid-template-columns: 1fr !important;
	}

	.kozaru-staff-contact-log-section .kozaru-command-card-header,
	.kozaru-staff-email-card .kozaru-command-card-header,
	.kozaru-staff-contact-log-card .kozaru-command-card-header {
		align-items: flex-start;
		flex-direction: column;
	}
}

/* -------------------------------------------------------------------------
Kozaru Honbu - Waiver Tracking v0.2.7.7
------------------------------------------------------------------------- */
.kozaru-staff-waiver-summary-grid {
	align-items: stretch;
}

.kozaru-staff-waiver-status-card .kozaru-command-card-header,
.kozaru-staff-waiver-attention-card .kozaru-command-card-header,
.kozaru-staff-waiver-all-card .kozaru-command-card-header {
	gap: 1rem;
}

.kozaru-waiver-status-list {
	margin-top: 1rem;
}

.kozaru-waiver-status-table td,
.kozaru-waiver-status-table th {
	vertical-align: top;
}

.kozaru-waiver-consent-text {
	background: rgba(15, 23, 42, 0.04);
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: 16px;
	margin: 0.75rem 0 1rem;
	max-height: 24rem;
	overflow: auto;
	padding: 1rem;
}

.kozaru-waiver-consent-text p {
	margin: 0 0 0.85rem;
}

.kozaru-waiver-consent-text p:last-child {
	margin-bottom: 0;
}

.kozaru-status-complete {
	background: rgba(34, 197, 94, 0.12);
	color: #166534;
}

.kozaru-status-missing,
.kozaru-status-expired,
.kozaru-status-revoked {
	background: rgba(239, 68, 68, 0.12);
	color: #991b1b;
}

@media (max-width: 720px) {
	.kozaru-waiver-consent-text {
		max-height: 18rem;
	}
}

/* Kozaru Honbu v0.2.7.9 - groups, categories, birthdays */
.kozaru-group-pill,
.kozaru-class-category-pill {
	--kozaru-pill-colour: #2271b1;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	border: 1px solid rgba(34, 113, 177, 0.22);
	border-left: 4px solid var(--kozaru-pill-colour);
	border-radius: 999px;
	padding: 0.22rem 0.6rem;
	font-size: 0.78rem;
	font-weight: 700;
	line-height: 1.25;
	background: #fff;
	color: #1d2327;
	text-decoration: none;
}

.kozaru-class-category-pill {
	--kozaru-pill-colour: var(--kozaru-category-colour, #2271b1);
}

.kozaru-group-pill:hover,
.kozaru-class-category-pill:hover {
	color: #1d2327;
	text-decoration: none;
}

.kozaru-pill-row,
.kozaru-pill-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	align-items: center;
	margin-top: 0.35rem;
}

.kozaru-staff-member-checkbox-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 0.45rem 0.8rem;
	max-height: 22rem;
	overflow: auto;
	padding: 0.85rem;
	border: 1px solid rgba(0, 0, 0, 0.12);
	border-radius: 14px;
	background: #fff;
}

.kozaru-staff-member-checkbox-list label {
	display: flex;
	gap: 0.45rem;
	align-items: flex-start;
}

.kozaru-birthday-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.65rem;
}

.kozaru-birthday-list li {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	padding-bottom: 0.65rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.kozaru-birthday-list li:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

@media (max-width: 640px) {
	.kozaru-birthday-list li {
		flex-direction: column;
		gap: 0.2rem;
	}
}

.kozaru-staff-edit-subsection {
	margin-top: 0.75rem;
}

.kozaru-staff-edit-subsection h4 {
	margin: 0;
	font-size: 1rem;
}

/* Kozaru Honbu v0.2.7.9 - category-led schedules and birthday fixes */
.kozaru-staff-session-item,
.kozaru-calendar-event-card {
	border-left: 6px solid var(--kozaru-category-colour, #2271b1);
}

.kozaru-calendar-event-meta .kozaru-class-category-pill,
.kozaru-staff-session-item .kozaru-class-category-pill {
	margin-right: 0.25rem;
}

.kozaru-staff-edit-grid,
.kozaru-staff-create-form .kozaru-form-grid,
.kozaru-staff-manager-form .kozaru-form-grid {
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
}

.kozaru-staff-manager-form input,
.kozaru-staff-manager-form select,
.kozaru-staff-manager-form textarea,
.kozaru-staff-create-form input,
.kozaru-staff-create-form select,
.kozaru-staff-create-form textarea {
	max-width: 100%;
	box-sizing: border-box;
}

@media (max-width: 720px) {
	.kozaru-staff-manager-form,
	.kozaru-staff-create-form {
		overflow-x: hidden;
	}

	.kozaru-staff-checkbox-grid {
		grid-template-columns: 1fr;
	}
}

/* =========================================================
Kozaru Honbu v0.2.7.10 - frontend usability tidy
---------------------------------------------------------
Keep desktop wide, but stop mobile forms/cards/buttons from escaping the
viewport. This pass intentionally leaves the Obi system untouched.
========================================================= */

.kozaru-frontend-wrap,
.kozaru-frontend-wrap *,
.kozaru-frontend-wrap *::before,
.kozaru-frontend-wrap *::after,
.kozaru-calendar-shortcode,
.kozaru-calendar-shortcode *,
.kozaru-calendar-shortcode *::before,
.kozaru-calendar-shortcode *::after,
.kozaru-registration-box,
.kozaru-registration-box *,
.kozaru-registration-box *::before,
.kozaru-registration-box *::after {
	box-sizing: border-box;
}

.kozaru-command-card,
.kozaru-frontend-card,
.kozaru-registration-box,
.kozaru-calendar-event-card,
.kozaru-managed-student-workspace,
.kozaru-managed-tab-panel,
.kozaru-staff-create-panel {
	max-width: 100%;
	min-width: 0;
	overflow-wrap: anywhere;
}

.kozaru-frontend-wrap input,
.kozaru-frontend-wrap select,
.kozaru-frontend-wrap textarea,
.kozaru-registration-box input,
.kozaru-registration-box select,
.kozaru-registration-box textarea {
	max-width: 100%;
}

.kozaru-frontend-wrap .description,
.kozaru-muted {
	overflow-wrap: anywhere;
}

.kozaru-table-scroll {
	max-width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.kozaru-label-with-help {
	align-items: center;
	display: inline-flex;
	gap: 0.4rem;
	min-width: 0;
}

.kozaru-help-tip {
	align-items: center;
	background: #eef2f7;
	border: 1px solid #cbd5e1;
	border-radius: 999px;
	color: #334155;
	cursor: help;
	display: inline-flex;
	font-size: 0.72rem;
	font-weight: 900;
	height: 1.25rem;
	justify-content: center;
	line-height: 1;
	position: relative;
	text-decoration: none;
	width: 1.25rem;
}

.kozaru-help-tip::after {
	background: #111827;
	border-radius: 10px;
	bottom: calc(100% + 8px);
	box-shadow: 0 12px 28px rgba(15, 23, 42, 0.22);
	color: #fff;
	content: attr(data-kozaru-help);
	font-size: 0.78rem;
	font-weight: 650;
	left: 50%;
	line-height: 1.35;
	max-width: min(280px, calc(100vw - 36px));
	opacity: 0;
	padding: 0.65rem 0.75rem;
	pointer-events: none;
	position: absolute;
	text-transform: none;
	transform: translate(-50%, 4px);
	transition: opacity 0.12s ease, transform 0.12s ease;
	visibility: hidden;
	white-space: normal;
	width: max-content;
	z-index: 1000;
}

.kozaru-help-tip:hover::after,
.kozaru-help-tip:focus::after,
.kozaru-help-tip:focus-visible::after {
	opacity: 1;
	transform: translate(-50%, 0);
	visibility: visible;
}

.kozaru-staff-interface {
	max-width: none;
	width: 100%;
}

.kozaru-staff-interface .kozaru-command-card,
.kozaru-staff-interface .kozaru-frontend-card {
	border: 1px solid #dde4ee;
	border-radius: 22px;
}

.kozaru-staff-create-form,
.kozaru-staff-manager-form form,
.kozaru-staff-edit-grid,
.kozaru-staff-create-form .kozaru-form-grid {
	max-width: 100%;
	min-width: 0;
}

.kozaru-staff-edit-grid,
.kozaru-staff-create-form .kozaru-form-grid,
.kozaru-staff-manager-form .kozaru-form-grid {
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
}

.kozaru-staff-edit-grid > label,
.kozaru-staff-create-form label,
.kozaru-staff-manager-form label,
.kozaru-self-service-form label,
.kozaru-registration-box label {
	min-width: 0;
}

.kozaru-staff-edit-grid label > span,
.kozaru-staff-create-form label > span,
.kozaru-staff-manager-form label > span,
.kozaru-self-service-form label > span,
.kozaru-registration-box label > span {
	font-weight: 850;
	line-height: 1.25;
}

.kozaru-staff-checkbox-grid,
.kozaru-staff-member-checkbox-list {
	max-width: 100%;
	min-width: 0;
}

.kozaru-staff-checkbox-grid label,
.kozaru-staff-member-checkbox-list label {
	border-radius: 12px;
	min-width: 0;
	overflow-wrap: anywhere;
	padding: 0.15rem 0;
}

.kozaru-command-list-actions,
.kozaru-form-actions,
.kozaru-frontend-card-actions,
.kozaru-calendar-event-actions,
.kozaru-managed-registration-actions,
.kozaru-item-detail-actions,
.kozaru-staff-button-row {
	max-width: 100%;
}

.kozaru-command-list-actions .kozaru-button,
.kozaru-command-list-actions .button,
.kozaru-form-actions .kozaru-button,
.kozaru-form-actions .button,
.kozaru-frontend-card-actions .kozaru-button,
.kozaru-frontend-card-actions .button,
.kozaru-calendar-event-actions .kozaru-button,
.kozaru-calendar-event-actions .button,
.kozaru-managed-registration-actions .kozaru-button,
.kozaru-managed-registration-actions .button,
.kozaru-item-detail-actions .kozaru-button,
.kozaru-item-detail-actions .button,
.kozaru-staff-button-row .kozaru-button,
.kozaru-staff-button-row .button {
	max-width: 100%;
	min-width: 0;
	white-space: normal;
}

@media screen and (min-width: 1180px) {
	.kozaru-frontend-wrap.kozaru-staff-interface,
	.kozaru-staff-interface {
		max-width: none;
		padding-left: clamp(20px, 2vw, 36px);
		padding-right: clamp(20px, 2vw, 36px);
		width: 100%;
	}

	.kozaru-staff-layout-grid,
	.kozaru-staff-overview-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 782px) {
	.kozaru-frontend-wrap,
	.kozaru-calendar-shortcode,
	.kozaru-registration-box,
	.kozaru-staff-interface {
		max-width: 100%;
		overflow-x: hidden;
		padding-left: 10px;
		padding-right: 10px;
		width: 100%;
	}

	.kozaru-staff-tabs {
		flex-wrap: nowrap;
		overflow-x: auto;
		padding-bottom: 6px;
		-webkit-overflow-scrolling: touch;
	}

	.kozaru-staff-tab {
		flex: 0 0 auto;
	}

	.kozaru-command-grid,
	.kozaru-frontend-card-grid,
	.kozaru-portal-card-grid,
	.kozaru-staff-layout-grid,
	.kozaru-staff-overview-grid,
	.kozaru-staff-contact-summary-grid,
	.kozaru-staff-follow-up-grid,
	.kozaru-staff-edit-grid,
	.kozaru-staff-create-form .kozaru-form-grid,
	.kozaru-staff-manager-form .kozaru-form-grid {
		grid-template-columns: minmax(0, 1fr) !important;
	}

	.kozaru-command-card,
	.kozaru-frontend-card,
	.kozaru-registration-box,
	.kozaru-calendar-event-card,
	.kozaru-managed-student-workspace,
	.kozaru-managed-tab-panel,
	.kozaru-staff-create-panel {
		border-radius: 18px;
		padding: 16px;
	}

	.kozaru-staff-create-form,
	.kozaru-staff-manager-form form {
		padding: 14px;
	}

	.kozaru-staff-card-header,
	.kozaru-command-card-header,
	.kozaru-staff-section-header,
	.kozaru-command-list-item,
	.kozaru-staff-session-item,
	.kozaru-birthday-list li {
		align-items: stretch;
		flex-direction: column;
	}

	.kozaru-frontend-wrap input:not([type="checkbox"]):not([type="radio"]):not([type="color"]),
	.kozaru-frontend-wrap select,
	.kozaru-frontend-wrap textarea,
	.kozaru-registration-box input:not([type="checkbox"]):not([type="radio"]):not([type="color"]),
	.kozaru-registration-box select,
	.kozaru-registration-box textarea {
		min-height: 44px;
		width: 100% !important;
	}

	.kozaru-form-actions,
	.kozaru-command-list-actions,
	.kozaru-frontend-card-actions,
	.kozaru-calendar-event-actions,
	.kozaru-managed-registration-actions,
	.kozaru-item-detail-actions,
	.kozaru-staff-button-row {
		display: grid;
		grid-template-columns: minmax(0, 1fr);
	}

	.kozaru-form-actions .kozaru-button,
	.kozaru-form-actions .button,
	.kozaru-command-list-actions .kozaru-button,
	.kozaru-command-list-actions .button,
	.kozaru-frontend-card-actions .kozaru-button,
	.kozaru-frontend-card-actions .button,
	.kozaru-calendar-event-actions .kozaru-button,
	.kozaru-calendar-event-actions .button,
	.kozaru-managed-registration-actions .kozaru-button,
	.kozaru-managed-registration-actions .button,
	.kozaru-item-detail-actions .kozaru-button,
	.kozaru-item-detail-actions .button,
	.kozaru-staff-button-row .kozaru-button,
	.kozaru-staff-button-row .button,
	.kozaru-staff-search-form .kozaru-button,
	.kozaru-staff-search-form button {
		justify-content: center;
		text-align: center;
		width: 100%;
	}

	.kozaru-help-tip::after {
		left: auto;
		right: 0;
		transform: translateY(4px);
	}

	.kozaru-help-tip:hover::after,
	.kozaru-help-tip:focus::after,
	.kozaru-help-tip:focus-visible::after {
		transform: translateY(0);
	}
}

/* Kozaru Honbu v0.2.7.12 - class category age/rank eligibility and invite workflow polish */
.kozaru-form-fieldset {
	border: 1px solid #dcdcde;
	border-radius: 12px;
	margin: 12px 0;
	padding: 14px 16px;
}

.kozaru-form-fieldset legend {
	font-weight: 700;
	padding: 0 6px;
}

.kozaru-form-hint {
	color: #646970;
	font-size: 13px;
	line-height: 1.45;
	margin: 8px 0 0;
}

.kozaru-class-category-list .kozaru-class-category-pill small,
.kozaru-pill-row .kozaru-class-category-pill small {
	font-size: 11px;
	font-weight: 600;
	opacity: .85;
}

.kozaru-eligible-category-list {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

/* Kozaru Honbu v0.2.7.14 - category filters and manager class edit workflow */
.kozaru-calendar-category-filter {
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 16px;
	box-sizing: border-box;
	margin: 16px 0;
	padding: 14px 16px;
	width: 100%;
}

.kozaru-calendar-category-filter-heading {
	align-items: center;
	display: flex;
	gap: 12px;
	justify-content: space-between;
	margin-bottom: 10px;
}

.kozaru-calendar-category-filter-options {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.kozaru-calendar-category-filter-pill {
	--kozaru-category-colour: #2271b1;
	align-items: center;
	background: color-mix(in srgb, var(--kozaru-category-colour) 12%, #fff);
	border: 1px solid color-mix(in srgb, var(--kozaru-category-colour) 38%, #dcdcde);
	border-left: 5px solid var(--kozaru-category-colour);
	border-radius: 999px;
	box-sizing: border-box;
	cursor: pointer;
	display: inline-flex;
	font-size: 13px;
	font-weight: 700;
	gap: 7px;
	line-height: 1.2;
	max-width: 100%;
	min-height: 36px;
	padding: 6px 10px 6px 8px;
}

.kozaru-calendar-category-filter-pill input {
	margin: 0;
	min-height: 0 !important;
	width: auto !important;
}

.kozaru-calendar-category-filter-pill small {
	background: rgba(255,255,255,.8);
	border-radius: 999px;
	font-size: 11px;
	font-weight: 800;
	min-width: 20px;
	padding: 2px 6px;
	text-align: center;
}

.kozaru-calendar-category-filter-actions {
	margin: 12px 0 0;
}

@media (max-width: 700px) {
	.kozaru-calendar-category-filter {
		border-radius: 14px;
		padding: 12px;
	}

	.kozaru-calendar-category-filter-heading {
		align-items: flex-start;
		flex-direction: column;
		gap: 6px;
	}

	.kozaru-calendar-category-filter-options {
		display: grid;
		grid-template-columns: minmax(0, 1fr);
	}

	.kozaru-calendar-category-filter-pill {
		justify-content: flex-start;
		width: 100%;
	}

	.kozaru-calendar-category-filter-actions .kozaru-button,
	.kozaru-calendar-category-filter-actions .button {
		justify-content: center;
		width: 100%;
	}
}

/* Kozaru Honbu v0.2.7.14 - attendance kiosk and calendar link polish */
.kozaru-attendance-kiosk-page .kozaru-staff-section,
.kozaru-attendance-kiosk-section {
	max-width: 1280px;
	margin-inline: auto;
}

.kozaru-attendance-kiosk-title p {
	max-width: 760px;
}

.kozaru-open-attendance-card {
	border-left: 6px solid #d8dee8;
}

.kozaru-open-attendance-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 14px;
}

.kozaru-open-attendance-item {
	border-left: 6px solid var(--kozaru-category-colour, #2271b1);
	text-decoration: none;
	color: inherit;
}

.kozaru-open-attendance-item.is-selected {
	box-shadow: 0 0 0 3px rgba(34, 113, 177, 0.16);
}

.kozaru-attendance-kiosk {
	border-left: 8px solid var(--kozaru-category-colour, #2271b1);
}

.kozaru-attendance-kiosk-header {
	gap: 16px;
	align-items: flex-start;
}

.kozaru-kiosk-hint {
	margin: 0 0 18px;
}

.kozaru-attendance-kiosk-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 14px;
	align-items: stretch;
}

.kozaru-kiosk-student {
	display: flex;
	flex-direction: column;
	gap: 8px;
	min-width: 0;
}

.kozaru-kiosk-student-card {
	position: relative;
	display: grid;
	gap: 4px;
	min-height: 118px;
	padding: 18px 16px;
	border: 1px solid #d8dee8;
	border-radius: 18px;
	background: #fff;
	cursor: pointer;
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
	transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease, background 120ms ease;
}

.kozaru-kiosk-student-card:hover,
.kozaru-kiosk-student-card:focus-within {
	transform: translateY(-1px);
	box-shadow: 0 14px 32px rgba(15, 23, 42, 0.10);
}

.kozaru-kiosk-student-card input[type="checkbox"] {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 1px;
	height: 1px;
	opacity: 0;
	pointer-events: none;
}

.kozaru-kiosk-present-indicator {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	justify-self: start;
	min-width: 56px;
	padding: 5px 10px;
	border-radius: 999px;
	background: #eef2f7;
	color: #4b5563;
	font-size: 0.82rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.kozaru-kiosk-student-card input[type="checkbox"]:checked + .kozaru-kiosk-present-indicator {
	background: #d1fae5;
	color: #047857;
}

.kozaru-kiosk-student-card:has(input[type="checkbox"]:checked) {
	border-color: #10b981;
	background: linear-gradient(135deg, #f0fdf4 0%, #ffffff 76%);
}

.kozaru-kiosk-student-card strong {
	font-size: 1.04rem;
	line-height: 1.25;
}

.kozaru-kiosk-student-card small {
	color: #667085;
	line-height: 1.25;
}

.kozaru-kiosk-student-card.is-paused {
	cursor: default;
	background: #f8fafc;
	color: #667085;
}

.kozaru-kiosk-note {
	display: grid;
	gap: 4px;
	font-size: 0.84rem;
	font-weight: 700;
	color: #475467;
}

.kozaru-kiosk-note input {
	width: 100%;
	min-width: 0;
}

.kozaru-kiosk-actions {
	position: sticky;
	bottom: 10px;
	z-index: 5;
	padding: 10px;
	margin-top: 18px;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: blur(8px);
	box-shadow: 0 -8px 24px rgba(15, 23, 42, 0.08);
}

.kozaru-kiosk-save {
	width: 100%;
	min-height: 54px;
	font-size: 1.05rem;
}

@media (max-width: 720px) {
	.kozaru-attendance-kiosk-page,
	.kozaru-attendance-kiosk-section {
		width: 100%;
		max-width: 100%;
		overflow-x: clip;
	}

	.kozaru-open-attendance-list,
	.kozaru-attendance-kiosk-grid {
		grid-template-columns: 1fr;
	}

	.kozaru-attendance-kiosk-header {
		align-items: stretch;
	}

	.kozaru-kiosk-student-card {
		min-height: 104px;
		padding: 16px 14px;
	}

	.kozaru-kiosk-actions {
		bottom: 0;
		border-radius: 16px 16px 0 0;
		margin-inline: -8px;
	}
}

/* v0.2.7.16 attendance kiosk and QR workflows */
.kozaru-kiosk-qr-panel {
	margin: 18px 0;
}

.kozaru-qr-card {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 18px;
	align-items: center;
	padding: 18px;
	border: 1px solid rgba(15, 23, 42, 0.10);
	border-radius: 20px;
	background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
	box-shadow: 0 12px 34px rgba(15, 23, 42, 0.06);
}

.kozaru-qr-card h4 {
	margin: 0 0 6px;
	font-size: 1.05rem;
}

.kozaru-qr-card p {
	margin: 0 0 10px;
	color: #475467;
}

.kozaru-qr-image-wrap {
	display: grid;
	place-items: center;
	padding: 10px;
	border-radius: 18px;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
}

.kozaru-qr-image {
	display: block;
	width: 176px;
	height: 176px;
	max-width: 100%;
	border-radius: 10px;
}

.kozaru-kiosk-live-summary {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 12px;
	align-items: center;
	justify-content: space-between;
	padding: 12px 14px;
	margin: 0 0 12px;
	border-radius: 16px;
	background: #ecfdf5;
	border: 1px solid #bbf7d0;
	color: #065f46;
}

.kozaru-kiosk-live-summary span {
	font-size: 0.9rem;
	font-weight: 650;
}

.kozaru-public-checkin-page,
.kozaru-student-scan-page {
	max-width: 980px;
	margin-inline: auto;
}

.kozaru-public-checkin-hero h2 {
	font-size: clamp(2rem, 5vw, 4rem);
	line-height: 1;
	margin-bottom: 10px;
}

.kozaru-kiosk-search-form {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 12px;
	align-items: end;
}

.kozaru-kiosk-search-form label {
	display: grid;
	gap: 6px;
	font-weight: 800;
}

.kozaru-kiosk-search-form input[type="search"] {
	width: 100%;
	min-height: 54px;
	font-size: 1.1rem;
}

.kozaru-kiosk-self-list {
	margin-top: 18px;
}

.kozaru-kiosk-self-card {
	display: grid;
	gap: 8px;
	padding: 18px;
	border: 2px solid rgba(15, 23, 42, 0.10);
	border-radius: 22px;
	background: #ffffff;
	box-shadow: 0 14px 36px rgba(15, 23, 42, 0.08);
}

.kozaru-kiosk-self-card strong {
	font-size: 1.1rem;
}

.kozaru-linked-checkin-card {
	margin-bottom: 16px;
	border-color: #10b981;
	background: linear-gradient(135deg, #ecfdf5 0%, #ffffff 100%);
}

.kozaru-kiosk-self-card .kozaru-button {
	width: 100%;
	min-height: 50px;
}

@media (max-width: 720px) {
	.kozaru-qr-card {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.kozaru-qr-image-wrap {
		justify-self: center;
	}

	.kozaru-kiosk-search-form {
		grid-template-columns: 1fr;
	}

	.kozaru-public-checkin-grid,
	.kozaru-student-scan-page .kozaru-attendance-kiosk-grid {
		grid-template-columns: 1fr;
	}
}

/* Kozaru Honbu v0.2.7.16 - simplified attendance kiosk and editable review records */
.kozaru-attendance-simple-kiosk .kozaru-kiosk-qr-panel,
.kozaru-attendance-simple-kiosk .kozaru-attendance-kiosk-form,
.kozaru-attendance-simple-kiosk .kozaru-kiosk-note {
	display: none;
}

.kozaru-kiosk-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
	gap: 1rem;
	align-items: start;
}

.kozaru-kiosk-main-list,
.kozaru-kiosk-checked-sidebar {
	background: #fff;
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: 1.25rem;
	padding: 1rem;
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
}

.kozaru-kiosk-checked-sidebar {
	position: sticky;
	top: 1rem;
}

.kozaru-kiosk-list-heading {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 0.85rem;
}

.kozaru-kiosk-list-heading h4 {
	margin: 0;
	font-size: clamp(1.15rem, 2vw, 1.45rem);
}

.kozaru-kiosk-list-heading span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2rem;
	height: 2rem;
	padding: 0 0.6rem;
	border-radius: 999px;
	background: rgba(34, 113, 177, 0.12);
	font-weight: 800;
	color: #0f172a;
}

.kozaru-kiosk-simple-summary {
	margin-bottom: 1rem;
}

.kozaru-kiosk-pending-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
	gap: 0.85rem;
}

.kozaru-kiosk-checkin-form,
.kozaru-kiosk-clear-form {
	margin: 0;
}

.kozaru-kiosk-checkin-button {
	width: 100%;
	min-height: 6.5rem;
	padding: 1rem;
	border: 2px solid rgba(15, 23, 42, 0.1);
	border-left: 0.5rem solid var(--kozaru-category-colour, #2271b1);
	border-radius: 1rem;
	background: linear-gradient(180deg, #fff, #f8fafc);
	box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
	text-align: left;
	cursor: pointer;
	display: grid;
	gap: 0.35rem;
	align-content: center;
	transition: transform 0.12s ease, border-color 0.12s ease, box-shadow 0.12s ease;
}

.kozaru-kiosk-checkin-button:hover,
.kozaru-kiosk-checkin-button:focus-visible {
	transform: translateY(-1px);
	border-color: var(--kozaru-category-colour, #2271b1);
	box-shadow: 0 14px 30px rgba(15, 23, 42, 0.12);
	outline: none;
}

.kozaru-kiosk-checkin-name {
	font-size: 1.2rem;
	font-weight: 850;
	color: #111827;
}

.kozaru-kiosk-checkin-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	font-size: 0.85rem;
	color: #64748b;
}

.kozaru-kiosk-checkin-button strong {
	justify-self: start;
	margin-top: 0.25rem;
	padding: 0.35rem 0.65rem;
	border-radius: 999px;
	background: rgba(34, 197, 94, 0.13);
	color: #047857;
	font-size: 0.85rem;
}

.kozaru-kiosk-checked-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.55rem;
}

.kozaru-kiosk-checked-list li {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	padding: 0.65rem 0.75rem;
	border-radius: 0.85rem;
	background: rgba(34, 197, 94, 0.1);
	border: 1px solid rgba(34, 197, 94, 0.18);
	font-weight: 750;
}

.kozaru-small-link-button {
	border: 0;
	background: transparent;
	color: #b91c1c;
	font-weight: 800;
	cursor: pointer;
	padding: 0.2rem 0.35rem;
}

.kozaru-kiosk-paused-details,
.kozaru-kiosk-qr-details {
	margin-top: 1rem;
}

.kozaru-kiosk-qr-details summary,
.kozaru-kiosk-paused-details summary {
	cursor: pointer;
	font-weight: 800;
}

.kozaru-class-qr-card-compact {
	margin-top: 0.75rem;
}

.kozaru-class-qr-card-compact .kozaru-qr-image-wrap img {
	max-width: 170px;
}

.kozaru-attendance-record-editor-list {
	display: grid;
	gap: 0.85rem;
}

.kozaru-attendance-record-editor {
	display: grid;
	grid-template-columns: minmax(190px, 1.4fr) minmax(140px, 0.7fr) minmax(220px, 1fr) auto;
	gap: 0.75rem;
	align-items: end;
	padding: 0.9rem;
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: 1rem;
	background: #fff;
}

.kozaru-attendance-record-main {
	display: grid;
	gap: 0.15rem;
}

.kozaru-attendance-record-main strong {
	font-size: 1rem;
}

.kozaru-attendance-record-main span,
.kozaru-attendance-record-main small {
	color: #64748b;
}

.kozaru-attendance-record-editor label {
	display: grid;
	gap: 0.25rem;
	font-weight: 800;
}

.kozaru-attendance-record-editor select,
.kozaru-attendance-record-editor input[type="text"] {
	width: 100%;
	max-width: 100%;
}

.kozaru-dashboard-stat-grid .kozaru-stat-card {
	display: grid;
	gap: 0.2rem;
}

@media (max-width: 900px) {
	.kozaru-kiosk-layout {
		grid-template-columns: 1fr;
	}

	.kozaru-kiosk-checked-sidebar {
		position: static;
		order: -1;
	}

	.kozaru-attendance-record-editor {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 520px) {
	.kozaru-kiosk-pending-list {
		grid-template-columns: 1fr;
	}

	.kozaru-kiosk-main-list,
	.kozaru-kiosk-checked-sidebar {
		padding: 0.85rem;
		border-radius: 1rem;
	}

	.kozaru-kiosk-checkin-button {
		min-height: 5.5rem;
	}

	.kozaru-kiosk-checked-list li {
		align-items: flex-start;
	}
}

/* Kozaru Honbu v0.2.7.19 - true full-screen attendance kiosk */
body.kozaru-kiosk-fullscreen,
body.kozaru-kiosk-fullscreen-attendance {
	margin: 0 !important;
	padding: 0 !important;
	background: #f6f8fb !important;
	overflow-x: hidden !important;
}

body.kozaru-kiosk-fullscreen #wpadminbar,
body.kozaru-kiosk-fullscreen .site-header,
body.kozaru-kiosk-fullscreen .site-footer,
body.kozaru-kiosk-fullscreen .main-navigation,
body.kozaru-kiosk-fullscreen .wp-site-blocks > header,
body.kozaru-kiosk-fullscreen .wp-site-blocks > footer,
body.kozaru-kiosk-fullscreen #masthead,
body.kozaru-kiosk-fullscreen #colophon,
body.kozaru-kiosk-fullscreen .entry-header,
body.kozaru-kiosk-fullscreen .page-header,
body.kozaru-kiosk-fullscreen .wp-block-post-title,
body.kozaru-kiosk-fullscreen .wp-block-navigation,
body.kozaru-kiosk-fullscreen .wp-block-site-title,
body.kozaru-kiosk-fullscreen .wp-block-site-logo {
	display: none !important;
}

html body.kozaru-kiosk-fullscreen.admin-bar,
html body.kozaru-kiosk-fullscreen {
	margin-top: 0 !important;
}

body.kozaru-kiosk-fullscreen .wp-site-blocks,
body.kozaru-kiosk-fullscreen #page,
body.kozaru-kiosk-fullscreen .site,
body.kozaru-kiosk-fullscreen .site-content,
body.kozaru-kiosk-fullscreen .content-area,
body.kozaru-kiosk-fullscreen main,
body.kozaru-kiosk-fullscreen article,
body.kozaru-kiosk-fullscreen .entry-content,
body.kozaru-kiosk-fullscreen .wp-block-group,
body.kozaru-kiosk-fullscreen .wp-block-post-content {
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

body.kozaru-kiosk-fullscreen .kozaru-frontend-wrap.kozaru-kiosk-fullscreen-wrap,
body.kozaru-kiosk-fullscreen .kozaru-staff-interface.kozaru-attendance-kiosk-page {
	width: 100vw !important;
	max-width: none !important;
	min-height: 100vh !important;
	margin: 0 !important;
	padding: 0 !important;
	background: #f6f8fb !important;
}

body.kozaru-kiosk-fullscreen .kozaru-attendance-kiosk-section {
	width: 100% !important;
	max-width: none !important;
	min-height: 100vh;
	margin: 0 !important;
	padding: clamp(1rem, 2vw, 1.75rem) !important;
	background:
	radial-gradient(circle at top left, rgba(34, 113, 177, 0.11), transparent 28rem),
	linear-gradient(180deg, #ffffff 0%, #f6f8fb 42%, #eef3f8 100%);
	box-sizing: border-box;
}

.kozaru-kiosk-shell {
	width: min(100%, 1480px);
	min-height: calc(100vh - clamp(2rem, 4vw, 3.5rem));
	margin: 0 auto;
	display: grid;
	grid-template-rows: auto 1fr;
	gap: clamp(0.85rem, 1.5vw, 1.25rem);
}

.kozaru-kiosk-open-strip {
	margin: 0;
	padding: clamp(0.9rem, 1.6vw, 1.25rem);
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: 1.35rem;
	background: rgba(255, 255, 255, 0.92);
	box-shadow: 0 20px 50px rgba(15, 23, 42, 0.08);
}

.kozaru-kiosk-open-strip-heading {
	display: flex;
	justify-content: space-between;
	align-items: end;
	gap: 1rem;
	margin-bottom: 0.8rem;
}

.kozaru-kiosk-open-strip-heading h2 {
	margin: 0;
	font-size: clamp(1.35rem, 2vw, 2rem);
	line-height: 1.05;
}

.kozaru-kiosk-open-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 0.75rem;
}

.kozaru-kiosk-open-item {
	display: grid;
	gap: 0.3rem;
	padding: 0.85rem 1rem 0.85rem 1.1rem;
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-left: 0.45rem solid var(--kozaru-category-colour, #2271b1);
	border-radius: 1rem;
	background: #fff;
	color: #111827;
	text-decoration: none;
}

.kozaru-kiosk-open-item.is-selected {
	border-color: var(--kozaru-category-colour, #2271b1);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--kozaru-category-colour, #2271b1) 18%, transparent);
}

.kozaru-attendance-simple-kiosk {
	margin: 0;
	padding: clamp(1rem, 1.8vw, 1.5rem) !important;
	border: 1px solid rgba(15, 23, 42, 0.1) !important;
	border-radius: 1.5rem !important;
	background: rgba(255, 255, 255, 0.95) !important;
	box-shadow: 0 24px 60px rgba(15, 23, 42, 0.1) !important;
}

.kozaru-attendance-simple-kiosk .kozaru-attendance-kiosk-header {
	padding: 0 0 1rem;
	margin: 0 0 1rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.kozaru-attendance-simple-kiosk .kozaru-attendance-kiosk-header h3 {
	font-size: clamp(1.7rem, 3vw, 3.15rem);
	line-height: 1;
	margin: 0.1rem 0 0.35rem;
}

.kozaru-attendance-simple-kiosk .kozaru-kiosk-live-summary {
	padding: 0.9rem 1rem;
	border-radius: 1rem;
	align-items: center;
}

.kozaru-attendance-simple-kiosk .kozaru-kiosk-live-summary span {
	font-size: clamp(0.95rem, 1vw, 1.05rem);
}

.kozaru-attendance-simple-kiosk .kozaru-kiosk-layout {
	grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
	gap: clamp(0.85rem, 1.5vw, 1.25rem);
}

.kozaru-attendance-simple-kiosk .kozaru-kiosk-main-list,
.kozaru-attendance-simple-kiosk .kozaru-kiosk-checked-sidebar {
	min-width: 0;
	padding: clamp(1rem, 1.5vw, 1.35rem);
	border-radius: 1.25rem;
	box-shadow: none;
}

.kozaru-attendance-simple-kiosk .kozaru-kiosk-checked-sidebar {
	position: sticky;
	top: 1rem;
	max-height: calc(100vh - 15rem);
	overflow: auto;
}

.kozaru-attendance-simple-kiosk .kozaru-kiosk-pending-list {
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 0.9rem;
}

.kozaru-attendance-simple-kiosk .kozaru-kiosk-checkin-button {
	min-height: 7.25rem;
	font-size: 1rem;
}

.kozaru-attendance-simple-kiosk .kozaru-kiosk-checkin-name {
	font-size: clamp(1.1rem, 1.5vw, 1.35rem);
}

.kozaru-attendance-simple-kiosk .kozaru-kiosk-qr-details {
	display: none !important;
}

body.kozaru-kiosk-fullscreen .kozaru-kiosk-flash {
	margin: 0;
}

@media (min-width: 1200px) {
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-layout {
		grid-template-columns: minmax(0, 1fr) 390px;
	}
}

@media (max-width: 900px) {
	body.kozaru-kiosk-fullscreen .kozaru-attendance-kiosk-section {
		padding: 0.75rem !important;
	}

	.kozaru-kiosk-shell {
		min-height: calc(100vh - 1.5rem);
	}

	.kozaru-kiosk-open-strip-heading {
		display: block;
	}

	.kozaru-kiosk-open-list {
		grid-template-columns: 1fr;
	}

	.kozaru-attendance-simple-kiosk .kozaru-kiosk-layout {
		grid-template-columns: 1fr;
	}

	.kozaru-attendance-simple-kiosk .kozaru-kiosk-checked-sidebar {
		position: static;
		order: -1;
		max-height: none;
	}
}

@media (max-width: 520px) {
	.kozaru-attendance-simple-kiosk {
		padding: 0.85rem !important;
		border-radius: 1.1rem !important;
	}

	.kozaru-attendance-simple-kiosk .kozaru-attendance-kiosk-header h3 {
		font-size: clamp(1.45rem, 10vw, 2.2rem);
	}

	.kozaru-attendance-simple-kiosk .kozaru-kiosk-live-summary {
		display: grid;
		gap: 0.25rem;
	}

	.kozaru-attendance-simple-kiosk .kozaru-kiosk-checkin-button {
		min-height: 5.75rem;
		padding: 0.9rem;
	}
}

/* Kozaru Honbu v0.2.7.19 - bare-template kiosk viewport repair */
html:has(body.kozaru-kiosk-bare-template),
body.kozaru-kiosk-bare-template {
	width: 100% !important;
	min-width: 100% !important;
	min-height: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	background: #f6f8fb !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-bare-main,
body.kozaru-kiosk-bare-template .kozaru-frontend-wrap.kozaru-kiosk-fullscreen-wrap,
body.kozaru-kiosk-bare-template .kozaru-staff-interface.kozaru-attendance-kiosk-page,
body.kozaru-kiosk-bare-template .kozaru-attendance-kiosk-section,
body.kozaru-kiosk-bare-template .kozaru-kiosk-shell {
	display: block !important;
	box-sizing: border-box !important;
	width: 100% !important;
	max-width: none !important;
	min-width: 0 !important;
	margin: 0 !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-bare-main {
	min-height: 100vh !important;
	overflow-x: hidden !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-kiosk-section {
	min-height: 100vh !important;
	padding: clamp(0.75rem, 1.6vw, 1.4rem) !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-shell {
	min-height: calc(100vh - clamp(1.5rem, 3.2vw, 2.8rem)) !important;
	display: grid !important;
	grid-template-rows: auto 1fr !important;
	gap: clamp(0.8rem, 1.4vw, 1.15rem) !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-open-strip,
body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk {
	width: 100% !important;
	max-width: none !important;
	box-sizing: border-box !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-layout {
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 420px) !important;
	align-items: start !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-main-list,
body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-checked-sidebar {
	width: 100% !important;
	max-width: none !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-checked-sidebar .kozaru-kiosk-qr-details {
	display: none !important;
}

@media (min-width: 1280px) {
	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-layout {
		grid-template-columns: minmax(0, 1fr) 420px !important;
	}
}

@media (max-width: 900px) {
	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-layout {
		grid-template-columns: 1fr !important;
	}
}

/* Kozaru Honbu v0.2.7.19 - tightened modern full-screen attendance kiosk */
body.kozaru-kiosk-bare-template {
	background:
	radial-gradient(circle at top left, rgba(34, 113, 177, 0.12), transparent 24rem),
	linear-gradient(180deg, #f8fafc 0%, #eef3f8 100%) !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-kiosk-section {
	padding: clamp(0.55rem, 1.1vw, 1rem) !important;
	background: transparent !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-shell {
	width: min(100%, 1680px) !important;
	min-height: calc(100vh - clamp(1.1rem, 2.2vw, 2rem)) !important;
	gap: clamp(0.55rem, 0.9vw, 0.85rem) !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-open-strip {
	padding: clamp(0.55rem, 0.85vw, 0.85rem) !important;
	border-radius: 1rem !important;
	background: rgba(255, 255, 255, 0.88) !important;
	box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08) !important;
	display: grid !important;
	grid-template-columns: minmax(180px, 260px) minmax(0, 1fr) !important;
	gap: clamp(0.55rem, 1vw, 0.85rem) !important;
	align-items: center !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-open-strip-heading {
	display: block !important;
	margin: 0 !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-open-strip-heading .kozaru-command-eyebrow {
	margin: 0 0 0.15rem !important;
	font-size: 0.68rem !important;
	letter-spacing: 0.1em !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-open-strip-heading h2 {
	font-size: clamp(1rem, 1.25vw, 1.35rem) !important;
	line-height: 1.05 !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-open-list {
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
	gap: 0.5rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-open-item {
	padding: 0.55rem 0.7rem 0.55rem 0.8rem !important;
	border-radius: 0.8rem !important;
	gap: 0.15rem !important;
	font-size: 0.92rem !important;
	box-shadow: none !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-open-item strong {
	font-size: 0.98rem !important;
	line-height: 1.1 !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-open-item .kozaru-pill-row {
	margin: 0 !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk {
	padding: clamp(0.7rem, 1vw, 1rem) !important;
	border-radius: 1.15rem !important;
	box-shadow: 0 18px 42px rgba(15, 23, 42, 0.1) !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-attendance-kiosk-header {
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) auto !important;
	gap: 0.75rem !important;
	align-items: start !important;
	padding: 0 0 0.55rem !important;
	margin: 0 0 0.65rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-attendance-kiosk-header .kozaru-command-eyebrow {
	margin-bottom: 0.15rem !important;
	font-size: 0.72rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-attendance-kiosk-header h3 {
	font-size: clamp(1.85rem, 3vw, 3.45rem) !important;
	line-height: 0.98 !important;
	margin: 0 0 0.18rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-attendance-kiosk-header .kozaru-command-empty {
	margin: 0 !important;
	font-size: clamp(0.9rem, 1.05vw, 1rem) !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-status {
	align-self: start !important;
	white-space: nowrap !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-live-summary {
	margin: 0 0 0.65rem !important;
	padding: 0.55rem 0.75rem !important;
	border-radius: 0.85rem !important;
	display: flex !important;
	justify-content: space-between !important;
	gap: 0.75rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-layout {
	grid-template-columns: minmax(0, 1fr) minmax(300px, 380px) !important;
	gap: clamp(0.55rem, 0.95vw, 0.85rem) !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-main-list,
body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-checked-sidebar {
	padding: clamp(0.65rem, 0.95vw, 0.95rem) !important;
	border-radius: 1rem !important;
	background: rgba(255, 255, 255, 0.94) !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-main-list {
	min-height: clamp(13rem, 34vh, 28rem) !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-checked-sidebar {
	max-height: calc(100vh - 13rem) !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-list-heading {
	margin-bottom: 0.55rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-list-heading h4 {
	font-size: clamp(1rem, 1.25vw, 1.25rem) !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-list-heading span {
	min-width: 1.65rem !important;
	height: 1.65rem !important;
	font-size: 0.88rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-pending-list {
	grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)) !important;
	gap: 0.65rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-checkin-button {
	min-height: 5.6rem !important;
	padding: 0.75rem 0.85rem !important;
	border-radius: 0.9rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-checkin-name {
	font-size: clamp(1.02rem, 1.25vw, 1.2rem) !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-checkin-button strong {
	padding: 0.22rem 0.5rem !important;
	font-size: 0.78rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-checked-list {
	gap: 0.4rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-checked-list li {
	padding: 0.48rem 0.58rem !important;
	border-radius: 0.7rem !important;
	font-size: 0.9rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-empty {
	margin-top: 0.35rem !important;
}

body.kozaru-kiosk-bare-template .kozaru-kiosk-flash {
	position: fixed !important;
	top: 0.75rem !important;
	right: 0.75rem !important;
	z-index: 9999 !important;
	max-width: 18rem !important;
	box-shadow: 0 16px 34px rgba(15, 23, 42, 0.14) !important;
	animation: kozaruKioskFlashOut 2.2s ease forwards !important;
	pointer-events: none !important;
}

@keyframes kozaruKioskFlashOut {
	0%,
	70% {
		opacity: 1;
		transform: translateY(0);
		visibility: visible;
	}
	100% {
		opacity: 0;
		transform: translateY(-0.35rem);
		visibility: hidden;
	}
}

@media (min-width: 1500px) {
	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-layout {
		grid-template-columns: minmax(0, 1fr) 360px !important;
	}
}

@media (max-width: 900px) {
	body.kozaru-kiosk-bare-template .kozaru-kiosk-open-strip {
		grid-template-columns: 1fr !important;
	}

	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-attendance-kiosk-header {
		grid-template-columns: 1fr !important;
	}

	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-live-summary {
		display: grid !important;
	}

	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-main-list {
		min-height: auto !important;
	}
}

@media (max-width: 520px) {
	body.kozaru-kiosk-bare-template .kozaru-attendance-kiosk-section {
		padding: 0.55rem !important;
	}

	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-attendance-kiosk-header h3 {
		font-size: clamp(1.45rem, 9vw, 2.1rem) !important;
	}

	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-checkin-button {
		min-height: 5.2rem !important;
	}
}

/* Kozaru Honbu v0.2.8.4 - frontend kiosk and add-to-calendar polish */
@media (max-width: 900px) {
	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-layout,
	body.kozaru-kiosk-fullscreen .kozaru-attendance-simple-kiosk .kozaru-kiosk-layout,
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-layout {
		display: flex !important;
		flex-direction: column !important;
		gap: 0.85rem !important;
	}

	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-main-list,
	body.kozaru-kiosk-fullscreen .kozaru-attendance-simple-kiosk .kozaru-kiosk-main-list,
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-main-list {
		order: 1 !important;
		width: 100% !important;
		max-width: 100% !important;
		min-width: 0 !important;
	}

	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-checked-sidebar,
	body.kozaru-kiosk-fullscreen .kozaru-attendance-simple-kiosk .kozaru-kiosk-checked-sidebar,
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-checked-sidebar {
		order: 2 !important;
		position: static !important;
		width: 100% !important;
		max-width: 100% !important;
		min-width: 0 !important;
		max-height: none !important;
		overflow: visible !important;
	}
}

@media (max-width: 520px) {
	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-main-list,
	body.kozaru-kiosk-bare-template .kozaru-attendance-simple-kiosk .kozaru-kiosk-checked-sidebar {
		padding: 0.8rem !important;
	}

	body.kozaru-kiosk-bare-template .kozaru-kiosk-list-heading {
		align-items: center !important;
	}

	body.kozaru-kiosk-bare-template .kozaru-kiosk-list-heading h4 {
		font-size: 1.1rem !important;
		line-height: 1.15 !important;
	}

	body.kozaru-kiosk-bare-template .kozaru-kiosk-empty {
		font-size: 0.95rem !important;
		line-height: 1.45 !important;
	}
}

/* Kozaru Honbu v0.2.8.4 - readable entity forms and calendar actions */

.kozaru-add-to-calendar {
	display: inline-block;
	position: relative;
}

.kozaru-add-to-calendar summary {
	align-items: center;
	background: #ffffff;
	border: 1px solid var(--kozaru-ui-line, #c3c4c7);
	border-radius: 10px;
	box-sizing: border-box;
	color: var(--kozaru-ui-ink, #1d2327);
	cursor: pointer;
	display: inline-flex;
	font-size: 0.9rem;
	font-weight: 800;
	gap: 6px;
	justify-content: center;
	line-height: 1.15;
	list-style: none;
	min-height: 40px;
	padding: 9px 12px;
	text-decoration: none;
}

.kozaru-add-to-calendar summary::-webkit-details-marker {
	display: none;
}

.kozaru-add-to-calendar summary::after {
	content: "▾";
	font-size: 0.82em;
	line-height: 1;
}

.kozaru-add-to-calendar[open] summary::after {
	content: "▴";
}

.kozaru-add-to-calendar-menu {
	background: #ffffff;
	border: 1px solid var(--kozaru-ui-line, #dcdcde);
	border-radius: 12px;
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.12);
	display: grid;
	gap: 2px;
	min-width: 170px;
	padding: 6px;
	position: absolute;
	right: 0;
	top: calc(100% + 6px);
	z-index: 20;
}

.kozaru-add-to-calendar-menu a {
	border-radius: 8px;
	color: var(--kozaru-ui-ink, #1d2327);
	display: block;
	font-weight: 700;
	padding: 8px 10px;
	text-decoration: none;
	white-space: nowrap;
}

.kozaru-add-to-calendar-menu a:hover,
.kozaru-add-to-calendar-menu a:focus {
	background: var(--kozaru-ui-soft, #f6f7f7);
	color: var(--kozaru-ui-blue, #2271b1);
	text-decoration: none;
}


@media screen and (max-width: 782px) {
	.kozaru-add-to-calendar,
	.kozaru-add-to-calendar summary {
		width: 100%;
	}

	.kozaru-add-to-calendar-menu {
		box-shadow: none;
		margin-top: 8px;
		position: static;
		width: 100%;
	}
}

/* Kozaru Honbu v0.2.9.x - Actionable Analytics / Reports */

/* Kozaru Honbu v0.2.9.x - Analytics filters, exports, drill-downs, and print view */

@media print {
	.kozaru-table-scroll {
		overflow: visible !important;
	}

	table.kozaru-table {
		width: 100% !important;
		font-size: 11px !important;
	}
}

/* Kozaru Honbu v0.2.9.7 - Report Presets / Dashboard Widgets */

/* Kozaru Honbu v0.2.9.7 - Analytics Presets / Dashboard Widgets */

/* Kozaru Honbu v0.2.9.8 - Student Health / Risk Indicators */

.kozaru-health-badge {
	display: inline-flex;
	align-items: center;
	margin-bottom: 6px;
}

.kozaru-health-good {
	background: #edfaef;
	color: #0a6322;
}

.kozaru-health-warning {
	background: #fcf6e3;
	color: #7a5400;
}

.kozaru-health-danger {
	background: #fcf0f1;
	color: #8a2424;
}

.kozaru-health-neutral {
	background: #f0f6fc;
	color: #1d4f7a;
}

/* Kozaru Honbu v0.2.9.9 - Lifecycle Funnel / Conversion / Retention Insights */

/* =========================================================
Kozaru Honbu v0.2.10.1 - frontend dashboard shell refresh
Role-aware command-centre shell without disturbing the existing workspaces.
========================================================= */

.kozaru-front-dashboard-refresh {
	max-width: min(100%, 1280px);
}

.kozaru-dashboard-shell {
	align-items: stretch;
	background: linear-gradient(135deg, #111827 0%, #1f2937 54%, #3b1218 100%);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-top: 8px solid #d82132;
	border-radius: 30px;
	box-shadow: 0 22px 50px rgba(15, 23, 42, 0.18);
	color: #ffffff;
	display: grid;
	gap: clamp(18px, 3vw, 28px);
	grid-template-columns: minmax(0, 1.55fr) minmax(280px, 0.75fr);
	margin: 0 0 clamp(18px, 3vw, 28px);
	padding: clamp(22px, 4vw, 34px);
}

.kozaru-dashboard-shell-main {
	display: grid;
	gap: 16px;
	min-width: 0;
}

.kozaru-dashboard-shell .kozaru-command-eyebrow {
	color: rgba(255, 255, 255, 0.76);
	margin: 0;
}

.kozaru-dashboard-shell h2 {
	color: #ffffff;
	font-size: clamp(2.15rem, 5vw, 4.25rem);
	letter-spacing: -0.055em;
	line-height: 0.98;
	margin: 0;
}

.kozaru-dashboard-shell p {
	color: rgba(255, 255, 255, 0.78);
	font-size: 1.05rem;
	line-height: 1.55;
	margin: 0;
	max-width: 780px;
}

.kozaru-dashboard-identity-row {
	align-items: center;
	display: flex;
	gap: 18px;
	min-width: 0;
}

.kozaru-dashboard-identity-row .kozaru-profile-photo {
	background: rgba(255, 255, 255, 0.12);
	border: 2px solid rgba(255, 255, 255, 0.28);
	box-shadow: 0 14px 32px rgba(0, 0, 0, 0.22);
	flex: 0 0 auto;
}

.kozaru-dashboard-identity-student {
	margin-top: 14px;
	max-width: 640px;
}

.kozaru-dashboard-identity-student .kozaru-student-identity-name,
.kozaru-command-hero-student-identity .kozaru-student-identity-name {
	color: inherit;
}

.kozaru-dashboard-identity-student .kozaru-student-identity-rank,
.kozaru-command-hero-student-identity .kozaru-student-identity-rank {
	color: rgba(255, 255, 255, 0.78);
}

.kozaru-dashboard-identity-student .kozaru-student-obi-label,
.kozaru-command-hero-student-identity .kozaru-student-obi-label {
	color: rgba(255, 255, 255, 0.82);
}

.kozaru-command-hero-student-identity {
	margin: 12px 0 8px;
	max-width: 620px;
}

.kozaru-dashboard-identity-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.kozaru-dashboard-identity-meta > span {
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 999px;
	color: rgba(255, 255, 255, 0.9);
	font-size: 0.82rem;
	font-weight: 800;
	padding: 7px 11px;
}

.kozaru-dashboard-priority-card {
	align-content: start;
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(255, 255, 255, 0.3);
	border-radius: 24px;
	box-shadow: 0 18px 42px rgba(0, 0, 0, 0.16);
	color: #111827;
	display: grid;
	gap: 10px;
	padding: clamp(18px, 3vw, 24px);
}

.kozaru-dashboard-priority-card span {
	color: #64748b;
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.kozaru-dashboard-priority-card strong {
	color: #111827;
	font-size: clamp(1.35rem, 2.7vw, 2rem);
	line-height: 1.05;
}

.kozaru-dashboard-priority-card p {
	color: #475569;
	font-size: 0.95rem;
}

.kozaru-dashboard-metric-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 185px), 1fr));
	margin: 0 0 clamp(18px, 3vw, 28px);
}

.kozaru-dashboard-metric-card {
	background: #ffffff;
	border: 1px solid #d7dee8;
	border-radius: 18px;
	box-shadow: 0 10px 26px rgba(15, 23, 42, 0.07);
	color: #111827;
	display: grid;
	gap: 5px;
	min-width: 0;
	padding: 17px;
	text-decoration: none;
}

.kozaru-dashboard-metric-card strong {
	color: #111827;
	font-size: clamp(1.85rem, 4vw, 3rem);
	letter-spacing: -0.04em;
	line-height: 0.95;
}

.kozaru-dashboard-metric-card span {
	color: #1f2937;
	font-weight: 900;
}

.kozaru-dashboard-metric-card small {
	color: #64748b;
	font-weight: 700;
	line-height: 1.35;
}

.kozaru-dashboard-linked-card:hover,
.kozaru-dashboard-linked-card:focus-visible {
	border-color: #111827;
	box-shadow: 0 14px 32px rgba(15, 23, 42, 0.12);
	transform: translateY(-1px);
}

.kozaru-dashboard-action-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 270px), 1fr));
	margin: 0 0 clamp(18px, 3vw, 28px);
}

.kozaru-dashboard-action-card {
	align-content: space-between;
	background: #ffffff;
	border: 1px solid #d7dee8;
	border-radius: 20px;
	box-shadow: 0 10px 26px rgba(15, 23, 42, 0.06);
	display: grid;
	gap: 16px;
	min-width: 0;
	padding: 18px;
}

.kozaru-dashboard-action-card h3 {
	color: #111827;
	font-size: clamp(1.15rem, 2.2vw, 1.55rem);
	line-height: 1.08;
	margin: 0 0 8px;
}

.kozaru-dashboard-action-card p {
	color: #64748b;
	line-height: 1.5;
	margin: 0;
}

.kozaru-dashboard-section-heading {
	align-items: center;
	display: flex;
	gap: 16px;
	justify-content: space-between;
	margin: 0 0 14px;
}

.kozaru-dashboard-section-heading h3 {
	font-size: clamp(1.35rem, 2.5vw, 2rem);
	line-height: 1.05;
	margin: 0;
}

.kozaru-staff-dashboard-snapshot {
	margin: 0 0 clamp(18px, 3vw, 28px);
}

.kozaru-dashboard-tone-good {
	border-color: #bbf7d0;
}

.kozaru-dashboard-tone-good strong:first-child,
.kozaru-dashboard-tone-good > h3:first-child {
	color: #166534;
}

.kozaru-dashboard-tone-warning {
	border-color: #fed7aa;
}

.kozaru-dashboard-tone-warning strong:first-child,
.kozaru-dashboard-tone-warning > h3:first-child {
	color: #9a3412;
}

.kozaru-dashboard-tone-danger,
.kozaru-dashboard-tone-error {
	border-color: #fecaca;
}

.kozaru-dashboard-tone-danger strong:first-child,
.kozaru-dashboard-tone-error strong:first-child,
.kozaru-dashboard-tone-danger > h3:first-child,
.kozaru-dashboard-tone-error > h3:first-child {
	color: #991b1b;
}

.kozaru-portal-dashboard-shell + .kozaru-portal-metric-grid,
.kozaru-staff-dashboard-shell + .kozaru-staff-metric-row {
	margin-top: 0;
}

@media screen and (max-width: 900px) {
	.kozaru-dashboard-shell {
		grid-template-columns: 1fr;
	}

	.kozaru-dashboard-section-heading {
		align-items: stretch;
		display: grid;
	}
}

@media screen and (max-width: 640px) {
	.kozaru-dashboard-shell {
		border-radius: 22px;
		padding: 20px;
	}

	.kozaru-dashboard-identity-row {
		align-items: flex-start;
	}

	.kozaru-dashboard-action-card,
	.kozaru-dashboard-metric-card,
	.kozaru-dashboard-priority-card {
		border-radius: 16px;
	}
}

/* =========================================================
Kozaru Honbu v0.2.10.2 - Student / Account Manager Card Deepening
---------------------------------------------------------
Adds richer student snapshots and attention badges without changing the
underlying portal workflow or managed-student tab machinery.
========================================================= */

.kozaru-student-snapshot-section {
	margin: 0 0 clamp(18px, 3vw, 28px);
}

.kozaru-student-snapshot-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
}

.kozaru-student-snapshot-card,
.kozaru-managed-student-glance-panel {
	background: #ffffff;
	border: 1px solid #d7dee8;
	border-radius: 22px;
	box-shadow: 0 12px 30px rgba(15, 23, 42, 0.055);
	padding: clamp(16px, 2.4vw, 22px);
}

.kozaru-student-snapshot-card.is-active {
	border-color: #111827;
	box-shadow: 0 16px 34px rgba(15, 23, 42, 0.09);
}

.kozaru-student-snapshot-header,
.kozaru-managed-student-picker-identity {
	align-items: flex-start;
	display: flex;
	gap: 12px;
}

.kozaru-student-snapshot-header {
	justify-content: space-between;
	margin-bottom: 14px;
}

.kozaru-student-snapshot-header h4 {
	font-size: clamp(1.05rem, 2vw, 1.28rem);
	line-height: 1.1;
	margin: 0 0 4px;
}

.kozaru-student-snapshot-header small {
	color: #64748b;
	font-weight: 800;
}

.kozaru-student-snapshot-stats,
.kozaru-managed-student-picker-mini-stats,
.kozaru-managed-student-glance-grid {
	display: grid;
	gap: 9px;
	grid-template-columns: repeat(auto-fit, minmax(88px, 1fr));
}

.kozaru-student-snapshot-stats,
.kozaru-managed-student-glance-grid {
	margin: 0 0 14px;
}

.kozaru-student-snapshot-stats span,
.kozaru-managed-student-picker-mini-stats span,
.kozaru-managed-student-glance-grid span,
.kozaru-managed-student-next-step {
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	color: #64748b;
	display: block;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.035em;
	line-height: 1.25;
	padding: 10px 11px;
	text-transform: uppercase;
}

.kozaru-student-snapshot-stats strong,
.kozaru-managed-student-picker-mini-stats strong,
.kozaru-managed-student-glance-grid strong,
.kozaru-managed-student-next-step strong {
	color: #111827;
	display: block;
	font-size: 1.22rem;
	letter-spacing: 0;
	line-height: 1.1;
	margin-bottom: 3px;
	text-transform: none;
}

.kozaru-managed-student-picker-card .kozaru-health-badge {
	margin-left: auto;
	white-space: nowrap;
}

.kozaru-managed-student-picker-mini-stats {
	margin-top: 4px;
}

.kozaru-managed-student-picker-mini-stats span {
	background: rgba(248, 250, 252, 0.92);
	font-size: 0.72rem;
	padding: 8px 9px;
}

.kozaru-managed-student-picker-card.is-active .kozaru-managed-student-picker-mini-stats span {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.18);
	color: rgba(255, 255, 255, 0.78);
}

.kozaru-managed-student-picker-card.is-active .kozaru-managed-student-picker-mini-stats strong {
	color: #ffffff;
}

.kozaru-student-attention-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 7px;
	margin: 10px 0 0;
}

.kozaru-student-attention-chip {
	border: 1px solid #d7dee8;
	border-radius: 999px;
	color: #334155;
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 850;
	line-height: 1.2;
	padding: 7px 10px;
	text-decoration: none;
}

.kozaru-student-attention-chip:hover,
.kozaru-student-attention-chip:focus-visible {
	text-decoration: none;
}

.kozaru-student-attention-good {
	background: #edfaef;
	border-color: #bbf7d0;
	color: #166534;
}

.kozaru-student-attention-warning {
	background: #fff7ed;
	border-color: #fed7aa;
	color: #9a3412;
}

.kozaru-student-attention-danger,
.kozaru-student-attention-error {
	background: #fef2f2;
	border-color: #fecaca;
	color: #991b1b;
}

.kozaru-student-attention-neutral {
	background: #eff6ff;
	border-color: #bfdbfe;
	color: #1d4ed8;
}

.kozaru-student-snapshot-action {
	margin: 14px 0 0;
}

.kozaru-managed-student-glance-panel {
	display: grid;
	gap: 14px;
	grid-template-columns: minmax(220px, 0.8fr) minmax(260px, 1.2fr);
	margin: 0 0 clamp(16px, 2.4vw, 22px);
}

.kozaru-managed-student-glance-status p:last-child {
	color: #64748b;
	font-weight: 650;
	line-height: 1.45;
	margin: 8px 0 0;
}

.kozaru-managed-student-next-step {
	align-self: stretch;
	grid-column: 1 / -1;
}

.kozaru-managed-student-next-step span {
	color: #111827;
	display: block;
	font-size: 0.98rem;
	font-weight: 800;
	letter-spacing: 0;
	text-transform: none;
}

.kozaru-managed-student-signal-list {
	color: #64748b;
	font-weight: 700;
	grid-column: 1 / -1;
	margin: 0;
	padding-left: 20px;
}

.kozaru-managed-student-signal-list li {
	margin: 0 0 4px;
}

.kozaru-managed-student-glance-panel .kozaru-student-attention-chips {
	grid-column: 1 / -1;
	margin-top: 0;
}

@media screen and (max-width: 900px) {
	.kozaru-managed-student-glance-panel {
		grid-template-columns: 1fr;
	}
}

@media screen and (max-width: 782px) {
	.kozaru-student-snapshot-header,
	.kozaru-managed-student-picker-identity {
		align-items: flex-start;
		display: grid;
		grid-template-columns: auto minmax(0, 1fr);
	}

	.kozaru-student-snapshot-header .kozaru-health-badge,
	.kozaru-managed-student-picker-card .kozaru-health-badge {
		grid-column: 1 / -1;
		margin-left: 0;
	}

	.kozaru-student-attention-chips,
	.kozaru-student-attention-chip {
		width: 100%;
	}
}

/* Kozaru Honbu v0.2.10.3 - Instructor Operational Dashboard */
.kozaru-staff-action-queue {
	margin: clamp(18px, 3vw, 28px) 0;
}

.kozaru-staff-watch-section .kozaru-staff-action-queue {
	margin-top: 0;
}

.kozaru-staff-watch-grid {
	align-items: start;
	grid-template-columns: repeat(2, minmax(280px, 1fr));
}

.kozaru-staff-watch-card-header {
	align-items: flex-start;
	display: flex;
	gap: 12px;
	justify-content: space-between;
	margin: 0 0 14px;
}

.kozaru-staff-watch-card-header h3 {
	margin: 0;
}

.kozaru-staff-watch-list {
	display: grid;
	gap: 10px;
}

.kozaru-staff-watch-item {
	align-items: flex-start;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 16px;
	box-shadow: none;
	padding: 14px;
}

.kozaru-staff-watch-item .kozaru-command-item-main small {
	color: #64748b;
	display: block;
	font-weight: 650;
	line-height: 1.45;
	margin-top: 6px;
}

.kozaru-staff-watch-item .kozaru-command-list-actions {
	align-items: flex-end;
}

.kozaru-staff-overview-watch-card {
	grid-column: span 1;
}

@media screen and (max-width: 1100px) {
	.kozaru-staff-watch-grid {
		grid-template-columns: 1fr;
	}
}

@media screen and (max-width: 782px) {
	.kozaru-staff-watch-card-header,
	.kozaru-staff-watch-item {
		display: grid;
		grid-template-columns: 1fr;
	}

	.kozaru-staff-watch-item .kozaru-command-list-actions,
	.kozaru-staff-watch-item .kozaru-command-list-actions .kozaru-button {
		width: 100%;
	}
}

/* Kozaru Honbu v0.2.10.6 - tight staff dashboard session rows.
Manager and instructor dashboards use the same occurrence data as the richer calendar views,
but the dashboard needs a quick operational checklist rather than full event cards. */
.kozaru-staff-session-list {
	gap: 6px;
	margin-bottom: 0;
}

.kozaru-staff-session-item {
	align-items: center;
	border-left-width: 4px;
	border-radius: 12px;
	gap: 8px;
	min-height: 0;
	padding: 7px 9px;
}

.kozaru-staff-session-item .kozaru-command-item-main {
	align-items: center;
	display: flex;
	flex: 1 1 auto;
	flex-wrap: nowrap;
	gap: 6px;
	line-height: 1.25;
	min-width: 0;
}

.kozaru-staff-session-item .kozaru-command-item-main > strong {
	display: inline-block;
	font-size: 0.92rem;
	line-height: 1.25;
	margin: 0;
	max-width: min(18rem, 38vw);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.kozaru-staff-session-item .kozaru-command-item-main span,
.kozaru-staff-session-item .kozaru-pill-row,
.kozaru-staff-session-item .kozaru-staff-pill-row {
	align-items: center;
	display: inline-flex;
	flex: 0 0 auto;
	gap: 4px;
	margin: 0;
	min-width: 0;
	white-space: nowrap;
}

.kozaru-staff-session-item .kozaru-command-item-main > span:not(.kozaru-staff-count-pill) {
	color: #4b5563;
	font-size: 0.82rem;
}

.kozaru-staff-session-item .kozaru-command-item-main > span:not(.kozaru-staff-count-pill)::before,
.kozaru-staff-session-item .kozaru-pill-row::before,
.kozaru-staff-session-item .kozaru-staff-pill-row::before {
	color: #9ca3af;
	content: "•";
	font-weight: 700;
}

.kozaru-staff-session-item .kozaru-command-item-main > span:first-of-type::before,
.kozaru-staff-session-item .kozaru-pill-row:first-child::before {
	content: "";
	display: none;
}

.kozaru-staff-session-item .kozaru-class-category-pill,
.kozaru-staff-session-item .kozaru-staff-count-pill {
	font-size: 0.68rem;
	line-height: 1;
	padding: 3px 7px;
}

.kozaru-staff-session-item .kozaru-command-list-actions {
	align-items: center;
	flex: 0 0 auto;
	flex-wrap: nowrap;
	gap: 4px;
	justify-content: flex-end;
}

.kozaru-staff-session-item .kozaru-command-list-actions .kozaru-button,
.kozaru-staff-session-item .kozaru-command-list-actions .button,
.kozaru-staff-session-item .kozaru-add-to-calendar summary {
	border-radius: 9px;
	font-size: 0.72rem;
	font-weight: 800;
	line-height: 1.1;
	min-height: 28px;
	padding: 5px 8px;
	white-space: nowrap;
}

.kozaru-staff-session-item .kozaru-add-to-calendar {
	margin: 0;
}

.kozaru-staff-session-item .kozaru-add-to-calendar-menu {
	min-width: 150px;
}

@media (max-width: 1180px) {
	.kozaru-staff-session-item {
		align-items: stretch;
		flex-direction: column;
	}

	.kozaru-staff-session-item .kozaru-command-item-main {
		width: 100%;
	}

	.kozaru-staff-session-item .kozaru-command-list-actions {
		justify-content: flex-start;
	}
}

@media (max-width: 720px) {
	.kozaru-staff-session-item .kozaru-command-item-main {
		align-items: flex-start;
		flex-direction: column;
		gap: 4px;
	}

	.kozaru-staff-session-item .kozaru-command-item-main > strong {
		max-width: 100%;
	}

	.kozaru-staff-session-item .kozaru-command-item-main > span::before,
	.kozaru-staff-session-item .kozaru-pill-row::before,
	.kozaru-staff-session-item .kozaru-staff-pill-row::before {
		content: "";
		display: none;
	}

	.kozaru-staff-session-item .kozaru-command-list-actions {
		display: flex;
		flex-wrap: wrap;
	}
}

/* Kozaru Honbu v0.2.10.6 - dojo manager operational cockpit.
These blocks keep the manager dashboard focused on actionable, read-only
operational signals while preserving the instructor dashboard's simpler class-floor view. */
.kozaru-manager-action-queue,
.kozaru-manager-operational-snapshot,
.kozaru-manager-shortcuts,
.kozaru-manager-priority-panel {
	margin-top: 18px;
}

.kozaru-manager-action-queue-grid,
.kozaru-manager-snapshot-grid {
	grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.kozaru-manager-cockpit-card {
	min-height: 124px;
}

.kozaru-manager-cockpit-card strong {
	font-size: clamp(1.75rem, 2.4vw, 2.45rem);
	line-height: 1;
}

.kozaru-manager-cockpit-card span {
	font-weight: 850;
}

.kozaru-manager-shortcut-grid {
	grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.kozaru-manager-priority-panel .kozaru-dashboard-section-heading {
	margin-bottom: 12px;
}

.kozaru-manager-priority-list {
	gap: 8px;
}

.kozaru-manager-priority-item {
	align-items: center;
	border-left-width: 4px;
	gap: 10px;
	padding: 10px 12px;
}

.kozaru-manager-priority-item .kozaru-command-item-main {
	gap: 4px;
}

.kozaru-manager-priority-item .kozaru-command-item-title {
	font-size: 0.98rem;
}

.kozaru-manager-priority-item small {
	color: #64748b;
	font-size: 0.82rem;
}

.kozaru-manager-dashboard .kozaru-staff-metric-row {
	margin-bottom: 14px;
}

@media (max-width: 720px) {
	.kozaru-manager-action-queue-grid,
	.kozaru-manager-snapshot-grid,
	.kozaru-manager-shortcut-grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.kozaru-manager-priority-item {
		align-items: stretch;
		flex-direction: column;
	}

	.kozaru-manager-priority-item .kozaru-command-list-actions {
		justify-content: flex-start;
	}
}

/* =========================================================
Kozaru Honbu v0.2.10.7 - frontend command-centre polish
---------------------------------------------------------
Cosmetic/responsive pass only. No workflow assumptions and no Obi Builder
rendering changes. This keeps the public dashboards feeling like one product
across students, account managers, instructors, and dojo managers.
========================================================= */
.kozaru-frontend-wrap,
.kozaru-calendar-shortcode,
.kozaru-registration-box {
	--kozaru-ui-radius: 22px;
	--kozaru-ui-radius-sm: 14px;
	--kozaru-ui-focus: 0 0 0 3px rgba(36, 121, 184, 0.22);
	--kozaru-ui-card-shadow: 0 12px 34px rgba(15, 23, 42, 0.065);
	--kozaru-ui-card-shadow-hover: 0 16px 38px rgba(15, 23, 42, 0.105);
}

.kozaru-frontend-wrap a:focus-visible,
.kozaru-frontend-wrap button:focus-visible,
.kozaru-frontend-wrap summary:focus-visible,
.kozaru-frontend-wrap input:focus-visible,
.kozaru-frontend-wrap select:focus-visible,
.kozaru-frontend-wrap textarea:focus-visible,
.kozaru-calendar-shortcode a:focus-visible,
.kozaru-calendar-shortcode button:focus-visible,
.kozaru-calendar-shortcode summary:focus-visible,
.kozaru-registration-box a:focus-visible,
.kozaru-registration-box button:focus-visible,
.kozaru-registration-box input:focus-visible,
.kozaru-registration-box select:focus-visible,
.kozaru-registration-box textarea:focus-visible {
	box-shadow: var(--kozaru-ui-focus);
	outline: 2px solid transparent;
	outline-offset: 2px;
}

.kozaru-frontend-wrap p,
.kozaru-calendar-shortcode p,
.kozaru-registration-box p {
	line-height: 1.55;
}

.kozaru-command-hero,
.kozaru-dashboard-shell,
.kozaru-staff-hero {
	position: relative;
}

.kozaru-command-hero::after,
.kozaru-dashboard-shell::after {
	background: linear-gradient(90deg, rgba(255,255,255,0.2), rgba(255,255,255,0));
	border-radius: inherit;
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
}

.kozaru-dashboard-shell,
.kozaru-frontend-card,
.kozaru-command-card,
.kozaru-managed-student-workspace,
.kozaru-managed-student-picker,
.kozaru-managed-student-glance-panel,
.kozaru-student-snapshot-card,
.kozaru-dashboard-action-card,
.kozaru-dashboard-metric-card,
.kozaru-dashboard-priority-card,
.kozaru-staff-metric,
.kozaru-staff-create-panel,
.kozaru-calendar-event-card,
.kozaru-registration-box {
	border-radius: var(--kozaru-ui-radius);
	min-width: 0;
	overflow-wrap: anywhere;
}

.kozaru-frontend-card,
.kozaru-command-card,
.kozaru-managed-student-workspace,
.kozaru-managed-student-picker,
.kozaru-managed-student-glance-panel,
.kozaru-student-snapshot-card,
.kozaru-dashboard-action-card,
.kozaru-dashboard-metric-card,
.kozaru-staff-metric,
.kozaru-staff-create-panel,
.kozaru-calendar-event-card,
.kozaru-registration-box {
	box-shadow: var(--kozaru-ui-card-shadow);
}

.kozaru-dashboard-action-card,
.kozaru-dashboard-metric-card,
.kozaru-dashboard-priority-card,
.kozaru-student-snapshot-card,
.kozaru-managed-student-picker-card,
.kozaru-command-list-item,
.kozaru-staff-metric,
.kozaru-staff-create-panel,
.kozaru-calendar-event-card {
	transition: border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease;
}

.kozaru-dashboard-action-card:hover,
.kozaru-dashboard-metric-card:hover,
.kozaru-student-snapshot-card:hover,
.kozaru-managed-student-picker-card:hover,
.kozaru-command-list-item:hover,
.kozaru-staff-metric:hover,
.kozaru-staff-create-panel:hover,
.kozaru-calendar-event-card:hover {
	box-shadow: var(--kozaru-ui-card-shadow-hover);
	transform: translateY(-1px);
}

.kozaru-dashboard-section-heading,
.kozaru-staff-section-header,
.kozaru-staff-watch-card-header,
.kozaru-command-card-header,
.kozaru-student-snapshot-header {
	align-items: flex-start;
	min-width: 0;
}

.kozaru-dashboard-section-heading > *,
.kozaru-staff-section-header > *,
.kozaru-staff-watch-card-header > *,
.kozaru-command-card-header > *,
.kozaru-student-snapshot-header > * {
	min-width: 0;
}

.kozaru-dashboard-section-heading p,
.kozaru-staff-section-header p,
.kozaru-command-card-header p,
.kozaru-staff-watch-card-header p {
	color: #64748b;
	font-weight: 650;
	margin-bottom: 0;
}

.kozaru-command-empty,
.kozaru-notice,
.kozaru-form-hint {
	line-height: 1.5;
}

.kozaru-command-empty {
	background: #f8fafc;
	border: 1px dashed #cbd5e1;
	border-radius: var(--kozaru-ui-radius-sm);
	color: #64748b;
	font-weight: 650;
	margin: 0;
	padding: 12px 14px;
}

.kozaru-command-list .kozaru-command-empty,
.kozaru-staff-watch-list .kozaru-command-empty {
	grid-column: 1 / -1;
}

.kozaru-button,
.kozaru-registration-form .button,
.kozaru-login-form-card .button,
.kozaru-staff-tab,
.kozaru-managed-student-tabs .kozaru-button,
.kozaru-add-to-calendar summary {
	-webkit-tap-highlight-color: transparent;
}

.kozaru-button,
.kozaru-registration-form .button,
.kozaru-login-form-card .button {
	white-space: normal;
}

.kozaru-command-list-actions,
.kozaru-frontend-card-actions,
.kozaru-form-actions,
.kozaru-staff-button-row,
.kozaru-calendar-event-actions,
.kozaru-item-detail-actions {
	align-items: center;
	gap: 8px;
}

.kozaru-status,
.kozaru-health-badge,
.kozaru-student-attention-chip,
.kozaru-staff-count-pill,
.kozaru-class-category-pill,
.kozaru-group-pill {
	max-width: 100%;
	min-width: 0;
}

.kozaru-staff-tabs,
.kozaru-managed-student-tabs {
	background: rgba(255,255,255,0.74);
	border: 1px solid rgba(215, 222, 232, 0.75);
	border-radius: 999px;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.045);
	padding: 6px;
}

.kozaru-staff-tab,
.kozaru-managed-student-tabs .kozaru-button {
	border-radius: 999px;
	min-height: 38px;
}

.kozaru-staff-tab.is-active,
.kozaru-staff-tab[aria-current="page"],
.kozaru-managed-student-tabs .kozaru-button.is-active,
.kozaru-managed-student-tabs .kozaru-button[aria-selected="true"] {
	box-shadow: 0 8px 18px rgba(17, 24, 39, 0.16);
}

.kozaru-dashboard-metric-grid,
.kozaru-dashboard-action-grid,
.kozaru-student-snapshot-grid,
.kozaru-manager-action-queue-grid,
.kozaru-manager-snapshot-grid,
.kozaru-manager-shortcut-grid,
.kozaru-staff-watch-grid,
.kozaru-command-grid,
.kozaru-frontend-card-grid,
.kozaru-portal-card-grid {
	align-items: stretch;
}

.kozaru-dashboard-action-card,
.kozaru-student-snapshot-card,
.kozaru-manager-cockpit-card,
.kozaru-staff-watch-card,
.kozaru-command-card,
.kozaru-frontend-card {
	align-content: start;
}

.kozaru-staff-interface .kozaru-staff-section {
	margin-top: clamp(18px, 3vw, 30px);
}

.kozaru-staff-interface .kozaru-staff-section:first-of-type {
	margin-top: 0;
}

.kozaru-manager-priority-item,
.kozaru-staff-watch-item,
.kozaru-managed-registration-item,
.kozaru-form-status-item,
.kozaru-command-booking-list .kozaru-command-list-item,
.kozaru-forms-status-list .kozaru-command-list-item {
	border-radius: 16px;
}

.kozaru-staff-table,
.kozaru-staff-grading-table,
.kozaru-waiver-status-table {
	border-collapse: separate;
	border-spacing: 0;
}

.kozaru-table-scroll table,
.kozaru-staff-table,
.kozaru-staff-grading-table {
	margin-bottom: 0;
}

.kozaru-managed-student-picker-card,
.kozaru-student-snapshot-card {
	isolation: isolate;
}

.kozaru-managed-student-picker-card.is-active,
.kozaru-student-snapshot-card.is-active {
	position: relative;
}

.kozaru-managed-student-picker-card.is-active::after,
.kozaru-student-snapshot-card.is-active::after {
	border: 2px solid rgba(255,255,255,0.52);
	border-radius: inherit;
	content: "";
	inset: 5px;
	pointer-events: none;
	position: absolute;
	z-index: -1;
}

.kozaru-dashboard-metric-card,
.kozaru-staff-metric,
.kozaru-manager-cockpit-card {
	min-height: 0;
}

.kozaru-dashboard-metric-card small,
.kozaru-staff-metric small,
.kozaru-manager-cockpit-card small,
.kozaru-student-snapshot-header small,
.kozaru-command-list-item small {
	line-height: 1.35;
}

@media screen and (min-width: 1180px) {
	.kozaru-frontend-wrap.kozaru-staff-interface,
	.kozaru-staff-interface {
		padding-left: clamp(24px, 2.4vw, 42px);
		padding-right: clamp(24px, 2.4vw, 42px);
	}

	.kozaru-manager-action-queue-grid,
	.kozaru-manager-snapshot-grid,
	.kozaru-manager-shortcut-grid {
		grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
	}

	.kozaru-staff-watch-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 900px) {
	.kozaru-staff-tabs,
	.kozaru-managed-student-tabs {
		border-radius: 18px;
	}

	.kozaru-dashboard-section-heading,
	.kozaru-staff-section-header,
	.kozaru-staff-watch-card-header,
	.kozaru-command-card-header,
	.kozaru-student-snapshot-header {
		display: grid;
		gap: 10px;
		grid-template-columns: minmax(0, 1fr);
	}
}

@media screen and (max-width: 782px) {
	.kozaru-frontend-wrap,
	.kozaru-calendar-shortcode,
	.kozaru-registration-box,
	.kozaru-staff-interface {
		padding-left: 8px;
		padding-right: 8px;
	}

	.kozaru-command-hero,
	.kozaru-dashboard-shell {
		border-left-width: 5px;
		border-radius: 22px;
		padding: 20px;
	}

	.kozaru-command-hero h2,
	.kozaru-dashboard-shell h2,
	.kozaru-frontend-wrap h2,
	.kozaru-calendar-shortcode h2 {
		font-size: clamp(2rem, 12vw, 3.1rem);
		letter-spacing: -0.055em;
	}

	.kozaru-frontend-card,
	.kozaru-command-card,
	.kozaru-managed-student-workspace,
	.kozaru-managed-student-picker,
	.kozaru-managed-student-glance-panel,
	.kozaru-student-snapshot-card,
	.kozaru-dashboard-action-card,
	.kozaru-dashboard-metric-card,
	.kozaru-staff-metric,
	.kozaru-staff-create-panel,
	.kozaru-calendar-event-card,
	.kozaru-registration-box {
		border-radius: 18px;
		padding: 15px;
	}

	.kozaru-command-list-item,
	.kozaru-manager-priority-item,
	.kozaru-staff-watch-item,
	.kozaru-managed-registration-item,
	.kozaru-form-status-item {
		gap: 10px;
		padding: 12px;
	}

	.kozaru-command-list-actions,
	.kozaru-frontend-card-actions,
	.kozaru-form-actions,
	.kozaru-staff-button-row,
	.kozaru-calendar-event-actions,
	.kozaru-item-detail-actions,
	.kozaru-managed-registration-actions {
		display: grid;
		grid-template-columns: minmax(0, 1fr);
		width: 100%;
	}

	.kozaru-command-list-actions .kozaru-button,
	.kozaru-command-list-actions .button,
	.kozaru-frontend-card-actions .kozaru-button,
	.kozaru-frontend-card-actions .button,
	.kozaru-form-actions .kozaru-button,
	.kozaru-form-actions .button,
	.kozaru-staff-button-row .kozaru-button,
	.kozaru-staff-button-row .button,
	.kozaru-calendar-event-actions .kozaru-button,
	.kozaru-calendar-event-actions .button,
	.kozaru-item-detail-actions .kozaru-button,
	.kozaru-item-detail-actions .button,
	.kozaru-managed-registration-actions .kozaru-button,
	.kozaru-managed-registration-actions .button,
	.kozaru-add-to-calendar,
	.kozaru-add-to-calendar summary {
		justify-content: center;
		text-align: center;
		width: 100%;
	}

	.kozaru-staff-tabs,
	.kozaru-managed-student-tabs {
		border-radius: 16px;
		margin-left: -2px;
		margin-right: -2px;
		padding: 5px;
	}

	.kozaru-staff-tab,
	.kozaru-managed-student-tabs .kozaru-button {
		flex: 0 0 auto;
		font-size: 0.86rem;
		min-height: 36px;
		padding: 8px 11px;
	}

	.kozaru-dashboard-metric-grid,
	.kozaru-dashboard-action-grid,
	.kozaru-student-snapshot-grid,
	.kozaru-manager-action-queue-grid,
	.kozaru-manager-snapshot-grid,
	.kozaru-manager-shortcut-grid,
	.kozaru-staff-watch-grid,
	.kozaru-command-grid,
	.kozaru-frontend-card-grid,
	.kozaru-portal-card-grid {
		gap: 10px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.kozaru-frontend-wrap *,
	.kozaru-calendar-shortcode *,
	.kozaru-registration-box * {
		animation-duration: 0.01ms !important;
		scroll-behavior: auto !important;
		transition-duration: 0.01ms !important;
	}
}

/* -----------------------------------------------------------------------------
Kozaru Honbu v0.2.10.10 - public class schedule tightening
-------------------------------------------------------------------------- */
.kozaru-calendar-shortcode .kozaru-calendar-event-list {
	gap: 10px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-card {
	align-items: center;
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(15, 23, 42, 0.10);
	border-left: 5px solid var(--kozaru-category-colour, #2271b1);
	box-shadow: 0 10px 26px rgba(15, 23, 42, 0.05);
	display: grid;
	gap: 14px;
	grid-template-columns: 124px minmax(0, 1fr) auto;
	min-height: 0;
	padding: 14px 16px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-date {
	align-self: stretch;
	background: rgba(248, 250, 252, 0.92);
	border: 1px solid rgba(15, 23, 42, 0.10);
	border-radius: 14px;
	box-shadow: none;
	min-width: 0;
	padding: 10px 12px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-date strong {
	font-size: 1.05rem;
	line-height: 1.05;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-date span {
	font-size: 0.82rem;
	line-height: 1.25;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-main {
	min-width: 0;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-main h3 {
	font-size: 1.08rem;
	line-height: 1.18;
	margin: 0 0 5px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-meta {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 6px 12px;
	margin: 0;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-meta span,
.kozaru-calendar-shortcode .kozaru-calendar-event-registration,
.kozaru-calendar-shortcode .kozaru-calendar-event-excluded {
	font-size: 0.82rem;
	line-height: 1.3;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-registration {
	margin-top: 5px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-actions {
	align-items: center;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 7px;
	justify-content: flex-end;
	margin: 0;
	min-width: 190px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-actions .kozaru-button,
.kozaru-calendar-shortcode .kozaru-calendar-event-actions .button,
.kozaru-calendar-shortcode .kozaru-calendar-event-actions .kozaru-add-to-calendar summary {
	font-size: 0.82rem;
	min-height: 34px;
	padding: 7px 11px;
	white-space: nowrap;
}

.kozaru-calendar-shortcode .kozaru-trial-booking-link {
	border-color: rgba(34, 113, 177, 0.35);
}

@media (max-width: 900px) {
	.kozaru-calendar-shortcode .kozaru-calendar-event-card {
		grid-template-columns: 104px minmax(0, 1fr);
	}

	.kozaru-calendar-shortcode .kozaru-calendar-event-actions {
		grid-column: 1 / -1;
		justify-content: flex-start;
		min-width: 0;
	}
}

@media (max-width: 640px) {
	.kozaru-calendar-shortcode .kozaru-calendar-event-card {
		grid-template-columns: 1fr;
		padding: 12px;
	}

	.kozaru-calendar-shortcode .kozaru-calendar-event-date {
		align-items: center;
		display: flex;
		gap: 10px;
		justify-content: space-between;
		padding: 9px 10px;
	}

	.kozaru-calendar-shortcode .kozaru-calendar-event-actions,
	.kozaru-calendar-shortcode .kozaru-calendar-event-actions .kozaru-button,
	.kozaru-calendar-shortcode .kozaru-calendar-event-actions .button,
	.kozaru-calendar-shortcode .kozaru-calendar-event-actions .kozaru-add-to-calendar,
	.kozaru-calendar-shortcode .kozaru-calendar-event-actions .kozaru-add-to-calendar summary {
		width: 100%;
	}
}

/* -----------------------------------------------------------------------------
Kozaru Honbu v0.2.10.10 - kiosk launch fix and corporate schedule grouping
-------------------------------------------------------------------------- */
.kozaru-calendar-shortcode .kozaru-calendar-event-list {
	display: grid;
	gap: 8px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-card {
	border-left-width: 4px;
	gap: 10px;
	grid-template-columns: 92px minmax(0, 1fr) auto;
	padding: 10px 12px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-date {
	border-radius: 12px;
	padding: 8px 9px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-date strong {
	font-size: 0.96rem;
	line-height: 1.02;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-date span {
	font-size: 0.76rem;
	line-height: 1.2;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-main h3 {
	font-size: 1rem;
	line-height: 1.12;
	margin-bottom: 3px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-meta {
	gap: 4px 9px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-meta span,
.kozaru-calendar-shortcode .kozaru-calendar-event-registration,
.kozaru-calendar-shortcode .kozaru-calendar-event-excluded,
.kozaru-calendar-shortcode .kozaru-calendar-combined-details {
	font-size: 0.78rem;
	line-height: 1.25;
}

.kozaru-calendar-shortcode .kozaru-calendar-combined-details {
	color: #64748b;
	font-weight: 650;
	margin-top: 4px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-registration {
	margin-top: 3px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-actions {
	gap: 5px;
	min-width: 160px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-actions .kozaru-button,
.kozaru-calendar-shortcode .kozaru-calendar-event-actions .button,
.kozaru-calendar-shortcode .kozaru-calendar-event-actions .kozaru-add-to-calendar summary {
	font-size: 0.78rem;
	min-height: 30px;
	padding: 6px 9px;
}

.kozaru-calendar-shortcode .kozaru-calendar-event-card-combined {
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.95));
}

@media (min-width: 1180px) {
	.kozaru-calendar-shortcode .kozaru-calendar-event-list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.kozaru-calendar-shortcode .kozaru-calendar-event-card {
		grid-template-columns: 86px minmax(0, 1fr);
	}

	.kozaru-calendar-shortcode .kozaru-calendar-event-actions {
		grid-column: 1 / -1;
		justify-content: flex-end;
		min-width: 0;
	}
}

@media (max-width: 900px) {
	.kozaru-calendar-shortcode .kozaru-calendar-event-card {
		grid-template-columns: 86px minmax(0, 1fr);
	}
}

/* v0.2.10.11 frontend generated menu positioning. */
.wp-block-navigation .kozaru-menu-auth-first,
.menu .kozaru-menu-auth-first,
.nav-menu .kozaru-menu-auth-first,
ul.menu .kozaru-menu-auth-first {
	margin-left: auto;
}

.wp-block-navigation .kozaru-menu-dashboard,
.menu .kozaru-menu-dashboard,
.nav-menu .kozaru-menu-dashboard,
ul.menu .kozaru-menu-dashboard {
	order: -10;
}

.wp-block-navigation .kozaru-menu-auth,
.menu .kozaru-menu-auth,
.nav-menu .kozaru-menu-auth,
ul.menu .kozaru-menu-auth {
	order: 90;
}

/* Kozaru Honbu v0.3.2.6 - kiosk AJAX tap-race hardening */
.kozaru-attendance-kiosk.is-loading .kozaru-kiosk-checkin-button,
.kozaru-attendance-kiosk.is-loading .kozaru-kiosk-clear-form button[type="submit"] {
	cursor: progress;
	opacity: 0.68;
}

.kozaru-attendance-kiosk.is-loading .kozaru-kiosk-checkin-button:hover,
.kozaru-attendance-kiosk.is-loading .kozaru-kiosk-checkin-button:focus-visible,
.kozaru-kiosk-checkin-button:disabled:hover,
.kozaru-kiosk-checkin-button:disabled:focus-visible {
	transform: none;
	box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
}

.kozaru-kiosk-checkin-button:disabled,
.kozaru-kiosk-clear-form button[type="submit"]:disabled {
	pointer-events: none;
}

.kozaru-kiosk-checkin-form.is-loading .kozaru-kiosk-checkin-button {
	opacity: 1;
}

/* v0.3.3.4 - Frontend staff scalable selector workflow polish. */
.kozaru-staff-student-jump-card,
.kozaru-staff-manual-grading-card,
.kozaru-staff-suspension-card,
.kozaru-staff-contact-log-entry-card {
	margin-bottom: 1.25rem;
}

.kozaru-staff-student-jump-form {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 1rem;
	align-items: end;
}

.kozaru-staff-student-jump-form label {
	min-width: 0;
}

.kozaru-staff-suspension-card h4 {
	margin-top: 1.5rem;
}

@media (max-width: 720px) {
	.kozaru-staff-student-jump-form {
		grid-template-columns: 1fr;
	}
}

/* v0.4.0.1 - external grading eligibility checks from integration plugins. */
.kozaru-eligibility-external-checks {
	list-style: none;
	margin: 8px 0 0;
	padding: 0;
	display: grid;
	gap: 6px;
}

.kozaru-eligibility-external-check {
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: 10px;
	padding: 7px 9px;
	background: rgba(255, 255, 255, 0.72);
}

.kozaru-eligibility-external-check strong,
.kozaru-eligibility-external-check span,
.kozaru-eligibility-external-check small {
	display: block;
}

.kozaru-eligibility-external-check small {
	margin-top: 2px;
	opacity: 0.78;
}

/* v0.4.0.2 - clearer external grading eligibility checks. */
.kozaru-eligibility-check-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .5rem;
}

.kozaru-eligibility-check-status {
	display: inline-flex !important;
	align-items: center;
	border-radius: 999px;
	padding: .15rem .5rem;
	background: rgba(15, 23, 42, .08);
	font-size: .68rem;
	font-weight: 850;
	line-height: 1.4;
	text-transform: uppercase;
}

.kozaru-eligibility-check-progress {
	display: grid;
	grid-template-columns: minmax(4.5rem, 1fr) auto;
	gap: .5rem;
	align-items: center;
	margin-top: .4rem;
}

.kozaru-eligibility-check-progress-bar {
	display: block !important;
	position: relative;
	height: .45rem;
	border-radius: 999px;
	background: rgba(15, 23, 42, .12);
	overflow: hidden;
}

.kozaru-eligibility-check-progress-bar::before {
	content: "";
	position: absolute;
	inset: 0 auto 0 0;
	width: var(--kozaru-check-percent, 0%);
	border-radius: inherit;
	background: currentColor;
}

.kozaru-eligibility-check-message,
.kozaru-eligibility-check-meta {
	display: block !important;
	margin-top: .25rem;
}

.kozaru-eligibility-check-pass {
	border-color: rgba(22, 101, 52, .22);
	color: #166534;
}

.kozaru-eligibility-check-warning {
	border-color: rgba(180, 83, 9, .24);
	color: #92400e;
}

.kozaru-eligibility-check-fail {
	border-color: rgba(185, 28, 28, .28);
	color: #991b1b;
}

.kozaru-eligibility-check-info {
	color: #1f2937;
}


/* v0.4.2.2 - Learn-aware grading readiness UX. */
.kozaru-grading-readiness-summary {
	border: 1px solid rgba(15, 23, 42, .12);
	border-radius: 1rem;
	background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(248,250,252,.88));
	padding: .8rem .9rem;
	margin: 0 0 .8rem;
	box-shadow: 0 .7rem 1.5rem rgba(15, 23, 42, .07);
}

.kozaru-grading-readiness-summary.is-compact {
	padding: .7rem;
}

.kozaru-grading-readiness-summary-main {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: .75rem;
}

.kozaru-grading-readiness-summary-main small {
	color: #475569;
	line-height: 1.45;
}

.kozaru-grading-readiness-pill {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	padding: .2rem .65rem;
	font-size: .68rem;
	font-weight: 850;
	letter-spacing: .02em;
	text-transform: uppercase;
	white-space: nowrap;
}

.kozaru-grading-readiness-pill-success { background: #dcfce7; color: #166534; }
.kozaru-grading-readiness-pill-warning { background: #fef3c7; color: #92400e; }
.kozaru-grading-readiness-pill-danger { background: #fee2e2; color: #991b1b; }
.kozaru-grading-readiness-pill-info { background: #e0f2fe; color: #075985; }

.kozaru-grading-readiness-facts {
	display: flex;
	flex-wrap: wrap;
	gap: .4rem;
	margin-top: .6rem;
}

.kozaru-grading-readiness-facts span {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	background: rgba(15, 23, 42, .06);
	color: #334155;
	font-size: .68rem;
	font-weight: 780;
	padding: .15rem .5rem;
}

.kozaru-grading-readiness-reasons {
	margin: .6rem 0 0 1.1rem;
	color: #475569;
}

.kozaru-eligibility-external-panel {
	margin-top: .75rem;
}

.kozaru-eligibility-external-panel-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: .75rem;
	margin-bottom: .45rem;
}

.kozaru-eligibility-external-panel-header strong,
.kozaru-eligibility-external-panel-header small {
	display: block;
}

.kozaru-eligibility-external-panel-header small,
.kozaru-eligibility-external-counts {
	color: #64748b;
	font-size: .68rem;
}

.kozaru-eligibility-blocking-note {
	border-left: 3px solid #991b1b;
	background: #fef2f2;
	color: #991b1b;
	font-weight: 780;
	padding: .45rem .55rem;
	border-radius: .7rem;
	margin-bottom: .45rem;
}

.kozaru-eligibility-check-source {
	color: #64748b;
	font-size: .68rem;
}

.kozaru-eligibility-check-meta-row {
	display: flex;
	flex-wrap: wrap;
	gap: .3rem;
	margin-top: .45rem;
}

.kozaru-eligibility-check-meta-pill {
	display: inline-flex !important;
	align-items: center;
	border-radius: 999px;
	background: rgba(15, 23, 42, .07);
	color: #334155;
	font-size: .62rem;
	font-weight: 850;
	padding: .1rem .45rem;
	text-transform: uppercase;
}

.kozaru-eligibility-check-meta-pill.is-blocking-now {
	background: #fee2e2;
	color: #991b1b;
}

.kozaru-eligibility-external-check.is-blocking-now {
	box-shadow: 0 0 0 2px rgba(185, 28, 28, .08);
}

@media (max-width: 720px) {
	.kozaru-grading-readiness-summary-main,
	.kozaru-eligibility-external-panel-header {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* v0.4.2.2 - Learn-aware analytics next-step rows. */
.kozaru-grading-readiness-next-step,
.kozaru-eligibility-check-next-step {
	display: block;
	margin-top: .55rem;
	padding: .55rem .7rem;
	border-radius: .75rem;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	color: #334155;
	font-size: .78rem;
	line-height: 1.45;
}

.kozaru-grading-readiness-next-step strong,
.kozaru-eligibility-check-next-step strong {
	color: #0f172a;
}

.kozaru-manager-analytics-next-step-list li {
	display: grid;
	grid-template-columns: minmax(8rem, 1fr) minmax(12rem, 2fr) auto;
	gap: .6rem;
	align-items: start;
}

.kozaru-manager-analytics-next-step-list em {
	font-style: normal;
	font-size: .72rem;
	font-weight: 800;
	text-transform: uppercase;
	color: #64748b;
}

@media (max-width: 720px) {
	.kozaru-manager-analytics-next-step-list li {
		grid-template-columns: 1fr;
	}
}

/* v0.4.2.2 - Learn action-queue metadata. */
.kozaru-grading-readiness-action-pill,
.kozaru-eligibility-check-action-link {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	font-size: .68rem;
	font-weight: 850;
	line-height: 1.2;
	padding: .16rem .5rem;
	text-transform: uppercase;
	text-decoration: none;
}

.kozaru-grading-readiness-action-critical,
.kozaru-action-priority-critical { background: #fee2e2 !important; color: #991b1b !important; }
.kozaru-grading-readiness-action-high,
.kozaru-action-priority-high { background: #ffedd5 !important; color: #9a3412 !important; }
.kozaru-grading-readiness-action-normal,
.kozaru-action-priority-normal { background: #e0f2fe !important; color: #075985 !important; }
.kozaru-grading-readiness-action-low,
.kozaru-action-priority-low { background: #f1f5f9 !important; color: #475569 !important; }
.kozaru-grading-readiness-action-done,
.kozaru-action-priority-done { background: #dcfce7 !important; color: #166534 !important; }

.kozaru-grading-readiness-next-step {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: .45rem;
}

.kozaru-manager-analytics-priority-list li a {
	justify-self: end;
	font-size: .72rem;
	font-weight: 850;
	text-decoration: none;
}

@media (max-width: 720px) {
	.kozaru-grading-readiness-next-step,
	.kozaru-manager-analytics-priority-list li {
		align-items: flex-start;
		grid-template-columns: 1fr;
	}
}

/* v0.4.2.2 - Manager learning priority queue filters and mobile polish. */
.kozaru-manager-analytics-filter-note {
	margin: .25rem 0 .75rem;
	padding: .55rem .7rem;
	border-left: 4px solid #0ea5e9;
	border-radius: .6rem;
	background: #f0f9ff;
}

.kozaru-manager-action-row {
	position: relative;
	border-left: 4px solid #cbd5e1;
}

.kozaru-manager-action-row.kozaru-action-priority-critical { border-left-color: #b91c1c; }
.kozaru-manager-action-row.kozaru-action-priority-high { border-left-color: #ea580c; }
.kozaru-manager-action-row.kozaru-action-priority-normal { border-left-color: #0284c7; }
.kozaru-manager-action-row.kozaru-action-priority-low { border-left-color: #64748b; }
.kozaru-manager-action-row.kozaru-action-priority-done { border-left-color: #16a34a; }

.kozaru-manager-action-link {
	align-self: center;
	border-radius: 999px;
	padding: .22rem .6rem;
	background: #0f172a;
	color: #fff !important;
}

.kozaru-manager-analytics-empty-action {
	background: #f8fafc;
	color: #475569;
}

@media (max-width: 720px) {
	.kozaru-manager-analytics-filter-form label {
		min-width: 100%;
	}

	.kozaru-manager-action-link {
		justify-self: start;
		width: fit-content;
	}
}

/* Frontend disclosure buttons for manual staff forms. */
.kozaru-disclosure-card > .kozaru-disclosure-summary {
	align-items: center;
	background: var(--kozaru-crimson, #c5161d);
	border-radius: 999px;
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font-weight: 850;
	letter-spacing: .06em;
	line-height: 1.2;
	margin: 0;
	padding: .75rem 1rem;
	text-transform: uppercase;
}

.kozaru-disclosure-card[open] > .kozaru-disclosure-summary {
	margin-bottom: 1rem;
}

/* Phase 32 message delivery states */
.kozaru-status-sendable,
.kozaru-status-sent {
	background: #eaf8ee;
	border-color: #c9eed3;
	color: #0f6b2b;
}

.kozaru-status-blocked,
.kozaru-status-failed,
.kozaru-status-suppressed,
.kozaru-status-needs_contact {
	background: #fff7ed;
	border-color: #fed7aa;
	color: #9a3412;
}

/* Kozaru classmates directory grouping. */
.kozaru-classmates-sections {
	display: grid;
	gap: clamp(18px, 3vw, 28px);
	margin-top: 18px;
}

.kozaru-classmates-section {
	display: grid;
	gap: 12px;
}

.kozaru-classmates-section-header {
	align-items: baseline;
	display: flex;
	gap: 10px;
	justify-content: space-between;
}

.kozaru-classmates-section-header h3 {
	font-size: clamp(1.15rem, 2.2vw, 1.55rem);
	margin: 0;
}

.kozaru-classmates-section-header span {
	color: var(--kozaru-ui-muted, #64748b);
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.kozaru-classmates-list .kozaru-student-list-card-header {
	display: grid;
	gap: 10px;
	grid-template-columns: 1fr;
}

.kozaru-classmates-list .kozaru-student-list-card-identity {
	max-width: 100%;
}

.kozaru-classmates-list .kozaru-student-identity-identity_card .kozaru-student-identity-main {
	min-width: 0;
}

.kozaru-classmates-list .kozaru-student-identity-identity_card .kozaru-student-obi {
	align-items: flex-start;
	min-width: 0;
	text-align: left;
}

@media screen and (max-width: 782px) {
	.kozaru-classmates-section-header {
		align-items: flex-start;
		flex-direction: column;
	}
}

/* v1.0.44 - Student-side preferred regular class display and selection. */
.kozaru-my-preferred-class-card {
	grid-column: 1 / -1;
	display: grid;
	gap: 1rem;
}
.kozaru-my-preferred-class-summary {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	align-items: flex-start;
}
.kozaru-my-preferred-class-current {
	min-width: min(100%, 18rem);
	padding: .85rem 1rem;
	border: 1px solid rgba(15, 23, 42, .1);
	border-radius: 1rem;
	background: linear-gradient(135deg, rgba(197,22,29,.08), rgba(15,23,42,.035));
	box-shadow: inset 0 1px 0 rgba(255,255,255,.65);
}
.kozaru-my-preferred-class-current strong,
.kozaru-my-preferred-class-current span {
	display: block;
}
.kozaru-my-preferred-class-current strong {
	font-size: 1rem;
	color: #111827;
}
.kozaru-my-preferred-class-current span {
	margin-top: .2rem;
	font-size: .85rem;
	color: #64748b;
}
.kozaru-preferred-class-form {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
	gap: .75rem;
	align-items: end;
}
.kozaru-preferred-class-form label {
	display: grid;
	gap: .28rem;
	font-weight: 800;
	color: #334155;
}
.kozaru-preferred-class-form label span {
	font-size: .78rem;
	letter-spacing: .03em;
	text-transform: uppercase;
	color: #64748b;
}
.kozaru-preferred-class-form select {
	width: 100%;
	min-height: 2.55rem;
	border: 1px solid rgba(15, 23, 42, .16);
	border-radius: .8rem;
	background: #fff;
	padding: .55rem .7rem;
	color: #111827;
}
@media (max-width: 760px) {
	.kozaru-my-preferred-class-summary,
	.kozaru-preferred-class-form {
		display: grid;
		grid-template-columns: 1fr;
	}
	.kozaru-my-preferred-class-current {
		min-width: 0;
	}
	.kozaru-preferred-class-form .kozaru-button {
		width: 100%;
	}
}

/* v1.0.45 student preferred class live picker + private training journal. */
.kozaru-training-journal-card {
	display: grid;
	gap: 1rem;
}

.kozaru-training-journal-heading {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	align-items: flex-start;
}

.kozaru-training-journal-form {
	display: grid;
	gap: .75rem;
}

.kozaru-training-journal-fields {
	display: grid;
	grid-template-columns: minmax(0, .8fr) minmax(0, .9fr) minmax(0, 1.6fr);
	gap: .75rem;
}

.kozaru-training-journal-fields .is-wide {
	min-width: 0;
}

.kozaru-training-journal-form label {
	display: grid;
	gap: .28rem;
	font-weight: 700;
}

.kozaru-training-journal-form label span {
	font-size: .78rem;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: #64748b;
}

.kozaru-training-journal-form input,
.kozaru-training-journal-form select,
.kozaru-training-journal-form textarea {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.kozaru-training-journal-list {
	display: grid;
	gap: .65rem;
}

.kozaru-training-journal-entry {
	border: 1px solid rgba(15,23,42,.1);
	border-radius: .9rem;
	padding: .75rem .85rem;
	background: #f8fafc;
}

.kozaru-training-journal-entry div {
	display: flex;
	justify-content: space-between;
	gap: .75rem;
	align-items: baseline;
	flex-wrap: wrap;
}

.kozaru-training-journal-entry strong {
	color: #0f172a;
}

.kozaru-training-journal-entry span {
	font-size: .78rem;
	font-weight: 800;
	color: #64748b;
}

.kozaru-training-journal-entry p {
	margin: .35rem 0 0;
	color: #334155;
}

@media (max-width: 760px) {
	.kozaru-training-journal-fields {
		grid-template-columns: 1fr;
	}
}

/* v1.0.46 top-level encrypted student training journal. */
.kozaru-training-journal-page {
	display: grid;
	gap: 1.25rem;
}

.kozaru-training-journal-privacy-card,
.kozaru-training-journal-feature-card {
	display: grid;
	gap: 1rem;
}

.kozaru-training-journal-privacy-card {
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: start;
}

.kozaru-training-journal-privacy-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: flex-end;
	max-width: 24rem;
}

.kozaru-training-journal-privacy-badges span,
.kozaru-training-journal-feature span {
	border: 1px solid rgba(17, 24, 39, 0.12);
	border-radius: 999px;
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 700;
	line-height: 1;
	padding: 0.45rem 0.65rem;
	text-transform: uppercase;
}

.kozaru-training-journal-feature-grid {
	display: grid;
	gap: 0.85rem;
	grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
}

.kozaru-training-journal-feature {
	border: 1px solid rgba(17, 24, 39, 0.1);
	border-radius: 1rem;
	display: grid;
	gap: 0.45rem;
	padding: 1rem;
}

.kozaru-training-journal-feature p {
	margin: 0;
}

.kozaru-training-journal-feature.is-locked {
	opacity: 0.72;
}

@media (max-width: 760px) {
	.kozaru-training-journal-privacy-card {
		grid-template-columns: 1fr;
	}

	.kozaru-training-journal-privacy-badges {
		justify-content: flex-start;
	}
}

/* v1.0.47 private journal feature testing modules. */
.kozaru-training-journal-test-mode {
	border-left: 3px solid rgba(15, 23, 42, 0.22);
	color: #475569;
	font-size: 0.9rem;
	margin: 0.75rem 0 0;
	padding-left: 0.75rem;
}

.kozaru-training-journal-insight-grid {
	display: grid;
	gap: 0.75rem;
	grid-template-columns: repeat(auto-fit, minmax(8.5rem, 1fr));
}

.kozaru-training-journal-insight-grid article {
	background: #f8fafc;
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: 0.9rem;
	padding: 0.85rem;
}

.kozaru-training-journal-insight-grid strong {
	display: block;
	font-size: 1.45rem;
	line-height: 1.1;
}

.kozaru-training-journal-insight-grid span,
.kozaru-training-journal-mini-clouds span,
.kozaru-training-journal-meta-pills span,
.kozaru-training-journal-tags span {
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

.kozaru-training-journal-mini-clouds {
	display: grid;
	gap: 0.75rem;
	grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
}

.kozaru-training-journal-mini-clouds > div,
.kozaru-training-journal-goal,
.kozaru-training-journal-filter-card {
	background: #fff;
	border: 1px solid rgba(15, 23, 42, 0.09);
	border-radius: 0.9rem;
	padding: 0.85rem;
}

.kozaru-training-journal-mini-clouds strong {
	display: block;
	margin-bottom: 0.45rem;
}

.kozaru-training-journal-mini-clouds span,
.kozaru-training-journal-meta-pills span,
.kozaru-training-journal-tags span,
.kozaru-training-journal-privacy-badges span {
	background: rgba(15, 23, 42, 0.04);
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: 999px;
	display: inline-flex;
	gap: 0.25rem;
	margin: 0.15rem;
	padding: 0.4rem 0.58rem;
}

.kozaru-training-journal-filter-form {
	display: grid;
	gap: 0.75rem;
	grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
}

.kozaru-training-journal-filter-form label,
.kozaru-training-journal-filter-actions,
.kozaru-training-journal-check {
	display: grid;
	gap: 0.28rem;
}

.kozaru-training-journal-check {
	align-content: end;
	grid-template-columns: auto 1fr;
	justify-content: start;
}

.kozaru-training-journal-check input {
	width: auto;
}

.kozaru-training-journal-filter-actions {
	align-content: end;
	grid-template-columns: repeat(2, auto);
	justify-content: start;
}

.kozaru-training-journal-fields small {
	color: #64748b;
	font-weight: 500;
}

.kozaru-training-journal-goal-form {
	border-bottom: 1px solid rgba(15, 23, 42, 0.08);
	padding-bottom: 1rem;
}

.kozaru-training-journal-goal-list {
	display: grid;
	gap: 0.65rem;
}

.kozaru-training-journal-goal {
	display: grid;
	gap: 0.5rem;
}

.kozaru-training-journal-goal.is-complete {
	opacity: 0.76;
}

.kozaru-training-journal-goal > div,
.kozaru-training-journal-entry-head {
	display: flex;
	gap: 0.75rem;
	justify-content: space-between;
}

.kozaru-training-journal-inline-form {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	justify-content: flex-start;
}

.kozaru-training-journal-inline-form select {
	max-width: 12rem;
}

.kozaru-training-journal-entry {
	display: grid;
	gap: 0.65rem;
}

.kozaru-training-journal-entry.is-favorite {
	box-shadow: inset 3px 0 0 rgba(15, 23, 42, 0.35);
}

.kozaru-training-journal-entry .kozaru-training-journal-entry-head div,
.kozaru-training-journal-goal > div div {
	display: grid;
	gap: 0.2rem;
}

.kozaru-training-journal-entry-body p {
	margin: 0 0 0.55rem;
}

.kozaru-training-journal-entry-body p:last-child {
	margin-bottom: 0;
}

.kozaru-training-journal-prompt {
	border-left: 3px solid rgba(15, 23, 42, 0.18);
	color: #475569;
	font-size: 0.92rem;
	margin: 0;
	padding: 0.2rem 0 0.2rem 0.75rem;
}

.kozaru-training-journal-attachments {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.kozaru-training-journal-attachments strong {
	flex-basis: 100%;
}

.kozaru-training-journal-attachments a {
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: 999px;
	font-size: 0.82rem;
	font-weight: 800;
	padding: 0.4rem 0.65rem;
	text-decoration: none;
}

.kozaru-training-journal-delete-form {
	border-top: 1px solid rgba(15, 23, 42, 0.08);
	padding-top: 0.4rem;
}

@media (max-width: 760px) {
	.kozaru-training-journal-heading,
	.kozaru-training-journal-entry-head,
	.kozaru-training-journal-goal > div {
		align-items: stretch;
		flex-direction: column;
	}

	.kozaru-training-journal-filter-actions {
		grid-template-columns: 1fr;
	}
}

.kozaru-training-journal-export-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: flex-end;
}

@media (max-width: 760px) {
	.kozaru-training-journal-export-actions {
		justify-content: flex-start;
	}
}

/* v1.0.48 - cleaner private journal workspace and vision board. */
.kozaru-training-journal-page {
	gap: 1rem;
}

.kozaru-training-journal-hero {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(18rem, .85fr);
	gap: 1rem;
	align-items: start;
}

.kozaru-training-journal-hero-copy h3 {
	margin-bottom: .35rem;
}

.kozaru-training-journal-hero-copy > p:not(.kozaru-my-details-eyebrow):not(.kozaru-training-journal-test-mode),
.kozaru-training-journal-muted {
	color: #475569;
	margin: .25rem 0 0;
}

.kozaru-training-journal-hero-side {
	display: grid;
	gap: .75rem;
}

.kozaru-training-journal-quick-stats {
	display: grid;
	gap: .5rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.kozaru-training-journal-quick-stats article,
.kozaru-training-journal-count-pill {
	background: #f8fafc;
	border: 1px solid rgba(15, 23, 42, .09);
	border-radius: .85rem;
	padding: .65rem;
}

.kozaru-training-journal-quick-stats strong {
	display: block;
	font-size: 1.2rem;
	line-height: 1.1;
}

.kozaru-training-journal-quick-stats span,
.kozaru-training-journal-count-pill {
	color: #64748b;
	font-size: .72rem;
	font-weight: 850;
	letter-spacing: .04em;
	text-transform: uppercase;
}

.kozaru-training-journal-details {
	display: block;
}

.kozaru-training-journal-details > summary {
	align-items: center;
	cursor: pointer;
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	list-style: none;
}

.kozaru-training-journal-details > summary::-webkit-details-marker {
	display: none;
}

.kozaru-training-journal-details > summary span {
	color: #0f172a;
	font-size: 1rem;
	font-weight: 900;
}

.kozaru-training-journal-details > summary em {
	background: #f8fafc;
	border: 1px solid rgba(15, 23, 42, .08);
	border-radius: 999px;
	color: #64748b;
	font-size: .72rem;
	font-style: normal;
	font-weight: 850;
	letter-spacing: .04em;
	padding: .38rem .6rem;
	text-transform: uppercase;
}

.kozaru-training-journal-details[open] > summary {
	border-bottom: 1px solid rgba(15, 23, 42, .08);
	margin-bottom: .9rem;
	padding-bottom: .75rem;
}

.kozaru-training-journal-controls-inner {
	display: grid;
	gap: .85rem;
}

.kozaru-training-journal-workbench {
	display: grid;
	gap: 1rem;
	grid-template-columns: minmax(0, 1.05fr) minmax(22rem, .95fr);
	align-items: start;
}

.kozaru-training-journal-card {
	gap: .85rem;
}

.kozaru-training-journal-heading h3 {
	margin-bottom: .25rem;
}

.kozaru-training-journal-fields,
.kozaru-training-journal-filter-form,
.kozaru-vision-board-fields {
	grid-template-columns: repeat(auto-fit, minmax(10.5rem, 1fr));
}

.kozaru-training-journal-form textarea {
	min-height: 7.5rem;
}

.kozaru-training-journal-goal-form textarea,
.kozaru-vision-board-form textarea {
	min-height: 5.5rem;
}

.kozaru-vision-board-card {
	position: relative;
}

.kozaru-vision-board-add {
	background: #f8fafc;
	border: 1px solid rgba(15, 23, 42, .08);
	border-radius: 1rem;
	padding: .85rem;
}

.kozaru-vision-board-form {
	gap: .85rem;
}

.kozaru-vision-board-form-grid {
	display: grid;
	gap: .85rem;
	grid-template-columns: minmax(15rem, .7fr) minmax(0, 1.3fr);
}

.kozaru-vision-dropzone {
	align-content: center;
	background: #ffffff;
	border: 2px dashed rgba(15, 23, 42, .18);
	border-radius: 1rem;
	display: grid;
	gap: .45rem;
	justify-items: center;
	min-height: 13rem;
	padding: 1rem;
	text-align: center;
}

.kozaru-vision-dropzone.is-dragging,
.kozaru-vision-dropzone:focus {
	border-color: rgba(15, 23, 42, .45);
	outline: none;
}

.kozaru-vision-dropzone input[type="file"] {
	max-width: 100%;
}

.kozaru-vision-dropzone img {
	display: none;
	max-height: 10rem;
	max-width: 100%;
	object-fit: contain;
	border-radius: .75rem;
}

.kozaru-vision-dropzone.has-preview img {
	display: block;
}

.kozaru-vision-dropzone strong {
	font-size: .95rem;
}

.kozaru-vision-dropzone span {
	color: #64748b;
	font-size: .82rem;
}

.kozaru-vision-board-fields {
	display: grid;
	gap: .75rem;
}

.kozaru-vision-board-lower-grid {
	display: grid;
	gap: .85rem;
	grid-template-columns: minmax(0, 1fr) minmax(16rem, .45fr);
}

.kozaru-vision-placement-grid {
	display: grid;
	gap: .65rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.kozaru-vision-board-canvas {
	background: linear-gradient(90deg, rgba(15, 23, 42, .04) 1px, transparent 1px), linear-gradient(0deg, rgba(15, 23, 42, .04) 1px, transparent 1px), #f8fafc;
	background-size: 40px 40px;
	border: 1px solid rgba(15, 23, 42, .1);
	border-radius: 1rem;
	max-height: 72vh;
	overflow: auto;
	position: relative;
}

.kozaru-vision-board-plane {
	min-height: 820px;
	min-width: 1220px;
	position: relative;
}

.kozaru-vision-board-item {
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, .12);
	border-radius: 1rem;
	box-shadow: 0 14px 32px rgba(15, 23, 42, .08);
	display: grid;
	gap: .55rem;
	overflow: hidden;
	padding: .55rem;
	position: absolute;
}

.kozaru-vision-board-item img {
	background: #e2e8f0;
	border-radius: .75rem;
	display: block;
	max-height: 19rem;
	object-fit: cover;
	width: 100%;
}

.kozaru-vision-board-item-caption {
	display: grid;
	gap: .2rem;
}

.kozaru-vision-board-item-caption strong {
	font-size: .94rem;
	line-height: 1.2;
}

.kozaru-vision-board-item-caption span {
	color: #64748b;
	font-size: .76rem;
	font-weight: 850;
	letter-spacing: .04em;
	text-transform: uppercase;
}

.kozaru-vision-board-item-caption p {
	color: #475569;
	font-size: .84rem;
	margin: 0;
}

.kozaru-vision-board-delete-form {
	border-top: 1px solid rgba(15, 23, 42, .08);
	padding-top: .45rem;
}

.kozaru-vision-board-empty {
	align-items: center;
	background: #ffffff;
	border: 1px dashed rgba(15, 23, 42, .16);
	border-radius: 1rem;
	display: grid;
	gap: .25rem;
	left: 2rem;
	max-width: 28rem;
	padding: 1rem;
	position: absolute;
	top: 2rem;
}

.kozaru-vision-board-empty span {
	color: #64748b;
}

@media (max-width: 980px) {
	.kozaru-training-journal-hero,
	.kozaru-training-journal-workbench,
	.kozaru-vision-board-form-grid,
	.kozaru-vision-board-lower-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.kozaru-training-journal-quick-stats,
	.kozaru-vision-placement-grid {
		grid-template-columns: 1fr;
	}

	.kozaru-training-journal-details > summary {
		align-items: flex-start;
		flex-direction: column;
	}

	.kozaru-vision-board-plane {
		min-width: 900px;
	}
}


.kozaru-message-nav-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.35rem;
	height: 1.35rem;
	margin-left: 0.5rem;
	padding: 0 0.38rem;
	border-radius: 999px;
	background: #d3111d;
	color: #ffffff;
	font-size: 0.72rem;
	font-weight: 900;
	line-height: 1;
	vertical-align: middle;
}

/* Supervised Messages */
.kozaru-messages-page {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.kozaru-message-hero {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	gap: 1rem;
	padding: 1rem;
	border: 1px solid #d7dde5;
	border-radius: 0.75rem;
	background: #ffffff;
}

.kozaru-message-hero h2,
.kozaru-message-hero h3 {
	margin: 0.15rem 0 0.35rem;
}

.kozaru-message-hero p {
	margin: 0;
	color: #58616d;
}

.kozaru-message-audit-pill,
.kozaru-message-count-card {
	align-self: flex-start;
	padding: 0.65rem 0.8rem;
	border-radius: 999px;
	background: #f4f6f8;
	border: 1px solid #d7dde5;
	font-size: 0.85rem;
	font-weight: 700;
	color: #334155;
	white-space: nowrap;
}

.kozaru-message-count-card {
	min-width: 6rem;
	border-radius: 0.75rem;
	text-align: center;
}

.kozaru-message-count-card strong {
	display: block;
	font-size: 2rem;
	line-height: 1;
	color: #111827;
}

.kozaru-message-count-card span {
	display: block;
	margin-top: 0.25rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 0.75rem;
}

.kozaru-message-start-panel {
	border: 1px solid #d7dde5;
	border-radius: 0.85rem;
	background: #ffffff;
	padding: 0.85rem 1rem;
}

.kozaru-message-start-panel summary {
	cursor: pointer;
	font-weight: 800;
	color: #111827;
}

.kozaru-message-start-form {
	display: grid;
	gap: 0.8rem;
	margin-top: 0.85rem;
}

.kozaru-message-start-grid,
.kozaru-message-template-tools {
	display: flex;
	flex-wrap: wrap;
	align-items: end;
	gap: 0.75rem;
}

.kozaru-message-start-grid label,
.kozaru-message-template-tools label {
	display: grid;
	gap: 0.25rem;
	min-width: min(24rem, 100%);
}

.kozaru-message-start-grid span,
.kozaru-message-template-tools span {
	font-size: 0.78rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: #64748b;
}

.kozaru-message-template-hint {
	align-self: center;
	max-width: 34rem;
	text-transform: none !important;
	letter-spacing: 0 !important;
	font-weight: 600 !important;
}

.kozaru-message-start-form textarea {
	width: 100%;
	min-height: 5rem;
	resize: vertical;
}

.kozaru-message-fullscreen-panel,
.kozaru-message-thread-panel,
.kozaru-message-inbox-layout {
	border: 1px solid #d7dde5;
	border-radius: 0.85rem;
	background: #ffffff;
	box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
}

.kozaru-message-fullscreen-panel,
.kozaru-message-thread-panel {
	display: flex;
	flex-direction: column;
	min-height: min(72vh, 760px);
	overflow: hidden;
}

.kozaru-message-thread-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
	padding: 1rem;
	border-bottom: 1px solid #e5e7eb;
}

.kozaru-message-thread-header h3,
.kozaru-message-thread-header p {
	margin: 0.15rem 0;
}

.kozaru-message-thread-canvas {
	flex: 1 1 auto;
	min-height: 22rem;
	max-height: 62vh;
	overflow-y: auto;
	padding: 1rem;
	background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
}

.kozaru-message-bubble-row {
	display: flex;
	margin: 0.65rem 0;
}

.kozaru-message-bubble-row-mine {
	justify-content: flex-end;
}

.kozaru-message-bubble-row-other {
	justify-content: flex-start;
}

.kozaru-message-bubble {
	max-width: min(76%, 46rem);
	padding: 0.8rem 0.95rem;
	border-radius: 1.1rem;
	border: 1px solid transparent;
	box-shadow: 0 6px 18px rgba(15, 23, 42, 0.07);
}

.kozaru-message-bubble-row-mine .kozaru-message-bubble {
	background: #1565c0;
	color: #ffffff;
	border-bottom-right-radius: 0.25rem;
}

.kozaru-message-bubble-row-other .kozaru-message-bubble {
	background: #eef2f6;
	color: #111827;
	border-color: #d7dde5;
	border-bottom-left-radius: 0.25rem;
}

.kozaru-message-bubble p {
	margin: 0;
	white-space: pre-wrap;
	word-break: break-word;
}

.kozaru-message-meta {
	display: block;
	margin-top: 0.45rem;
	font-size: 0.76rem;
	line-height: 1.35;
	opacity: 0.82;
}

.kozaru-message-bubble-row-mine .kozaru-message-meta {
	text-align: right;
}

.kozaru-message-empty,
.kozaru-message-empty-large {
	padding: 2rem;
	text-align: center;
	color: #64748b;
}

.kozaru-message-empty-large {
	margin: 1rem;
	border: 1px dashed #cbd5e1;
	border-radius: 0.75rem;
	background: #f8fafc;
}

.kozaru-message-composer {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0.75rem;
	align-items: end;
	padding: 1rem;
	border-top: 1px solid #e5e7eb;
	background: #ffffff;
}

.kozaru-message-composer textarea {
	width: 100%;
	min-height: 5rem;
	resize: vertical;
}

.kozaru-message-inbox-layout {
	display: grid;
	grid-template-columns: minmax(18rem, 26rem) minmax(0, 1fr);
	min-height: min(75vh, 820px);
	overflow: hidden;
}

.kozaru-message-inbox-list {
	border-right: 1px solid #d7dde5;
	background: #f8fafc;
	overflow-y: auto;
	max-height: 75vh;
	padding: 0.75rem;
}

.kozaru-message-inbox-card {
	display: block;
	padding: 0.85rem;
	margin-bottom: 0.65rem;
	border: 1px solid #d7dde5;
	border-radius: 0.75rem;
	background: #ffffff;
	color: #111827;
	text-decoration: none;
}

.kozaru-message-inbox-card:hover,
.kozaru-message-inbox-card.is-active {
	border-color: #d3111d;
	box-shadow: inset 4px 0 0 #d3111d;
}

.kozaru-message-inbox-card.has-unread {
	border-color: #111827;
	box-shadow: inset 4px 0 0 #111827;
}

.kozaru-message-inbox-top,
.kozaru-message-inbox-preview,
.kozaru-message-inbox-meta {
	display: block;
}

.kozaru-message-inbox-top {
	display: flex;
	justify-content: space-between;
	gap: 0.5rem;
}

.kozaru-message-inbox-top em {
	font-style: normal;
	min-width: 1.6rem;
	padding: 0.1rem 0.4rem;
	border-radius: 999px;
	background: #d3111d;
	color: #ffffff;
	font-size: 0.75rem;
	font-weight: 800;
	text-align: center;
}

.kozaru-message-inbox-preview {
	margin-top: 0.35rem;
	color: #334155;
}

.kozaru-message-inbox-meta {
	margin-top: 0.35rem;
	color: #64748b;
	font-size: 0.78rem;
}

.kozaru-message-selected-thread {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.kozaru-message-retire-form {
	display: flex;
	gap: 0.5rem;
	align-items: center;
	max-width: 34rem;
}

.kozaru-message-retire-form input[type="text"] {
	min-width: 12rem;
}

@media (max-width: 900px) {
	.kozaru-message-hero,
	.kozaru-message-thread-header {
		flex-direction: column;
	}

	.kozaru-message-inbox-layout {
		grid-template-columns: 1fr;
	}

	.kozaru-message-inbox-list {
		max-height: 20rem;
		border-right: 0;
		border-bottom: 1px solid #d7dde5;
	}

	.kozaru-message-composer {
		grid-template-columns: 1fr;
	}

	.kozaru-message-bubble {
		max-width: 92%;
	}
}

.kozaru-message-bubble-row {
	flex-direction: column;
}

.kozaru-message-bubble-row-mine {
	align-items: flex-end;
}

.kozaru-message-bubble-row-other {
	align-items: flex-start;
}

.kozaru-message-bubble-row .kozaru-message-meta {
	max-width: min(76%, 46rem);
	margin-top: 0.25rem;
	padding: 0 0.25rem;
	color: #64748b;
}

.kozaru-message-bubble-row-mine .kozaru-message-meta {
	text-align: right;
}

/* Messages AJAX + HTML template rendering polish */
.kozaru-message-nav-badge[hidden] {
	display: none !important;
}

.kozaru-message-nav-badge.is-empty {
	background: #4b5563;
	color: #ffffff;
	opacity: 0.9;
}

.kozaru-message-bubble-row-mine .kozaru-message-bubble,
.kozaru-message-bubble-row-mine .kozaru-message-bubble * {
	color: #ffffff !important;
}

.kozaru-message-bubble-row-mine .kozaru-message-bubble a {
	color: #ffffff !important;
	text-decoration: underline;
	text-underline-offset: 0.14em;
}

.kozaru-message-bubble :is(p, ul, ol, blockquote, table) {
	margin-top: 0;
}

.kozaru-message-bubble :is(p, ul, ol, blockquote, table):last-child {
	margin-bottom: 0;
}

.kozaru-message-bubble ul,
.kozaru-message-bubble ol {
	padding-left: 1.25rem;
}

.kozaru-message-bubble table {
	max-width: 100%;
	border-collapse: collapse;
}

.kozaru-message-bubble td,
.kozaru-message-bubble th {
	border: 1px solid currentColor;
	padding: 0.25rem 0.4rem;
}

.kozaru-message-composer[data-submitting="1"],
.kozaru-message-start-form[data-submitting="1"],
.kozaru-message-retire-form[data-submitting="1"] {
	opacity: 0.72;
	pointer-events: none;
}

/* v1.0.68 - Public prospect/contact forms. */
.kozaru-prospect-form-box .kozaru-prospect-enquiry-form {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	max-width: 46rem;
}

.kozaru-prospect-form-section {
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: 1rem;
	background: rgba(255, 255, 255, 0.72);
	padding: 1rem;
	box-shadow: 0 12px 30px rgba(15, 23, 42, 0.04);
}

.kozaru-prospect-form-section h3 {
	margin: 0 0 0.75rem;
	font-size: 1rem;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

.kozaru-prospect-field-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.85rem;
}

.kozaru-prospect-field,
.kozaru-prospect-checkbox {
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
	min-width: 0;
}

.kozaru-prospect-field-wide,
.kozaru-prospect-checkbox {
	grid-column: 1 / -1;
}

.kozaru-prospect-checkbox {
	flex-direction: row;
	align-items: flex-start;
	margin-top: 0.8rem;
}

.kozaru-prospect-field span,
.kozaru-prospect-checkbox span {
	font-weight: 700;
}

.kozaru-prospect-field input,
.kozaru-prospect-field select,
.kozaru-prospect-field textarea {
	width: 100%;
	min-height: 2.75rem;
	border-radius: 0.7rem;
}

.kozaru-prospect-field textarea {
	min-height: 8rem;
}

.kozaru-prospect-form-status {
	border-radius: 0.85rem;
	padding: 0.85rem 1rem;
	font-weight: 700;
}

.kozaru-prospect-form-status.is-success {
	background: #ecfdf5;
	color: #065f46;
}

.kozaru-prospect-form-status.is-error {
	background: #fef2f2;
	color: #991b1b;
}

.kozaru-prospect-form-status.is-info {
	background: #eff6ff;
	color: #1d4ed8;
}

.kozaru-prospect-enquiry-form.is-kozaru-submitting {
	opacity: 0.76;
}

@media (max-width: 720px) {
	.kozaru-prospect-field-grid {
		grid-template-columns: 1fr;
	}

	.kozaru-prospect-form-section {
		padding: 0.85rem;
	}
}

/* v1.0.75 - Smarter public prospect form conditionals. */
.kozaru-prospect-field.is-hidden,[data-kozaru-prospect-trial-field][hidden],[data-kozaru-prospect-callback-field][hidden]{display:none!important}.kozaru-prospect-form-section-intent{position:relative}.kozaru-prospect-form-section-intent::after{content:'Fields adjust based on what you choose.';display:block;margin-top:.35rem;color:#64748b;font-size:.85rem}

/* v1.0.86 - trial attendees in kiosk: compact, deliberate buttons */
.kozaru-trial-attendees-today .kozaru-trial-attendee-actions form{margin:0;min-width:0}
.kozaru-trial-attendees-today .kozaru-trial-attendee-actions .kozaru-button{width:100%;min-height:2.4rem;border-radius:.75rem;font-weight:900;letter-spacing:.01em;box-shadow:none}
.kozaru-trial-attendees-today .kozaru-trial-attendee-actions .kozaru-button-secondary{background:#fff;color:#b91c1c;border-color:rgba(185,28,28,.28)}
@media(max-width:720px){.kozaru-trial-attendees-today .kozaru-trial-attendee-actions{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}}

/* v1.0.88 - attendance kiosk frontend parity for photo/PIN view */
.kozaru-kiosk-top-actions{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;justify-content:space-between;margin:0 0 .75rem;}
.kozaru-kiosk-dashboard-return,.kozaru-kiosk-token-link{min-height:2.35rem;border-radius:999px;font-weight:900;}
.kozaru-kiosk-class-select-strip{padding:.75rem .85rem;margin-bottom:.75rem;}
.kozaru-kiosk-class-select-strip .kozaru-kiosk-open-strip-heading h2{font-size:1rem;margin:.1rem 0 .35rem;}
.kozaru-kiosk-class-picker{display:flex;gap:.45rem;overflow-x:auto;padding:.15rem .05rem .35rem;scroll-snap-type:x proximity;}
.kozaru-kiosk-class-picker .kozaru-kiosk-open-item{min-width:10.5rem;padding:.55rem .65rem;border-radius:.8rem;scroll-snap-align:start;}
.kozaru-kiosk-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(9.5rem,1fr));gap:.75rem;}
.kozaru-kiosk-photo-checkin-form{margin:0;}
.kozaru-kiosk-photo-button{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;gap:.45rem;min-height:13rem;padding:.85rem;border-radius:1.1rem;}
.kozaru-kiosk-photo-frame{display:grid;place-items:center;width:5.6rem;height:5.6rem;border-radius:999px;overflow:hidden;background:rgba(15,23,42,.06);border:1px solid rgba(15,23,42,.1);}
.kozaru-kiosk-student-photo{width:100%;height:100%;object-fit:cover;}
.kozaru-kiosk-photo-placeholder{display:grid;place-items:center;width:100%;height:100%;font-size:2rem;font-weight:900;color:rgba(15,23,42,.45);}
.kozaru-kiosk-pin-hint{background:rgba(15,23,42,.08);border-radius:999px;padding:.1rem .45rem;font-weight:900;}
@media(max-width:720px){.kozaru-kiosk-photo-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.kozaru-kiosk-photo-button{min-height:12rem;padding:.7rem .55rem}.kozaru-kiosk-photo-frame{width:4.8rem;height:4.8rem}}

/* v1.0.89 - attendance QR self check-in polish */
.kozaru-kiosk-qr-disclosure {
	margin: 0 0 1rem;
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.88);
	box-shadow: 0 14px 34px rgba(15, 23, 42, 0.07);
	overflow: hidden;
}
.kozaru-kiosk-qr-disclosure > summary {
	cursor: pointer;
	list-style: none;
	padding: 0.85rem 1rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-size: 0.76rem;
	color: #111827;
	background: linear-gradient(135deg, rgba(239, 246, 255, 0.95), rgba(255, 255, 255, 0.95));
}
.kozaru-kiosk-qr-disclosure > summary::-webkit-details-marker {
	display: none;
}
.kozaru-kiosk-qr-disclosure > summary::after {
	content: '+';
	float: right;
	font-size: 1rem;
}
.kozaru-kiosk-qr-disclosure[open] > summary::after {
	content: '−';
}
.kozaru-kiosk-session-qr-card {
	margin: 0;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	background: #fff;
}
.kozaru-kiosk-session-qr-card .kozaru-qr-image-wrap {
	background: #fff;
	border-radius: 16px;
	padding: 0.7rem;
}
.kozaru-kiosk-session-qr-card .kozaru-qr-image {
	display: block;
	width: min(100%, 280px);
	height: auto;
	margin: 0 auto;
}
.kozaru-kiosk-token-note {
	margin-bottom: 1rem;
}
.kozaru-kiosk-class-select-strip {
	padding: 0.75rem;
}
.kozaru-kiosk-class-select-strip .kozaru-kiosk-open-strip-heading {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	margin-bottom: 0.55rem;
}
.kozaru-kiosk-class-select-strip .kozaru-command-eyebrow,
.kozaru-kiosk-class-select-strip h2 {
	margin: 0;
}
.kozaru-kiosk-class-select-strip h2 {
	font-size: clamp(1rem, 3vw, 1.25rem);
}
.kozaru-kiosk-class-picker {
	display: flex;
	gap: 0.5rem;
	overflow-x: auto;
	padding-bottom: 0.25rem;
	scroll-snap-type: x proximity;
}
.kozaru-kiosk-class-picker .kozaru-kiosk-open-item {
	min-width: 170px;
	padding: 0.65rem 0.7rem;
	font-size: 0.86rem;
	scroll-snap-align: start;
}
.kozaru-kiosk-class-picker .kozaru-kiosk-open-item strong {
	font-size: 0.92rem;
}
.kozaru-kiosk-class-picker .kozaru-kiosk-open-item span {
	font-size: 0.78rem;
}
@media (max-width: 720px) {
	.kozaru-kiosk-session-qr-card {
		display: block;
		padding: 1rem;
	}
	.kozaru-kiosk-session-qr-card .kozaru-qr-copy {
		margin-bottom: 0.9rem;
	}
	.kozaru-kiosk-top-actions {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 0.5rem;
	}
	.kozaru-kiosk-top-actions .kozaru-button {
		width: 100%;
		text-align: center;
	}
}

/* v1.0.114 - Attendance kiosk polish: compact class picker and safer self check-in mode. */
.kozaru-kiosk-shell.is-self-checkin-shell {
	max-width: 1120px;
	margin-inline: auto;
}

.kozaru-kiosk-class-select-strip.is-collapsed-picker {
	padding: 0.65rem 0.8rem;
}

.kozaru-kiosk-class-picker-disclosure > summary {
	cursor: pointer;
	font-weight: 900;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	font-size: 0.78rem;
	color: #334155;
}

.kozaru-kiosk-class-picker-disclosure[open] > summary {
	margin-bottom: 0.65rem;
}

.kozaru-kiosk-selected-session-note,
.kozaru-kiosk-self-checked-note {
	font-weight: 850;
	color: #047857;
}

.kozaru-attendance-kiosk.is-self-checkin-mode .kozaru-attendance-sync-note {
	display: none;
}

.kozaru-attendance-kiosk.is-self-checkin-mode .kozaru-kiosk-checked-list li {
	align-items: center;
}

.kozaru-attendance-kiosk.is-self-checkin-mode .kozaru-kiosk-checked-sidebar {
	background: rgba(255, 255, 255, 0.82);
}

.kozaru-trial-attendee-actions .kozaru-button {
	min-height: 2.75rem;
	border-radius: 999px;
	font-weight: 900;
	box-shadow: none;
}

.kozaru-trial-attendee-actions .kozaru-button strong {
	font: inherit;
}

@media (max-width: 720px) {
	.kozaru-kiosk-class-select-strip.is-collapsed-picker .kozaru-kiosk-open-strip-heading h2 {
		font-size: 1rem;
	}

	.kozaru-kiosk-class-picker-disclosure .kozaru-kiosk-class-picker {
		padding-bottom: 0.2rem;
	}

	.kozaru-attendance-kiosk.is-self-checkin-mode .kozaru-kiosk-layout {
		gap: 0.75rem;
	}

	.kozaru-attendance-kiosk.is-self-checkin-mode .kozaru-kiosk-checked-sidebar {
		order: 2;
	}
}


/* v1.0.136 - kiosk class picker reset and student-facing check-in PIN polish. */
body.kozaru-kiosk-bare-template .kozaru-kiosk-shell.is-class-picker-only {
	display: block !important;
	min-height: auto !important;
}
body.kozaru-kiosk-bare-template .kozaru-kiosk-shell.is-class-picker-only .kozaru-kiosk-open-strip {
	display: block !important;
	min-height: 0 !important;
	padding: clamp(1rem, 3vw, 1.5rem) !important;
}
body.kozaru-kiosk-bare-template .kozaru-kiosk-shell.is-class-picker-only .kozaru-kiosk-open-strip-heading {
	margin-bottom: 1rem !important;
}
body.kozaru-kiosk-bare-template .kozaru-kiosk-shell.is-class-picker-only .kozaru-kiosk-class-picker {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
	overflow: visible !important;
	gap: 0.75rem !important;
	padding: 0 !important;
	scroll-snap-type: none !important;
}
body.kozaru-kiosk-bare-template .kozaru-kiosk-shell.is-class-picker-only .kozaru-kiosk-open-item {
	min-width: 0 !important;
	width: 100% !important;
	padding: 0.9rem 1rem !important;
	border-radius: 1rem !important;
	font-size: 1rem !important;
}
.kozaru-student-pin-pill {
	font-variant-numeric: tabular-nums;
}
@media (max-width: 720px) {
	body.kozaru-kiosk-bare-template .kozaru-kiosk-shell.is-class-picker-only .kozaru-kiosk-class-picker {
		grid-template-columns: 1fr !important;
	}
	body.kozaru-kiosk-bare-template .kozaru-kiosk-shell.is-class-picker-only .kozaru-kiosk-open-strip-heading h2 {
		font-size: 1.4rem !important;
	}
}


/* v1.0.137 - selected staff kiosk no longer shows class-change picker. */
body.kozaru-kiosk-bare-template .kozaru-kiosk-shell.has-selected-class.is-staff-kiosk-shell .kozaru-kiosk-class-select-strip {
	display: none !important;
}
body.kozaru-kiosk-bare-template .kozaru-kiosk-shell.has-selected-class.is-staff-kiosk-shell .kozaru-attendance-kiosk {
	margin-top: 0 !important;
}


/* v1.0.140: front-facing cohesion rescue pass. Tighter, calmer, no wrapper gremlins. */
body.kozaru-frontend-student-app-page .kozaru-student-main-panel,
body.kozaru-frontend-student-app-page .kozaru-student-content,
body.kozaru-frontend-student-app-page .kozaru-dashboard-content {
    background: #f3f4f6 !important;
}
body.kozaru-frontend-student-app-page .kozaru-student-main-panel > *,
body.kozaru-frontend-student-app-page .kozaru-frontend-wrap,
body.kozaru-frontend-student-app-page .kozaru-calendar-shortcode {
    max-width: 1120px !important;
}
body.kozaru-frontend-student-app-page h1,
body.kozaru-frontend-student-app-page h2,
.kozaru-calendar-shortcode > h2 {
    font-size: clamp(1.9rem, 3.6vw, 3rem) !important;
    line-height: 1 !important;
    letter-spacing: -.055em !important;
    margin-bottom: .85rem !important;
}
body.kozaru-frontend-student-app-page h3 {
    font-size: clamp(1.1rem, 1.7vw, 1.45rem) !important;
    letter-spacing: -.035em !important;
    line-height: 1.08 !important;
}
body.kozaru-frontend-student-app-page .kozaru-frontend-card,
body.kozaru-frontend-student-app-page .kozaru-command-card,
body.kozaru-frontend-student-app-page .kozaru-dashboard-shell,
body.kozaru-frontend-student-app-page .kozaru-student-section-panel,
body.kozaru-frontend-student-app-page .kozaru-student-section-hero,
body.kozaru-frontend-student-app-page .kozaru-calendar-day-group,
body.kozaru-frontend-student-app-page .kozaru-calendar-filter-panel {
    border: 1px solid rgba(15, 23, 42, .10) !important;
    border-radius: 14px !important;
    box-shadow: none !important;
    background: #fff !important;
}
body.kozaru-frontend-student-app-page .kozaru-frontend-card,
body.kozaru-frontend-student-app-page .kozaru-command-card,
body.kozaru-frontend-student-app-page .kozaru-student-section-panel,
body.kozaru-frontend-student-app-page .kozaru-student-section-hero {
    padding: 1rem !important;
}
.kozaru-command-empty,
.kozaru-training-journal-muted,
.kozaru-my-preferred-class-card .kozaru-command-empty,
.kozaru-managed-registration-heading .kozaru-command-empty,
.kozaru-calendar-range-summary,
.kozaru-eligibility-external-panel-header small,
.kozaru-eligibility-check-source,
.kozaru-eligibility-check-message,
.kozaru-eligibility-check-next-step,
.kozaru-frontend-reason-list {
    display: none !important;
}
.kozaru-my-details-grid {
    grid-template-columns: repeat(3, minmax(240px, 1fr)) !important;
    align-items: stretch !important;
    gap: .8rem !important;
}
.kozaru-my-details-section {
    min-height: 0 !important;
}
.kozaru-frontend-meta-list {
    grid-template-columns: minmax(120px, max-content) minmax(0, 1fr) !important;
    gap: .45rem .85rem !important;
}
.kozaru-frontend-meta-list dt,
.kozaru-my-details-eyebrow,
.kozaru-command-eyebrow,
.kozaru-calendar-day-heading span {
    overflow-wrap: normal !important;
    word-break: keep-all !important;
    white-space: nowrap !important;
    letter-spacing: .13em !important;
}
.kozaru-my-details-submission-list li,
.kozaru-form-status-item {
    display: grid !important;
    grid-template-columns: minmax(220px, 1fr) auto minmax(160px, max-content) !important;
    gap: .75rem !important;
    align-items: center !important;
    min-width: 0 !important;
}
.kozaru-my-details-submission-list li strong,
.kozaru-form-status-item strong {
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
    line-height: 1.15 !important;
}
.kozaru-my-details-submission-list li small,
.kozaru-form-status-item small {
    min-width: 0 !important;
    white-space: normal !important;
    line-height: 1.25 !important;
}
.kozaru-my-forms .kozaru-form-status-item,
.kozaru-forms-manager .kozaru-form-status-item {
    grid-template-columns: minmax(260px, 1fr) auto minmax(140px, max-content) !important;
}
.kozaru-my-forms .kozaru-form-status-item .kozaru-command-list-actions,
.kozaru-forms-manager .kozaru-form-status-item .kozaru-command-list-actions {
    display: flex !important;
    gap: .45rem !important;
    justify-content: flex-end !important;
}
.kozaru-my-grading-progress .kozaru-frontend-card {
    display: grid !important;
    gap: .8rem !important;
}
.kozaru-my-grading-progress .kozaru-core-student-identity,
.kozaru-my-grading-progress .kozaru-student-identity-card {
    padding-bottom: .75rem !important;
    border-bottom: 1px solid rgba(15,23,42,.08) !important;
}
.kozaru-grading-readiness-summary,
.kozaru-eligibility-external-panel,
.kozaru-eligibility-external-check {
    border-radius: 14px !important;
    box-shadow: none !important;
}
.kozaru-grading-readiness-summary {
    padding: .85rem !important;
}
.kozaru-grading-readiness-summary-message {
    font-weight: 800 !important;
    color: #334155 !important;
}
.kozaru-grading-readiness-next {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: .45rem .6rem !important;
    align-items: center !important;
    padding: .65rem .75rem !important;
    border-radius: 12px !important;
}
.kozaru-grading-readiness-next strong {
    display: none !important;
}
.kozaru-eligibility-external-panel {
    border: 0 !important;
    padding: 0 !important;
    background: transparent !important;
}
.kozaru-eligibility-external-panel-header {
    margin: .25rem 0 .5rem !important;
}
.kozaru-eligibility-external-panel-header strong {
    font-size: 1rem !important;
    letter-spacing: -.02em !important;
}
.kozaru-eligibility-blocking-note {
    padding: .65rem .85rem !important;
    border-radius: 12px !important;
    font-size: .92rem !important;
}
.kozaru-eligibility-external-checks {
    display: grid !important;
    gap: .55rem !important;
}
.kozaru-eligibility-external-check {
    padding: .75rem .85rem !important;
    border-width: 1px !important;
}
.kozaru-eligibility-check-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: .75rem !important;
}
.kozaru-eligibility-check-header strong {
    font-size: .98rem !important;
}
.kozaru-eligibility-check-progress {
    margin: .55rem 0 .35rem !important;
}
.kozaru-eligibility-check-meta-row {
    margin-top: .45rem !important;
}
.kozaru-managed-class-plans {
    padding: 0 !important;
}
.kozaru-managed-class-plan-heading,
.kozaru-managed-event-booking-heading {
    margin: 0 0 .7rem !important;
    padding: 0 !important;
    display: flex !important;
    align-items: end !important;
    justify-content: space-between !important;
    gap: .7rem !important;
}
.kozaru-managed-class-plan-list,
.kozaru-managed-registration-list {
    display: grid !important;
    gap: .55rem !important;
}
.kozaru-managed-class-plan-item,
.kozaru-managed-registration-item {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(170px, max-content) !important;
    gap: .75rem !important;
    align-items: center !important;
    padding: .75rem .85rem !important;
    border-radius: 12px !important;
}
.kozaru-command-item-main strong,
.kozaru-command-item-title {
    line-height: 1.14 !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
}
.kozaru-command-item-main small {
    display: block !important;
    margin-top: .2rem !important;
    line-height: 1.2 !important;
}
.kozaru-managed-class-plan-actions,
.kozaru-managed-registration-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    gap: .45rem !important;
    min-width: 0 !important;
}
.kozaru-managed-class-plan-actions .kozaru-button,
.kozaru-managed-registration-actions .kozaru-button,
.kozaru-training-plan-set-button {
    min-height: 34px !important;
    padding: .45rem .7rem !important;
    font-size: .82rem !important;
    white-space: nowrap !important;
}
.kozaru-calendar-shortcode .kozaru-calendar-filter-panel {
    padding: .8rem .9rem !important;
    margin-bottom: .8rem !important;
}
.kozaru-calendar-filter-options {
    gap: .45rem !important;
}
.kozaru-calendar-filter-panel button,
.kozaru-calendar-filter-panel .kozaru-button,
.kozaru-calendar-class-action .kozaru-button {
    min-height: 34px !important;
    padding: .45rem .7rem !important;
    font-size: .82rem !important;
}
.kozaru-calendar-day-group {
    margin-bottom: .75rem !important;
    overflow: hidden !important;
}
.kozaru-calendar-day-heading {
    padding: .65rem .8rem !important;
}
.kozaru-calendar-event-row,
.kozaru-calendar-event-card {
    padding: .55rem .75rem !important;
}
.kozaru-calendar-event-row {
    display: grid !important;
    grid-template-columns: 110px minmax(0, 1fr) auto !important;
    gap: .75rem !important;
    align-items: center !important;
}
.kozaru-calendar-event-title,
.kozaru-calendar-event-row strong {
    font-size: 1rem !important;
    line-height: 1.15 !important;
}
.kozaru-button,
.kozaru-button-secondary,
.kozaru-button-danger,
button.kozaru-button,
a.kozaru-button {
    border-radius: 8px !important;
}
@media (max-width: 900px) {
    .kozaru-my-details-grid { grid-template-columns: 1fr !important; }
    .kozaru-managed-class-plan-item,
    .kozaru-managed-registration-item,
    .kozaru-calendar-event-row {
        grid-template-columns: 1fr !important;
    }
    .kozaru-managed-class-plan-actions,
    .kozaru-managed-registration-actions,
    .kozaru-calendar-class-action {
        justify-content: stretch !important;
        width: 100% !important;
    }
    .kozaru-managed-class-plan-actions form,
    .kozaru-managed-class-plan-actions .kozaru-button,
    .kozaru-managed-registration-actions form,
    .kozaru-managed-registration-actions .kozaru-button,
    .kozaru-calendar-class-action .kozaru-button {
        width: 100% !important;
    }
    .kozaru-my-details-submission-list li,
    .kozaru-form-status-item,
    .kozaru-my-forms .kozaru-form-status-item,
    .kozaru-forms-manager .kozaru-form-status-item {
        grid-template-columns: 1fr auto !important;
    }
    .kozaru-my-details-submission-list li small,
    .kozaru-form-status-item small {
        grid-column: 1 / -1 !important;
    }
}


/* v1.0.142: final student account polish - Profile, Forms, Event Bookings. */
.kozaru-student-app .kozaru-frontend-wrap.kozaru-my-details,
.kozaru-student-app .kozaru-frontend-wrap.kozaru-my-forms,
.kozaru-student-app .kozaru-frontend-wrap.kozaru-my-bookings,
.kozaru-student-app .kozaru-command-page {
  max-width: 1180px !important;
  margin: 0 auto !important;
}

.kozaru-student-app .kozaru-frontend-wrap.kozaru-my-details > h2,
.kozaru-student-app .kozaru-my-forms > h2,
.kozaru-student-app .kozaru-my-bookings > h2 {
  font-size: clamp(2rem, 4vw, 3rem) !important;
  line-height: .95 !important;
  letter-spacing: -.055em !important;
  margin: 0 0 1rem !important;
}

.kozaru-student-app .kozaru-my-details-hero,
.kozaru-student-app .kozaru-my-preferred-class-card,
.kozaru-student-app .kozaru-my-details-section,
.kozaru-student-app .kozaru-my-forms .kozaru-command-card,
.kozaru-student-app .kozaru-my-bookings .kozaru-command-card {
  border: 1px solid rgba(15,23,42,.10) !important;
  border-radius: 18px !important;
  box-shadow: 0 14px 34px rgba(15,23,42,.05) !important;
  background: #fff !important;
}

.kozaru-student-app .kozaru-my-details-hero {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 1rem !important;
  align-items: center !important;
  padding: 1.05rem 1.15rem !important;
}

.kozaru-student-app .kozaru-my-details-identity,
.kozaru-student-app .kozaru-my-details-identity .kozaru-student-identity,
.kozaru-student-app .kozaru-my-details-identity .kozaru-student-identity-card {
  min-width: 0 !important;
}

.kozaru-student-app .kozaru-my-details-primary-meta,
.kozaru-student-app .kozaru-compact-meta {
  display: grid !important;
  grid-template-columns: max-content minmax(0, 1fr) !important;
  align-items: baseline !important;
  gap: .55rem 1rem !important;
  margin: 0 !important;
}

.kozaru-student-app .kozaru-my-details-primary-meta dt,
.kozaru-student-app .kozaru-compact-meta dt {
  min-width: 0 !important;
  white-space: nowrap !important;
  color: #667085 !important;
  font-size: .72rem !important;
  line-height: 1 !important;
  letter-spacing: .14em !important;
}

.kozaru-student-app .kozaru-my-details-primary-meta dd,
.kozaru-student-app .kozaru-compact-meta dd {
  min-width: 0 !important;
  margin: 0 !important;
  text-align: right !important;
  font-weight: 800 !important;
  color: #111827 !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
}

.kozaru-student-app .kozaru-my-preferred-class-card {
  padding: 1rem 1.1rem !important;
}

.kozaru-student-app .kozaru-my-preferred-class-summary {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 320px) !important;
  gap: 1rem !important;
  align-items: center !important;
}

.kozaru-student-app .kozaru-my-preferred-class-current {
  border-radius: 14px !important;
  padding: .8rem .95rem !important;
  background: #f8fafc !important;
  border: 1px solid rgba(15,23,42,.10) !important;
}

.kozaru-student-app .kozaru-preferred-class-form {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto !important;
  gap: .7rem !important;
  align-items: end !important;
  margin-top: .9rem !important;
}

.kozaru-student-app .kozaru-preferred-class-form label,
.kozaru-student-app .kozaru-preferred-class-form select {
  min-width: 0 !important;
  width: 100% !important;
}

.kozaru-student-app .kozaru-preferred-class-form button {
  white-space: nowrap !important;
  min-height: 2.35rem !important;
}

.kozaru-student-app .kozaru-my-details-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 1rem !important;
  align-items: stretch !important;
}

.kozaru-student-app .kozaru-my-details-grid > *,
.kozaru-student-app .kozaru-my-details-section {
  min-width: 0 !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 1rem 1.1rem !important;
  overflow: hidden !important;
}

.kozaru-student-app .kozaru-my-details-section h3 {
  font-size: 1.25rem !important;
  line-height: 1.05 !important;
  letter-spacing: -.025em !important;
  margin: 0 0 .9rem !important;
  white-space: normal !important;
}

.kozaru-student-app .kozaru-my-details-forms .kozaru-forms-counts {
  grid-template-columns: max-content 1fr !important;
}

.kozaru-student-app .kozaru-my-details-form-snapshot,
.kozaru-student-app .kozaru-my-details-submission-list {
  display: grid !important;
  gap: .6rem !important;
  margin: .85rem 0 0 !important;
  padding: 0 !important;
}

.kozaru-student-app .kozaru-my-details-form-snapshot li,
.kozaru-student-app .kozaru-my-details-submission-list li {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: .7rem !important;
  padding: .7rem .75rem !important;
  border-radius: 12px !important;
  border: 1px solid rgba(15,23,42,.08) !important;
  background: #fbfcfe !important;
  min-width: 0 !important;
}

.kozaru-student-app .kozaru-my-details-form-snapshot li strong,
.kozaru-student-app .kozaru-my-details-submission-list li strong {
  display: block !important;
  min-width: 0 !important;
  font-size: .92rem !important;
  line-height: 1.15 !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}

.kozaru-student-app .kozaru-frontend-reason-list {
  margin: .85rem 0 0 !important;
  padding-left: 1rem !important;
  color: #475467 !important;
  font-size: .9rem !important;
  line-height: 1.45 !important;
}

.kozaru-student-app .kozaru-my-forms .kozaru-command-card,
.kozaru-student-app .kozaru-my-bookings .kozaru-command-card {
  padding: .85rem !important;
}

.kozaru-student-app .kozaru-forms-status-list,
.kozaru-student-app .kozaru-command-booking-list {
  display: grid !important;
  gap: .7rem !important;
}

.kozaru-student-app .kozaru-form-status-item,
.kozaru-student-app .kozaru-command-booking-item {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto auto !important;
  gap: .8rem !important;
  align-items: center !important;
  padding: .8rem .95rem !important;
  border-radius: 14px !important;
  border: 1px solid rgba(15,23,42,.08) !important;
  background: #fff !important;
  min-width: 0 !important;
}

.kozaru-student-app .kozaru-command-item-main,
.kozaru-student-app .kozaru-form-status-item > div:first-child {
  min-width: 0 !important;
}

.kozaru-student-app .kozaru-form-status-item strong,
.kozaru-student-app .kozaru-command-booking-item strong,
.kozaru-student-app .kozaru-command-item-title {
  display: block !important;
  font-size: 1rem !important;
  line-height: 1.2 !important;
  color: #111827 !important;
  min-width: 0 !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
}

.kozaru-student-app .kozaru-form-status-item small,
.kozaru-student-app .kozaru-command-booking-item small {
  display: block !important;
  margin-top: .18rem !important;
  color: #667085 !important;
  font-size: .82rem !important;
  line-height: 1.35 !important;
  white-space: normal !important;
}

.kozaru-student-app .kozaru-form-status-item .kozaru-status,
.kozaru-student-app .kozaru-command-booking-item .kozaru-status {
  justify-self: end !important;
  white-space: nowrap !important;
}

.kozaru-student-app .kozaru-command-list-actions {
  display: flex !important;
  gap: .45rem !important;
  align-items: center !important;
  justify-content: flex-end !important;
  min-width: max-content !important;
}

.kozaru-student-app .kozaru-command-list-actions .kozaru-button,
.kozaru-student-app .kozaru-command-booking-item .kozaru-status {
  min-height: 2.15rem !important;
  padding: .48rem .8rem !important;
  border-radius: 10px !important;
  font-size: .84rem !important;
}

.kozaru-student-app .kozaru-form-danger-action .kozaru-button-danger {
  background: #fff !important;
  color: #b42318 !important;
  border: 1px solid rgba(180,35,24,.35) !important;
  box-shadow: none !important;
}

.kozaru-student-app .kozaru-form-danger-action .kozaru-button-danger:hover,
.kozaru-student-app .kozaru-form-danger-action .kozaru-button-danger:focus {
  background: #fff4f2 !important;
}

.kozaru-student-app .kozaru-command-empty,
.kozaru-student-app .kozaru-student-large-empty {
  border: 1px dashed rgba(15,23,42,.16) !important;
  border-radius: 14px !important;
  background: #fbfcfe !important;
  padding: 1rem !important;
  color: #667085 !important;
  font-weight: 700 !important;
}

@media (max-width: 1100px) {
  .kozaru-student-app .kozaru-my-details-grid { grid-template-columns: 1fr !important; }
  .kozaru-student-app .kozaru-form-status-item,
  .kozaru-student-app .kozaru-command-booking-item { grid-template-columns: minmax(0, 1fr) auto !important; }
  .kozaru-student-app .kozaru-command-list-actions { grid-column: 1 / -1 !important; justify-content: flex-start !important; }
}

@media (max-width: 760px) {
  .kozaru-student-app .kozaru-my-details-hero,
  .kozaru-student-app .kozaru-my-preferred-class-summary,
  .kozaru-student-app .kozaru-preferred-class-form,
  .kozaru-student-app .kozaru-form-status-item,
  .kozaru-student-app .kozaru-command-booking-item {
    grid-template-columns: 1fr !important;
  }
  .kozaru-student-app .kozaru-my-details-primary-meta dd,
  .kozaru-student-app .kozaru-compact-meta dd { text-align: left !important; }
  .kozaru-student-app .kozaru-my-details-primary-meta,
  .kozaru-student-app .kozaru-compact-meta { grid-template-columns: 1fr auto !important; }
  .kozaru-student-app .kozaru-form-status-item .kozaru-status,
  .kozaru-student-app .kozaru-command-booking-item .kozaru-status { justify-self: start !important; }
}


/* v1.0.143: student portal navigation, mobile, and front-facing finish pass. */
.kozaru-student-shell,
.kozaru-student-dashboard,
.kozaru-student-app,
.kozaru-student-portal,
.kozaru-portal-student,
.kozaru-student-interface {
  --kozaru-student-gap: clamp(12px, 2vw, 20px);
  --kozaru-student-pad: clamp(14px, 2vw, 24px);
  --kozaru-student-card-radius: 18px;
}

.kozaru-student-shell .kozaru-student-content,
.kozaru-student-dashboard .kozaru-student-content,
.kozaru-student-app .kozaru-student-content,
.kozaru-student-portal .kozaru-student-content,
.kozaru-student-interface main,
.kozaru-student-interface .kozaru-dashboard-content {
  max-width: 1180px;
  margin-inline: auto;
  width: min(100%, 1180px);
}

.kozaru-student-shell .kozaru-frontend-card,
.kozaru-student-dashboard .kozaru-frontend-card,
.kozaru-student-app .kozaru-frontend-card,
.kozaru-student-portal .kozaru-frontend-card,
.kozaru-student-interface .kozaru-frontend-card,
.kozaru-student-shell .kozaru-command-card,
.kozaru-student-dashboard .kozaru-command-card,
.kozaru-student-app .kozaru-command-card,
.kozaru-student-portal .kozaru-command-card {
  border-radius: var(--kozaru-student-card-radius) !important;
  padding: var(--kozaru-student-pad) !important;
  box-shadow: 0 14px 42px rgba(15,23,42,.055) !important;
}

.kozaru-student-shell h1,
.kozaru-student-dashboard h1,
.kozaru-student-app h1,
.kozaru-student-portal h1,
.kozaru-student-interface h1 {
  font-size: clamp(2.2rem, 4vw, 4.4rem) !important;
  line-height: .94 !important;
  letter-spacing: -.07em !important;
  margin: 0 0 clamp(16px, 2vw, 28px) !important;
}

.kozaru-student-shell h2,
.kozaru-student-dashboard h2,
.kozaru-student-app h2,
.kozaru-student-portal h2,
.kozaru-student-interface h2 {
  font-size: clamp(1.4rem, 2.1vw, 2rem) !important;
  line-height: 1.05 !important;
  margin: 0 0 .75rem !important;
}

.kozaru-student-shell h3,
.kozaru-student-dashboard h3,
.kozaru-student-app h3,
.kozaru-student-portal h3,
.kozaru-student-interface h3 {
  line-height: 1.08 !important;
  text-wrap: balance;
}

.kozaru-student-shell p,
.kozaru-student-dashboard p,
.kozaru-student-app p,
.kozaru-student-portal p,
.kozaru-student-interface p,
.kozaru-student-shell li,
.kozaru-student-dashboard li,
.kozaru-student-app li,
.kozaru-student-portal li,
.kozaru-student-interface li {
  max-width: 72ch;
}

.kozaru-student-shell .kozaru-helper,
.kozaru-student-dashboard .kozaru-helper,
.kozaru-student-app .kozaru-helper,
.kozaru-student-portal .kozaru-helper,
.kozaru-student-interface .kozaru-helper,
.kozaru-student-shell .kozaru-muted-helper,
.kozaru-student-dashboard .kozaru-muted-helper,
.kozaru-student-app .kozaru-muted-helper,
.kozaru-student-portal .kozaru-muted-helper {
  display: none !important;
}

/* Profile cards: equal height without the weird empty-column mansion effect. */
.kozaru-student-profile-grid,
.kozaru-my-details-summary-grid,
.kozaru-profile-summary-grid,
.kozaru-student-account-summary-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
  gap: var(--kozaru-student-gap) !important;
  align-items: start !important;
}

.kozaru-student-profile-grid > *,
.kozaru-my-details-summary-grid > *,
.kozaru-profile-summary-grid > *,
.kozaru-student-account-summary-grid > * {
  min-width: 0 !important;
  height: auto !important;
  min-height: 0 !important;
}

.kozaru-student-profile-grid .kozaru-frontend-card,
.kozaru-my-details-summary-grid .kozaru-frontend-card,
.kozaru-profile-summary-grid .kozaru-frontend-card,
.kozaru-student-account-summary-grid .kozaru-frontend-card {
  min-height: 0 !important;
}

/* Forms / waivers: compact, no title/date/status collisions. */
.kozaru-forms-list,
.kozaru-student-forms-list,
.kozaru-waiver-list {
  display: grid !important;
  gap: 10px !important;
}

.kozaru-form-row,
.kozaru-student-form-row,
.kozaru-waiver-row,
.kozaru-profile-form-card {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto auto !important;
  gap: 12px !important;
  align-items: center !important;
  padding: 14px 16px !important;
  min-width: 0 !important;
}

.kozaru-form-row h3,
.kozaru-student-form-row h3,
.kozaru-waiver-row h3,
.kozaru-profile-form-card h3,
.kozaru-profile-form-card strong {
  min-width: 0 !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  white-space: normal !important;
  line-height: 1.15 !important;
}

.kozaru-form-row .kozaru-pill,
.kozaru-student-form-row .kozaru-pill,
.kozaru-waiver-row .kozaru-pill,
.kozaru-profile-form-card .kozaru-pill,
.kozaru-profile-form-card .kozaru-status-pill {
  justify-self: end !important;
  white-space: nowrap !important;
}

.kozaru-form-row time,
.kozaru-student-form-row time,
.kozaru-waiver-row time,
.kozaru-profile-form-card time,
.kozaru-profile-form-card small {
  color: #64748b !important;
  font-size: .84rem !important;
  white-space: normal !important;
}

/* Training Plan / Event Bookings / Schedule: separate lanes, one visual grammar. */
.kozaru-training-plan-shell,
.kozaru-registration-workspace,
.kozaru-student-registration-panel,
.kozaru-student-bookings-page,
.kozaru-calendar-page {
  max-width: 1180px !important;
  margin-inline: auto !important;
}

.kozaru-training-plan-row,
.kozaru-registration-session-row,
.kozaru-booking-row,
.kozaru-calendar-session-row,
.kozaru-calendar-class-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 12px !important;
  align-items: center !important;
  padding: 14px 16px !important;
  min-width: 0 !important;
}

.kozaru-training-plan-row .kozaru-button,
.kozaru-registration-session-row .kozaru-button,
.kozaru-booking-row .kozaru-button,
.kozaru-calendar-session-row .kozaru-button,
.kozaru-calendar-class-row .kozaru-button,
.kozaru-training-plan-row button,
.kozaru-registration-session-row button,
.kozaru-booking-row button,
.kozaru-calendar-session-row button,
.kozaru-calendar-class-row button {
  justify-self: end !important;
  white-space: nowrap !important;
  max-width: 100% !important;
}

.kozaru-calendar-filter-card,
.kozaru-schedule-filter-card {
  padding: 14px 16px !important;
  margin-bottom: 14px !important;
}

.kozaru-calendar-day-card,
.kozaru-schedule-day-card {
  overflow: hidden !important;
}

/* Grading: student-facing language/layout, no internal goblin phrasing. */
.kozaru-grading-readiness-card .kozaru-internal-warning,
.kozaru-grading-progress .kozaru-internal-warning,
.kozaru-grading-progress [class*="external"] p:not(.kozaru-command-eyebrow) {
  max-width: 100% !important;
}

.kozaru-grading-progress .kozaru-check-panel,
.kozaru-grading-progress .kozaru-readiness-panel,
.kozaru-grading-progress .kozaru-frontend-card {
  min-height: 0 !important;
}

@media (max-width: 780px) {
  .kozaru-student-shell,
  .kozaru-student-dashboard,
  .kozaru-student-app,
  .kozaru-student-portal,
  .kozaru-student-interface {
    --kozaru-student-gap: 10px;
    --kozaru-student-pad: 14px;
  }

  .kozaru-student-shell .kozaru-student-content,
  .kozaru-student-dashboard .kozaru-student-content,
  .kozaru-student-app .kozaru-student-content,
  .kozaru-student-portal .kozaru-student-content,
  .kozaru-student-interface main,
  .kozaru-student-interface .kozaru-dashboard-content {
    width: 100% !important;
    padding-inline: 10px !important;
  }

  .kozaru-student-shell h1,
  .kozaru-student-dashboard h1,
  .kozaru-student-app h1,
  .kozaru-student-portal h1,
  .kozaru-student-interface h1 {
    font-size: clamp(2rem, 12vw, 3.2rem) !important;
    letter-spacing: -.06em !important;
  }

  .kozaru-student-profile-grid,
  .kozaru-my-details-summary-grid,
  .kozaru-profile-summary-grid,
  .kozaru-student-account-summary-grid {
    grid-template-columns: 1fr !important;
  }

  .kozaru-form-row,
  .kozaru-student-form-row,
  .kozaru-waiver-row,
  .kozaru-profile-form-card,
  .kozaru-training-plan-row,
  .kozaru-registration-session-row,
  .kozaru-booking-row,
  .kozaru-calendar-session-row,
  .kozaru-calendar-class-row {
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
    gap: 10px !important;
  }

  .kozaru-form-row .kozaru-pill,
  .kozaru-student-form-row .kozaru-pill,
  .kozaru-waiver-row .kozaru-pill,
  .kozaru-profile-form-card .kozaru-pill,
  .kozaru-profile-form-card .kozaru-status-pill,
  .kozaru-training-plan-row .kozaru-button,
  .kozaru-registration-session-row .kozaru-button,
  .kozaru-booking-row .kozaru-button,
  .kozaru-calendar-session-row .kozaru-button,
  .kozaru-calendar-class-row .kozaru-button,
  .kozaru-training-plan-row button,
  .kozaru-registration-session-row button,
  .kozaru-booking-row button,
  .kozaru-calendar-session-row button,
  .kozaru-calendar-class-row button {
    justify-self: start !important;
    width: 100% !important;
  }

  .kozaru-student-sidebar,
  .kozaru-student-nav,
  .kozaru-student-dashboard-nav {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
}

/* v1.0.152 - compact attendance kiosk cards and credit badges. */
.kozaru-attendance-simple-kiosk .kozaru-kiosk-photo-button{
	min-height:0;
	padding:.65rem .7rem;
	gap:.35rem;
	box-shadow:none;
}
.kozaru-attendance-simple-kiosk .kozaru-kiosk-photo-frame{
	width:4.25rem;
	height:4.25rem;
}
.kozaru-attendance-simple-kiosk .kozaru-kiosk-checkin-meta{
	display:flex;
	flex-wrap:wrap;
	gap:.22rem .35rem;
	align-items:center;
	justify-content:center;
	line-height:1.1;
}
.kozaru-attendance-simple-kiosk .kozaru-class-credit-badge{
	font-size:.7rem;
	line-height:1;
	padding:.18rem .45rem;
	border-radius:999px;
	white-space:nowrap;
}
.kozaru-attendance-simple-kiosk .kozaru-kiosk-pin-hint{
	font-size:.7rem;
	line-height:1;
	padding:.18rem .45rem;
}
.kozaru-attendance-simple-kiosk .kozaru-kiosk-photo-button > strong{
	margin-top:.1rem;
	padding:.22rem .65rem;
	border-radius:999px;
	line-height:1;
}
@media(max-width:900px){
	.kozaru-attendance-simple-kiosk{
		padding:.7rem!important;
		border-radius:1rem!important;
	}
	.kozaru-attendance-simple-kiosk .kozaru-attendance-kiosk-header,
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-live-summary,
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-list-heading,
	.kozaru-attendance-simple-kiosk .kozaru-attendance-sync-note{
		display:none!important;
	}
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-layout{
		display:block!important;
		gap:0!important;
	}
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-main-list{
		padding:0!important;
		background:transparent!important;
		box-shadow:none!important;
	}
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-pending-list{
		display:grid!important;
		grid-template-columns:repeat(2,minmax(0,1fr))!important;
		gap:.55rem!important;
	}
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-photo-button{
		min-height:0!important;
		padding:.6rem .45rem!important;
		border-radius:.9rem!important;
		border-left:4px solid var(--kozaru-category-colour,#2271b1)!important;
	}
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-photo-frame{
		width:3.8rem!important;
		height:3.8rem!important;
	}
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-checkin-name{
		font-size:.92rem!important;
		line-height:1.05!important;
		margin:0!important;
	}
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-checkin-meta{
		font-size:.66rem!important;
		gap:.18rem .25rem!important;
	}
	.kozaru-attendance-simple-kiosk .kozaru-roster-badge,
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-checkin-meta span:not(.kozaru-class-credit-badge):not(.kozaru-kiosk-pin-hint){
		font-size:.65rem!important;
	}
	.kozaru-attendance-simple-kiosk .kozaru-class-credit-badge{
		max-width:100%;
		overflow:hidden;
		text-overflow:ellipsis;
	}
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-checked-sidebar{
		position:static!important;
		max-height:none!important;
		margin-top:.65rem!important;
		padding:.55rem!important;
	}
}
@media(max-width:390px){
	.kozaru-attendance-simple-kiosk .kozaru-kiosk-pending-list{
		grid-template-columns:1fr!important;
	}
}
