/**
 * Unalome Control - Public Styles
 * Void UI System compliant
 *
 * @package UnalomeControl
 */

/* ─── Custom Properties ─────────────────────────────────── */

:root {
	--uc-void:         #121212;
	--uc-canvas:       #181818;
	--uc-surface:      #1A1A1A;
	--uc-panel:        #1E1E1E;
	--uc-hover:        #242424;
	--uc-light:        #EDEDED;
	--uc-muted:        #BFBFBF;
	--uc-teal:         #44D8CC;
	--uc-red:          #E32817;
	--uc-border-dim:   #2A2A2A;
	--uc-border-mid:   #3A3A3A;
	--uc-border-input: #6B6B6B;
	--uc-border-focus: #E8E8E8;
	--uc-mono:         'JetBrains Mono', monospace;
	--uc-serif:        'Source Serif 4', serif;
	--uc-heading:      'Gloock', serif;
}

/* ─── Base Reset (scoped to UC) ─────────────────────────── */

.uc-account-wrap *,
.uc-dashboard-wrap *,
.uc-password-setup-wrap *,
.uc-preview-banner * {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

/* ─── Account Shortcode [up_my_account] ─────────────────── */

.uc-account-wrap {
	background: var(--uc-void);
	color: var(--uc-light);
	font-family: var(--uc-serif);
	font-weight: 300;
	padding: 2rem 0;
}

.uc-account-name {
	font-family: var(--uc-heading);
	font-size: 2.2rem;
	color: var(--uc-light);
	margin-bottom: 0.25rem;
}

.uc-account-email {
	font-family: var(--uc-mono);
	font-size: 0.75rem;
	color: var(--uc-muted);
	margin-bottom: 0.5rem;
}

.uc-account-since {
	font-family: var(--uc-mono);
	font-size: 0.65rem;
	color: var(--uc-muted);
	margin-bottom: 2rem;
}

.uc-account-enrollments {
	border-top: 0.5px solid var(--uc-border-dim);
	padding-top: 1.5rem;
	margin-top: 1.5rem;
}

.uc-account-enrollment-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.75rem 0;
	border-bottom: 0.5px solid var(--uc-border-dim);
}

.uc-account-enrollment-label {
	font-family: var(--uc-serif);
	font-weight: 300;
	font-size: 1rem;
	color: var(--uc-light);
}

.uc-account-enrollment-status {
	font-family: var(--uc-mono);
	font-size: 0.65rem;
	color: var(--uc-teal);
}

.uc-account-password-link {
	display: inline-block;
	margin-top: 2rem;
	font-family: var(--uc-mono);
	font-size: 0.7rem;
	color: var(--uc-muted);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.uc-account-password-link:hover {
	color: var(--uc-light);
}

/* ─── Dashboard Shortcode [up_my_dashboard] ─────────────── */

.uc-dashboard-wrap {
	background: var(--uc-void);
	color: var(--uc-light);
	font-family: var(--uc-serif);
	font-weight: 300;
	padding: 2rem 0;
}

.uc-dashboard-title {
	font-family: var(--uc-heading);
	font-size: 2.2rem;
	color: var(--uc-light);
	margin-bottom: 2rem;
}

/* ─── Enrollment Card ────────────────────────────────────── */

.uc-enrollment-card {
	background: var(--uc-void);
	border: 0.5px solid var(--uc-border-dim);
	padding: 1.5rem;
	margin-bottom: 1.5rem;
}

.uc-enrollment-card-product {
	font-family: var(--uc-heading);
	font-size: 1.4rem;
	color: var(--uc-light);
	margin-bottom: 0.25rem;
}

.uc-enrollment-card-cohort {
	font-family: var(--uc-mono);
	font-size: 0.65rem;
	color: var(--uc-muted);
	margin-bottom: 1rem;
}

.uc-enrollment-card-meta {
	font-family: var(--uc-mono);
	font-size: 0.65rem;
	color: var(--uc-muted);
	margin-bottom: 0.4rem;
}

.uc-enrollment-card-meta span {
	color: var(--uc-light);
}

.uc-enrollment-card-link {
	display: inline-block;
	margin-top: 1.25rem;
	font-family: var(--uc-mono);
	font-size: 0.7rem;
	color: var(--uc-teal);
	text-decoration: none;
	border-bottom: 0.5px solid var(--uc-teal);
	padding-bottom: 1px;
}

.uc-enrollment-card-link:hover {
	opacity: 0.75;
}

/* ─── Progress Bar [up_progress_bar] ────────────────────── */

.uc-progress-bar-wrap {
	margin: 1rem 0;
}

.uc-progress-label {
	font-family: var(--uc-mono);
	font-size: 0.65rem;
	color: var(--uc-muted);
	margin-bottom: 0.4rem;
	display: block;
}

.uc-progress-bar-track-outer {
	background: var(--uc-border-dim);
	height: 0.5px;
	width: 100%;
	position: relative;
}

.uc-progress-bar-track {
	background: var(--uc-teal);
	height: 0.5px;
	position: absolute;
	top: 0;
	left: 0;
	transition: width 0.4s ease;
}

/* ─── Session Unlock Date [up_session_unlock_date] ──────── */

.uc-unlock-date {
	font-family: var(--uc-mono);
	font-size: 0.65rem;
	color: var(--uc-muted);
	display: block;
	margin: 0.5rem 0;
}

.uc-unlock-date-value {
	color: var(--uc-light);
}

/* ─── Access Issue [up_access_issue] ────────────────────── */

.uc-access-issue {
	background: var(--uc-void);
	border-left: 2px solid var(--uc-red);
	padding: 1rem 1.25rem;
	margin: 1rem 0;
	font-family: var(--uc-serif);
	font-weight: 300;
	font-size: 0.9rem;
	color: var(--uc-light);
}

.uc-access-issue-label {
	font-family: var(--uc-mono);
	font-size: 0.6rem;
	color: var(--uc-red);
	display: block;
	margin-bottom: 0.4rem;
}

/* ─── Empty State ────────────────────────────────────────── */

.uc-empty-state {
	font-family: var(--uc-serif);
	font-weight: 300;
	font-size: 1rem;
	color: var(--uc-muted);
	padding: 2rem 0;
}

/* ─── Password Setup Form ────────────────────────────────── */

.uc-password-setup-wrap {
	background: var(--uc-void);
	color: var(--uc-light);
	font-family: var(--uc-serif);
	font-weight: 300;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	padding: 4rem 2rem;
	max-width: 480px;
	margin: 0 auto;
}

.uc-password-setup-title {
	font-family: var(--uc-heading);
	font-size: 2.2rem;
	color: var(--uc-light);
	margin-bottom: 2rem;
}

.uc-password-setup-field {
	width: 100%;
	margin-bottom: 1.5rem;
}

.uc-password-setup-label {
	font-family: var(--uc-mono);
	font-size: 0.65rem;
	color: var(--uc-muted);
	display: block;
	margin-bottom: 0.5rem;
}

.uc-password-setup-input {
	background: transparent;
	border: none;
	border-bottom: 0.5px solid var(--uc-border-dim);
	color: var(--uc-light);
	font-family: var(--uc-serif);
	font-weight: 300;
	font-size: 1rem;
	width: 100%;
	padding: 0.5rem 0;
	outline: none;
}

.uc-password-setup-input:focus {
	border-bottom-color: var(--uc-teal);
}

.uc-password-setup-input::placeholder {
	color: var(--uc-muted);
}

.uc-password-setup-error {
	font-family: var(--uc-mono);
	font-size: 0.65rem;
	color: var(--uc-red);
	display: block;
	margin-top: 0.4rem;
}

/* ─── Begin Button (press-and-hold) ─────────────────────── */

.uc-btn-begin {
	background: none;
	border: none;
	color: var(--uc-teal);
	font-family: var(--uc-mono);
	font-size: 0.75rem;
	cursor: pointer;
	padding: 0;
	margin-top: 2rem;
	position: relative;
	overflow: hidden;
	display: inline-block;
}

.uc-btn-begin::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	height: 1px;
	width: 0;
	background: var(--uc-teal);
	transition: none;
}

.uc-btn-begin.uc-holding::after {
	width: 100%;
	transition: width 2s linear;
}

.uc-btn-begin:focus {
	outline: none;
}

/* ─── Token Expired / Invalid ───────────────────────────── */

.uc-token-error-wrap {
	background: var(--uc-void);
	color: var(--uc-light);
	font-family: var(--uc-serif);
	font-weight: 300;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 4rem 2rem;
	max-width: 480px;
	margin: 0 auto;
}

.uc-token-error-message {
	font-size: 1rem;
	color: var(--uc-light);
	margin-bottom: 1.5rem;
}

.uc-token-error-link {
	font-family: var(--uc-mono);
	font-size: 0.7rem;
	color: var(--uc-muted);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.uc-token-error-link:hover {
	color: var(--uc-light);
}

/* ─── View as Student Preview Banner ────────────────────── */

.uc-preview-banner {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	background: var(--uc-teal);
	color: var(--uc-void);
	font-family: var(--uc-mono);
	font-size: 0.7rem;
	padding: 0.5rem 1.5rem;
	z-index: 99999;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.uc-preview-banner-countdown {
	font-family: var(--uc-mono);
	font-size: 0.7rem;
	color: var(--uc-void);
}

.uc-preview-banner-close {
	font-family: var(--uc-mono);
	font-size: 0.65rem;
	color: var(--uc-void);
	background: none;
	border: none;
	cursor: pointer;
	text-decoration: underline;
	text-underline-offset: 3px;
	padding: 0;
}
