/* SCI Webinar - Public Front-end Styling
   Brand palette: #E87722 (orange), #1F4E79 (navy), #000000, #FFFFFF */

:root {
	--sci-navy: #1F4E79;
	--sci-navy-deep: #163a5c;
	--sci-orange: #E87722; /* exact match to the reference button image */
	--sci-orange-dark: #ae5919; /* 75% brightness of the reference orange - passes 4.95:1 with white text, the reference orange alone only reaches 2.96:1 */
	--sci-orange-text-on-tint: #a25317; /* 70% brightness - passes 4.73:1 on the 15%-opacity orange tint backgrounds used for badges/pills */
	--sci-paper: #ffffff;
	--sci-paper-dim: #f4f6f8;
	--sci-sage: #2e7d52;
	--sci-ink: #000000;
	--sci-ink-soft: #4a4a4a;
	--sci-line: #dfe3e8;
	--sci-error: #b3432e;
	--sci-radius: 3px;
	--sci-font-display: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--sci-font-body: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--sci-font-mono: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.sciwebinar-app-root * {
	box-sizing: border-box;
	min-width: 0; /* Prevents flex/grid children from refusing to shrink
	                 below their content's natural width (e.g. a long
	                 unbroken URL or email address), which is the most
	                 common cause of whole-page horizontal scroll on
	                 mobile even when every individual rule looks
	                 "responsive" in isolation. */
}

.sciwebinar-app-root {
	max-width: 100%;
	overflow-x: hidden;
}

.sciwebinar-app-root a, .sciwebinar-app-root p, .sciwebinar-app-root div, .sciwebinar-app-root span, .sciwebinar-app-root td, .sciwebinar-app-root th, .sciwebinar-app-root li {
	overflow-wrap: break-word;
	word-wrap: break-word;
}

.sciwebinar-app-root {
	font-family: var(--sci-font-body);
	color: var(--sci-ink);
	background: var(--sci-paper);
	min-height: 100vh;
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
}

.sciwebinar-app-root a {
	color: var(--sci-navy);
}

.sciwebinar-app-root .sci-topbar {
	background: var(--sci-navy);
	color: #ffffff;
	padding: 18px 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-bottom: 3px solid var(--sci-orange);
	flex-wrap: wrap;
	gap: 10px;
}

@media (max-width: 640px) {
	.sciwebinar-app-root .sci-topbar {
		padding: 14px 16px;
	}

	.sciwebinar-app-root .sci-topbar-nav {
		order: 3;
		width: 100%;
		flex-wrap: wrap;
		gap: 12px;
	}

	.sciwebinar-app-root .sci-topbar-user {
		font-size: 12px;
	}
}

.sciwebinar-app-root .sci-topbar-brand {
	font-family: var(--sci-font-display);
	font-size: 19px;
}

.sciwebinar-app-root .sci-topbar-brand .sci-tag {
	display: inline-block;
	font-family: var(--sci-font-mono);
	font-size: 11px;
	color: var(--sci-orange);
	border: 1px solid var(--sci-orange);
	border-radius: var(--sci-radius);
	padding: 1px 6px;
	margin-left: 8px;
	vertical-align: middle;
	letter-spacing: 0.04em;
}

.sciwebinar-app-root .sci-topbar-nav {
	display: flex;
	gap: 18px;
	font-size: 14px;
}

.sciwebinar-app-root .sci-topbar-nav a {
	color: rgba(255, 255, 255, 0.75);
	text-decoration: none;
	padding-bottom: 3px;
	border-bottom: 2px solid transparent;
}

.sciwebinar-app-root .sci-topbar-nav a:hover, .sciwebinar-app-root .sci-topbar-nav a.active {
	color: #ffffff;
	border-bottom-color: var(--sci-orange);
}

.sciwebinar-app-root .sci-topbar-user {
	font-size: 13px;
	color: rgba(255, 255, 255, 0.7);
}

.sciwebinar-app-root .sci-topbar-user a {
	color: var(--sci-orange);
	text-decoration: none;
	margin-left: 10px;
}

.sciwebinar-app-root .sci-shell {
	max-width: 680px;
	margin: 0 auto;
	padding: 48px 24px 80px;
}

.sciwebinar-app-root .sci-shell-wide {
	max-width: 1080px;
}

.sciwebinar-app-root .sci-eyebrow {
	font-family: var(--sci-font-mono);
	font-size: 12px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--sci-orange-dark);
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	gap: 8px;
}

/* Reusable wrapper for centering a page's intro header block (eyebrow +
   h1 + event meta row + subtext) as a unit, consistently across screen
   sizes - rather than centering each element ad hoc on individual pages. */
.sciwebinar-app-root .sci-header-centered {
	text-align: center;
}

.sciwebinar-app-root .sci-header-centered .sci-eyebrow {
	justify-content: center;
}

.sciwebinar-app-root .sci-header-centered .sci-event-meta {
	justify-content: center;
	text-align: center;
}

.sciwebinar-app-root .sci-header-centered .sci-sub {
	margin-left: auto;
	margin-right: auto;
}

.sciwebinar-app-root .sci-eyebrow::before {
	content: '[';
	color: var(--sci-navy);
}

.sciwebinar-app-root .sci-eyebrow::after {
	content: ']';
	color: var(--sci-navy);
}

.sciwebinar-app-root h1.sci-h1 {
	font-family: var(--sci-font-display);
	font-size: 34px;
	font-weight: 700;
	color: var(--sci-navy);
	margin: 0 0 12px;
	line-height: 1.15;
}

.sciwebinar-app-root .sci-sub {
	color: var(--sci-ink-soft);
	font-size: 16px;
	margin-bottom: 30px;
	max-width: 540px;
}

.sciwebinar-app-root .sci-card {
	background: #ffffff;
	border: 1px solid var(--sci-line);
	border-radius: var(--sci-radius);
	padding: 30px;
}

.sciwebinar-app-root .sci-section-title {
	font-family: var(--sci-font-mono);
	font-size: 13px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--sci-navy);
	border-bottom: 2px solid var(--sci-orange);
	padding-bottom: 8px;
	margin: 0 0 18px;
}

.sciwebinar-app-root .sci-field {
	margin-bottom: 20px;
}

.sciwebinar-app-root .sci-field-label {
	display: flex;
	align-items: baseline;
	gap: 8px;
	font-size: 14px;
	font-weight: 700;
	color: var(--sci-navy);
	margin-bottom: 7px;
}

.sciwebinar-app-root .sci-field-optional {
	font-size: 12px;
	font-weight: 400;
	color: var(--sci-ink-soft);
}

.sciwebinar-app-root .sci-field-required {
	color: var(--sci-error);
	font-weight: 700;
}

.sciwebinar-app-root .sci-field-tag {
	font-family: var(--sci-font-mono);
	font-size: 10px;
	color: var(--sci-orange-text-on-tint);
	background: rgba(232, 119, 34, 0.1);
	padding: 1px 5px;
	border-radius: 2px;
}

.sciwebinar-app-root .sci-field input[type="text"], .sciwebinar-app-root .sci-field input[type="email"], .sciwebinar-app-root .sci-field input[type="tel"], .sciwebinar-app-root .sci-field input[type="url"], .sciwebinar-app-root .sci-field input[type="password"], .sciwebinar-app-root .sci-field select, .sciwebinar-app-root .sci-field textarea {
	width: 100%;
	padding: 11px 13px;
	border: 1.5px solid var(--sci-line);
	border-radius: var(--sci-radius);
	font-size: 15px;
	font-family: var(--sci-font-body);
	color: var(--sci-ink);
	background: var(--sci-paper-dim);
}

.sciwebinar-app-root .sci-field input:focus, .sciwebinar-app-root .sci-field select:focus, .sciwebinar-app-root .sci-field textarea:focus {
	outline: none;
	border-color: var(--sci-navy);
	background: #ffffff;
}

.sciwebinar-app-root .sci-field-hint {
	font-size: 12px;
	color: var(--sci-ink-soft);
	margin-top: 5px;
}

.sciwebinar-app-root .sci-radio-group {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}

@media (max-width: 540px) {
	.sciwebinar-app-root .sci-radio-group {
		grid-template-columns: 1fr;
	}
}

.sciwebinar-app-root .sci-radio-option {
	border: 1.5px solid var(--sci-line);
	border-radius: var(--sci-radius);
	padding: 16px;
	cursor: pointer;
	position: relative;
}

.sciwebinar-app-root .sci-radio-option:hover {
	border-color: var(--sci-orange);
}

.sciwebinar-app-root .sci-radio-option input[type="radio"] {
	position: absolute;
	top: 16px;
	right: 16px;
	accent-color: var(--sci-orange-dark);
}

.sciwebinar-app-root .sci-radio-option.checked {
	border-color: var(--sci-navy);
	background: rgba(31, 78, 121, 0.04);
}

.sciwebinar-app-root .sci-radio-title {
	font-weight: 600;
	font-size: 15px;
	color: var(--sci-navy);
	margin-bottom: 3px;
}

.sciwebinar-app-root .sci-radio-price {
	font-family: var(--sci-font-mono);
	font-size: 14px;
	color: var(--sci-orange-dark);
}

.sciwebinar-app-root .sci-radio-desc {
	font-size: 13px;
	color: var(--sci-ink-soft);
	margin-top: 4px;
}

.sciwebinar-app-root .sci-payment-options {
	display: grid;
	gap: 10px;
}

.sciwebinar-app-root .sci-payment-option {
	border: 1.5px solid var(--sci-line);
	border-radius: var(--sci-radius);
	padding: 14px 16px;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 12px;
}

.sciwebinar-app-root .sci-payment-option:hover {
	border-color: var(--sci-orange);
}

.sciwebinar-app-root .sci-payment-option.checked {
	border-color: var(--sci-navy);
	background: rgba(31, 78, 121, 0.04);
}

.sciwebinar-app-root .sci-payment-option input[type="radio"] {
	accent-color: var(--sci-orange-dark);
}

.sciwebinar-app-root .sci-payment-label {
	font-weight: 600;
	font-size: 14px;
	color: var(--sci-navy);
}

.sciwebinar-app-root .sci-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: var(--sci-navy);
	color: #ffffff;
	border: none;
	border-radius: var(--sci-radius);
	padding: 14px 28px;
	font-size: 15px;
	font-weight: 600;
	font-family: var(--sci-font-body);
	cursor: pointer;
	text-decoration: none;
	width: 100%;
}

/* .sciwebinar-app-root a (a descendant selector, specificity 0,2,0) is otherwise
   more specific than .sci-btn alone (0,1,0) and would override its
   white text color whenever a button is rendered as an <a> tag (e.g.
   Edit/Delete links styled as buttons) - this rule matches that same
   specificity level so .sci-btn's white text wins as intended. */
.sciwebinar-app-root a.sci-btn {
	color: #ffffff;
}

.sciwebinar-app-root .sci-btn:hover {
	background: var(--sci-navy-deep);
}

.sciwebinar-app-root .sci-btn-orange {
	/* Using --sci-orange-dark rather than --sci-orange here: the bright
	   brand orange (#E87722) only reaches a 2.96:1 contrast ratio with
	   white text, below the WCAG AA threshold (4.5:1) for normal-weight
	   text. The darker shade (#ae5919) passes at 4.95:1 while staying
	   visually on-brand - the bright orange is still used everywhere
	   else (badges, borders, accents) where it isn't carrying body text. */
	background: var(--sci-orange-dark);
}

.sciwebinar-app-root .sci-btn-orange:hover {
	background: #8b4714; /* 60% brightness of the reference orange, 6.98:1 contrast */
}

.sciwebinar-app-root .sci-form-footnote {
	text-align: center;
	font-size: 13px;
	color: var(--sci-ink-soft);
	margin-top: 18px;
}

.sciwebinar-app-root .sci-alert {
	border-radius: var(--sci-radius);
	padding: 14px 16px;
	font-size: 14px;
	margin-bottom: 22px;
	border-left: 3px solid;
}

.sciwebinar-app-root .sci-alert-error {
	background: rgba(179, 67, 46, 0.08);
	border-color: var(--sci-error);
	color: #7a2d1d;
}

.sciwebinar-app-root .sci-alert-success {
	background: rgba(46, 125, 82, 0.1);
	border-color: var(--sci-sage);
	color: #1d5138;
}

.sciwebinar-app-root .sci-alert ul {
	margin: 4px 0 0;
	padding-left: 18px;
}

.sciwebinar-app-root .sci-payment-details-box {
	background: var(--sci-paper-dim);
	border: 1px solid var(--sci-line);
	border-radius: var(--sci-radius);
	padding: 20px;
	margin: 16px 0;
	font-family: var(--sci-font-mono);
	font-size: 14px;
}

.sciwebinar-app-root .sci-payment-details-box .row {
	display: flex;
	justify-content: space-between;
	padding: 6px 0;
	border-bottom: 1px solid var(--sci-line);
}

.sciwebinar-app-root .sci-payment-details-box .row:last-child {
	border-bottom: none;
}

.sciwebinar-app-root .sci-payment-details-box .row strong {
	color: var(--sci-navy);
}

.sciwebinar-app-root .sci-confirm-icon {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: var(--sci-sage);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	margin-bottom: 20px;
}

.sciwebinar-app-root .sci-zoom-box {
	background: var(--sci-navy);
	color: #ffffff;
	border-radius: var(--sci-radius);
	padding: 26px;
	text-align: center;
	margin: 24px 0;
}

.sciwebinar-app-root .sci-zoom-box a {
	color: #ffffff;
}

.sciwebinar-app-root .sci-zoom-box .sci-zoom-label {
	font-family: var(--sci-font-mono);
	font-size: 12px;
	color: var(--sci-orange);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: 12px;
}

.sciwebinar-app-root .sci-speaker-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 18px;
	margin: 24px 0;
}

.sciwebinar-app-root .sci-speaker-card {
	background: #ffffff;
	border: 1px solid var(--sci-line);
	border-radius: var(--sci-radius);
	padding: 20px;
}

.sciwebinar-app-root .sci-speaker-card .sci-speaker-name {
	font-family: var(--sci-font-display);
	font-size: 17px;
	color: var(--sci-navy);
	margin-bottom: 3px;
}

.sciwebinar-app-root .sci-speaker-card .sci-speaker-role {
	font-size: 13px;
	color: var(--sci-orange-dark);
	font-family: var(--sci-font-mono);
}

.sciwebinar-app-root .sci-section-label {
	font-family: var(--sci-font-mono);
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--sci-ink-soft);
	margin: 36px 0 14px;
}

.sciwebinar-app-root .sci-register-heading {
	font-family: var(--sci-font-display);
	font-size: 22px;
	font-weight: 700;
	text-transform: none;
	letter-spacing: normal;
	color: var(--sci-navy);
	text-align: center;
	margin: 40px 0 18px;
}

@media (max-width: 600px) {
	.sciwebinar-app-root .sci-register-heading {
		font-size: 18px;
	}
}

.sciwebinar-app-root .sci-event-meta {
	display: flex;
	gap: 28px;
	flex-wrap: wrap;
	margin: 22px 0 8px;
	font-size: 14px;
	color: var(--sci-ink-soft);
}

.sciwebinar-app-root .sci-event-meta strong {
	color: var(--sci-navy);
	display: block;
	font-family: var(--sci-font-mono);
	font-size: 12px;
	text-transform: uppercase;
	margin-bottom: 3px;
}

.sciwebinar-app-root .sci-dash-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
	margin-bottom: 28px;
}

@media (max-width: 720px) {
	.sciwebinar-app-root .sci-dash-stats {
		grid-template-columns: repeat(2, 1fr);
	}
}

.sciwebinar-app-root .sci-stat {
	background: #ffffff;
	border: 1px solid var(--sci-line);
	border-radius: var(--sci-radius);
	padding: 18px 20px;
}

.sciwebinar-app-root .sci-stat-figure {
	font-family: var(--sci-font-display);
	font-size: 28px;
	color: var(--sci-navy);
	display: block;
}

.sciwebinar-app-root .sci-stat-caption {
	font-family: var(--sci-font-mono);
	font-size: 11px;
	text-transform: uppercase;
	color: var(--sci-ink-soft);
}

.sciwebinar-app-root .sci-table-wrap {
	background: #ffffff;
	border: 1px solid var(--sci-line);
	border-radius: var(--sci-radius);
	overflow-x: auto;
	max-width: 100%;
}

.sciwebinar-app-root table.sci-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}

.sciwebinar-app-root table.sci-table th {
	text-align: left;
	font-family: var(--sci-font-mono);
	font-size: 11px;
	text-transform: uppercase;
	color: var(--sci-ink-soft);
	background: var(--sci-paper-dim);
	padding: 12px 14px;
	border-bottom: 1px solid var(--sci-line);
	white-space: nowrap;
}

.sciwebinar-app-root table.sci-table td {
	padding: 12px 14px;
	border-bottom: 1px solid var(--sci-line);
	vertical-align: middle;
}

.sciwebinar-app-root table.sci-table tr:last-child td {
	border-bottom: none;
}

.sciwebinar-app-root .sci-badge {
	display: inline-block;
	font-family: var(--sci-font-mono);
	font-size: 11px;
	padding: 3px 9px;
	border-radius: 20px;
}

.sciwebinar-app-root .sci-badge-yes {
	background: rgba(46, 125, 82, 0.15);
	color: #1d5138;
}

.sciwebinar-app-root .sci-badge-no {
	background: var(--sci-paper-dim);
	color: var(--sci-ink-soft);
}

.sciwebinar-app-root .sci-badge-review {
	background: rgba(232, 119, 34, 0.15);
	color: var(--sci-orange-text-on-tint);
}

.sciwebinar-app-root .sci-toolbar {
	display: flex;
	gap: 10px;
	margin-bottom: 20px;
	flex-wrap: wrap;
}

.sciwebinar-app-root .sci-toolbar input[type="search"] {
	flex: 1;
	min-width: 220px;
	padding: 10px 14px;
	border: 1.5px solid var(--sci-line);
	border-radius: var(--sci-radius);
	font-size: 14px;
}

.sciwebinar-app-root .sci-btn-sm {
	width: auto;
	padding: 10px 18px;
	font-size: 14px;
}

.sciwebinar-app-root .sci-pagination {
	display: flex;
	gap: 6px;
	margin-top: 20px;
	font-family: var(--sci-font-mono);
	font-size: 13px;
}

.sciwebinar-app-root .sci-pagination a, .sciwebinar-app-root .sci-pagination span {
	padding: 6px 11px;
	border: 1px solid var(--sci-line);
	border-radius: var(--sci-radius);
	color: var(--sci-ink);
	text-decoration: none;
}

.sciwebinar-app-root .sci-pagination .current {
	background: var(--sci-navy);
	color: #fff;
	border-color: var(--sci-navy);
}

.sciwebinar-app-root .sci-calendar-grid {
	display: grid;
	gap: 14px;
}

.sciwebinar-app-root .sci-calendar-item {
	background: #ffffff;
	border: 1px solid var(--sci-line);
	border-left: 4px solid var(--sci-orange);
	border-radius: var(--sci-radius);
	padding: 18px 20px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px;
}

.sciwebinar-app-root .sci-calendar-item.status-draft {
	border-left-color: var(--sci-line);
	opacity: 0.7;
}

.sciwebinar-app-root .sci-calendar-item.status-ended {
	border-left-color: var(--sci-sage);
}

.sciwebinar-app-root .sci-status-pill {
	font-family: var(--sci-font-mono);
	font-size: 11px;
	text-transform: uppercase;
	padding: 3px 10px;
	border-radius: 20px;
}

.sciwebinar-app-root .sci-status-pill.published {
	background: rgba(232, 119, 34, 0.15);
	color: var(--sci-orange-text-on-tint);
}

.sciwebinar-app-root .sci-status-pill.draft {
	background: var(--sci-paper-dim);
	color: var(--sci-ink-soft);
}

.sciwebinar-app-root .sci-status-pill.ended {
	background: rgba(46, 125, 82, 0.15);
	color: #1d5138;
}

.sciwebinar-app-root .sci-login-shell {
	max-width: 380px;
	margin: 90px auto;
	padding: 0 24px;
}

.sciwebinar-app-root .sci-login-card {
	background: #ffffff;
	border: 1px solid var(--sci-line);
	border-radius: var(--sci-radius);
	padding: 36px;
}

.sciwebinar-app-root .sci-login-logo {
	text-align: center;
	margin-bottom: 28px;
}

.sciwebinar-app-root .sci-login-logo .sci-mark {
	font-family: var(--sci-font-display);
	font-size: 24px;
	color: var(--sci-navy);
}

.sciwebinar-app-root .sci-login-logo .sci-mark .sci-mark-orange {
	color: var(--sci-orange-dark);
}

@media (max-width: 600px) {
	.sciwebinar-app-root h1.sci-h1 {
		font-size: 26px;
	}

	.sci-card,
	.sciwebinar-app-root .sci-login-card {
		padding: 22px;
	}
}

.sciwebinar-app-root a:focus-visible, .sciwebinar-app-root button:focus-visible, .sciwebinar-app-root input:focus-visible, .sciwebinar-app-root select:focus-visible {
	outline: 2px solid var(--sci-orange-dark);
	outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
	.sciwebinar-app-root * {
		transition: none !important;
	}
}

/* ---------- Comprehensive mobile pass ---------- */

@media (max-width: 600px) {
	.sciwebinar-app-root .sci-shell {
		padding: 32px 16px 60px;
	}

	.sciwebinar-app-root .sci-shell-wide {
		padding: 24px 12px 50px;
	}

	.sciwebinar-app-root .sci-sub {
		font-size: 14px;
	}

	.sciwebinar-app-root .sci-section-title {
		font-size: 11px;
	}

	/* The sticky total bar can behave unreliably with mobile browsers'
	   dynamic address-bar show/hide behavior, and "bottom: 16px" risks
	   sitting under on-screen keyboards or browser chrome. Switch to a
	   normal in-flow element on small screens instead of sticky. */
	.sciwebinar-app-root .sci-total-bar {
		position: static;
		flex-wrap: wrap;
		gap: 8px;
	}

	.sciwebinar-app-root .sci-login-shell {
		margin: 40px auto;
		padding: 0 16px;
	}

	.sciwebinar-app-root .sci-speaker-grid {
		grid-template-columns: 1fr;
	}

	.sciwebinar-app-root .sci-toolbar {
		flex-direction: column;
		align-items: stretch;
	}

	.sci-toolbar input[type="search"],
	.sciwebinar-app-root .sci-toolbar select {
		width: 100%;
	}

	.sciwebinar-app-root .sci-calendar-item {
		flex-direction: column;
		align-items: stretch;
	}

	.sciwebinar-app-root .sci-calendar-item > div:last-child {
		flex-wrap: wrap;
	}

	.sci-payment-option,
	.sciwebinar-app-root .sci-session-option {
		flex-wrap: wrap;
	}

	.sciwebinar-app-root .sci-session-option-price {
		margin-left: auto;
	}

	.sciwebinar-app-root .sci-dash-sidebar-header {
		padding: 0 16px 16px;
	}

	.sciwebinar-app-root .sci-dash-session-link {
		padding: 12px 16px;
	}
}

@media (max-width: 420px) {
	.sciwebinar-app-root h1.sci-h1 {
		font-size: 22px;
	}

	.sciwebinar-app-root .sci-btn {
		padding: 13px 20px;
		font-size: 14px;
	}
}

/* ---------- Session selection (registration form) ---------- */

.sciwebinar-app-root .sci-session-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.sciwebinar-app-root .sci-session-option {
	display: flex;
	align-items: center;
	gap: 14px;
	border: 1.5px solid var(--sci-line);
	border-radius: var(--sci-radius);
	padding: 14px 16px;
	cursor: pointer;
}

.sciwebinar-app-root .sci-session-option:hover {
	border-color: var(--sci-orange);
}

.sciwebinar-app-root .sci-session-option.checked {
	border-color: var(--sci-navy);
	background: rgba(31, 78, 121, 0.04);
}

.sciwebinar-app-root .sci-session-option input[type="radio"] {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	accent-color: var(--sci-orange-dark);
}

.sciwebinar-app-root .sci-session-option-body {
	flex: 1;
}

.sciwebinar-app-root .sci-session-option-title {
	font-weight: 600;
	font-size: 14px;
	color: var(--sci-navy);
}

.sciwebinar-app-root .sci-session-option-date {
	font-size: 12px;
	color: var(--sci-ink-soft);
	margin-top: 2px;
}

.sciwebinar-app-root .sci-session-option-price {
	font-weight: 700;
	font-size: 14px;
	color: var(--sci-orange-text-on-tint);
	white-space: nowrap;
}

.sciwebinar-app-root .sci-total-bar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: var(--sci-navy);
	color: #ffffff;
	border-radius: var(--sci-radius);
	padding: 16px 20px;
	font-size: 14px;
	position: sticky;
	bottom: 16px;
}

.sciwebinar-app-root .sci-total-bar strong {
	font-size: 20px;
	font-weight: 700;
}

/* ---------- Attendee dashboard - standard app layout ---------- */

.sciwebinar-app-root .sciwebinar-app-shell {
	min-height: calc(100vh - 64px);
}

.sciwebinar-app-root .sci-dash-layout {
	display: grid;
	grid-template-columns: 280px 1fr;
	min-height: calc(100vh - 64px);
}

@media (max-width: 860px) {
	.sciwebinar-app-root .sci-dash-layout {
		grid-template-columns: 1fr;
	}
}

.sciwebinar-app-root .sci-dash-sidebar {
	background: var(--sci-paper-dim);
	border-right: 1px solid var(--sci-line);
	padding: 24px 0;
	display: flex;
	flex-direction: column;
}

@media (max-width: 860px) {
	.sciwebinar-app-root .sci-dash-sidebar {
		border-right: none;
		border-bottom: 1px solid var(--sci-line);
	}
}

.sciwebinar-app-root .sci-dash-sidebar-header {
	padding: 0 20px 20px;
	border-bottom: 1px solid var(--sci-line);
	margin-bottom: 12px;
}

.sciwebinar-app-root .sci-dash-series-title {
	font-family: var(--sci-font-display);
	font-weight: 700;
	font-size: 16px;
	color: var(--sci-navy);
	line-height: 1.3;
	margin-bottom: 8px;
}

.sciwebinar-app-root .sci-dash-attendance-badge {
	display: inline-block;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	background: rgba(31, 78, 121, 0.1);
	color: var(--sci-navy);
	padding: 3px 10px;
	border-radius: 20px;
}

.sciwebinar-app-root .sci-dash-session-nav {
	display: flex;
	flex-direction: column;
}

.sciwebinar-app-root .sci-dash-session-link {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 20px;
	text-decoration: none;
	color: var(--sci-ink);
	border-left: 3px solid transparent;
	font-size: 14px;
}

.sciwebinar-app-root .sci-dash-session-link:hover {
	background: rgba(31, 78, 121, 0.06);
}

.sciwebinar-app-root .sci-dash-session-link.active {
	background: #ffffff;
	border-left-color: var(--sci-orange);
	font-weight: 600;
}

.sciwebinar-app-root .sci-dash-session-icon {
	font-size: 10px;
	flex-shrink: 0;
}

.sciwebinar-app-root .sci-dash-session-link.unlocked .sci-dash-session-icon {
	color: var(--sci-sage);
}

.sciwebinar-app-root .sci-dash-session-link.locked .sci-dash-session-icon {
	color: var(--sci-ink-soft);
	font-size: 13px;
}

.sciwebinar-app-root .sci-dash-session-link.locked {
	color: var(--sci-ink-soft);
}

.sciwebinar-app-root .sci-dash-session-link-title {
	flex: 1;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sciwebinar-app-root .sci-dash-session-link-date {
	font-size: 11px;
	color: var(--sci-ink-soft);
	white-space: nowrap;
	flex-shrink: 0;
}

.sciwebinar-app-root .sci-dash-main {
	padding: 40px 48px;
	max-width: 760px;
}

@media (max-width: 600px) {
	.sciwebinar-app-root .sci-dash-main {
		padding: 28px 20px;
	}
}

.sciwebinar-app-root .sci-dash-locked-state {
	text-align: center;
	padding: 40px 20px;
}

.sciwebinar-app-root .sci-dash-locked-state .sci-eyebrow, .sciwebinar-app-root .sci-dash-locked-state .sci-h1, .sciwebinar-app-root .sci-dash-locked-state .sci-sub {
	display: block;
	margin-left: auto;
	margin-right: auto;
}
