.ana-area-wrap {
	--ana-purple: #581f54;
	--ana-pink: #c1258f;
	--ana-green: #0e836a;
	--ana-yellow: #febc20;
	--ana-ink: #2d2438;
	--ana-muted: #74687c;
	--ana-soft: #fff7fb;
	--ana-line: #eadce9;
	color: var(--ana-ink);
	font-family: "Poppins", Arial, sans-serif;
	margin: 0;
	max-width: none;
	padding: 0;
	width: 100%;
}

.ana-area-wrap *,
.ana-area-wrap *::before,
.ana-area-wrap *::after {
	box-sizing: border-box;
}

.ana-area-page {
	background: #fcfbfc;
	padding-bottom: 60px;
}

.ana-page-titlebar {
	background: #fff;
	border-bottom: 1px solid var(--ana-line, #eadce9);
	margin-bottom: 28px;
	padding: 20px 0;
}

.ana-page-titlebar h1 {
	color: #581f54;
	font-size: 26px;
	font-weight: 800;
	line-height: 1.2;
	margin: 0;
}

.ana-area-page-content {
	min-height: 680px;
}

.ana-area-hero {
	align-items: flex-start;
	background: linear-gradient(135deg, #fff7fb 0%, #f3fbf6 100%);
	border: 1px solid var(--ana-line);
	border-radius: 8px;
	display: flex;
	gap: 24px;
	justify-content: space-between;
	margin-bottom: 22px;
	padding: 32px;
}

.ana-area-nav {
	background: #fff;
	border: 1px solid var(--ana-line);
	border-radius: 8px;
	display: grid;
	gap: 8px;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	margin-bottom: 18px;
	padding: 10px;
	position: sticky;
	top: 10px;
	z-index: 20;
}

.ana-area-nav a {
	align-items: center;
	border-radius: 6px;
	color: var(--ana-purple);
	display: flex;
	font-size: 14px;
	font-weight: 800;
	justify-content: center;
	min-height: 48px;
	padding: 10px;
	text-align: center;
	text-decoration: none;
}

.ana-area-nav a:hover,
.ana-area-nav a:focus {
	background: var(--ana-purple);
	color: #fff;
	outline: none;
	text-decoration: none;
}

.ana-area-kicker {
	color: var(--ana-pink);
	display: block;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0;
	margin-bottom: 8px;
	text-transform: uppercase;
}

.ana-area-hero h1,
.ana-login-panel h1 {
	color: var(--ana-purple);
	font-size: 34px;
	font-weight: 800;
	line-height: 1.12;
	margin: 0 0 10px;
}

.ana-area-hero p,
.ana-login-panel p {
	color: var(--ana-muted);
	font-size: 16px;
	line-height: 1.65;
	margin: 0;
	max-width: 680px;
}

.ana-area-logout,
.ana-material-item a,
.ana-compact-list a,
.ana-video-open {
	background: var(--ana-pink);
	border: 0;
	border-radius: 999px;
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font-size: 14px;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 42px;
	padding: 12px 18px;
	text-decoration: none;
	white-space: nowrap;
}

.ana-area-logout:hover,
.ana-material-item a:hover,
.ana-compact-list a:hover,
.ana-video-open:hover,
.ana-video-open:focus {
	background: #8a2e80;
	color: #fff;
	outline: none;
	text-decoration: none;
}

.ana-area-grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(12, 1fr);
}

.ana-area-card {
	background: #fff;
	border: 1px solid var(--ana-line);
	border-radius: 8px;
	box-shadow: 0 10px 30px rgba(88, 31, 84, 0.08);
	grid-column: span 4;
	min-width: 0;
	padding: 24px;
	scroll-margin-top: 90px;
}

.ana-area-card-wide {
	grid-column: span 8;
}

.ana-area-card-head {
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin-bottom: 18px;
}

.ana-area-card-head h2 {
	color: var(--ana-purple);
	font-size: 22px;
	font-weight: 800;
	line-height: 1.2;
	margin: 0;
}

.ana-area-card-description {
	color: var(--ana-muted);
	font-size: 14px;
	line-height: 1.5;
	margin: 7px 0 0;
}

.ana-timeline {
	display: grid;
	gap: 0;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	position: relative;
}

.ana-timeline::before {
	background: var(--ana-line);
	content: "";
	height: 2px;
	left: 9%;
	position: absolute;
	right: 9%;
	top: 18px;
}

.ana-timeline-item {
	min-width: 0;
	position: relative;
	text-align: center;
}

.ana-timeline-dot {
	background: #fff;
	border: 4px solid var(--ana-line);
	border-radius: 50%;
	height: 36px;
	margin: 0 auto 12px;
	position: relative;
	width: 36px;
	z-index: 1;
}

.ana-timeline-item.is-em-andamento .ana-timeline-dot {
	border-color: var(--ana-pink);
	box-shadow: 0 0 0 6px rgba(193, 37, 143, 0.12);
}

.ana-timeline-item.is-concluido .ana-timeline-dot {
	background: var(--ana-green);
	border-color: var(--ana-green);
}

.ana-timeline-item strong {
	color: var(--ana-ink);
	display: block;
	font-size: 14px;
	line-height: 1.35;
}

.ana-timeline-item small {
	color: var(--ana-muted);
	display: block;
	font-size: 12px;
	margin-top: 4px;
}

.ana-journey-content {
	border-top: 1px solid var(--ana-line);
	margin-top: 34px;
	padding-top: 26px;
}

.ana-journey-content > h2 {
	color: var(--ana-purple);
	font-size: 20px;
	font-weight: 800;
	margin: 0 0 18px;
}

.ana-journey-stage-content {
	margin-top: 22px;
}

.ana-journey-stage-content > h3 {
	color: var(--ana-green);
	font-size: 15px;
	font-weight: 800;
	margin: 0 0 10px;
}

.ana-profile-list {
	margin: 0;
}

.ana-profile-list dt {
	color: var(--ana-muted);
	font-size: 12px;
	font-weight: 700;
	margin-top: 14px;
	text-transform: uppercase;
}

.ana-profile-list dt:first-child {
	margin-top: 0;
}

.ana-profile-list dd {
	border-bottom: 1px solid var(--ana-line);
	color: var(--ana-ink);
	font-size: 15px;
	margin: 4px 0 0;
	padding-bottom: 12px;
	word-break: break-word;
}

.ana-material-tabs {
	display: grid;
	gap: 8px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-bottom: 16px;
}

.ana-library-search {
	margin-bottom: 16px;
}

.ana-library-search label {
	color: var(--ana-purple);
	display: block;
	font-size: 13px;
	font-weight: 800;
	margin-bottom: 7px;
}

.ana-library-search input {
	background: #fff;
	border: 1px solid var(--ana-line);
	border-radius: 6px;
	color: var(--ana-ink);
	font-size: 16px;
	min-height: 50px;
	padding: 10px 14px;
	width: 100%;
}

.ana-library-search input:focus {
	border-color: var(--ana-pink);
	box-shadow: 0 0 0 3px rgba(193, 37, 143, 0.12);
	outline: none;
}

.ana-material-tabs button {
	background: #fff;
	border: 1px solid var(--ana-line);
	border-radius: 6px;
	color: var(--ana-purple);
	cursor: pointer;
	font-size: 14px;
	font-weight: 700;
	min-height: 50px;
	padding: 10px 14px;
	text-align: center;
}

.ana-material-tabs button.is-active,
.ana-material-tabs button:hover,
.ana-material-tabs button:focus {
	background: var(--ana-purple);
	border-color: var(--ana-purple);
	color: #fff;
	outline: none;
}

.ana-material-list {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ana-material-item {
	background: var(--ana-soft);
	border: 1px solid #f1d6e8;
	border-radius: 8px;
	min-width: 0;
	padding: 22px;
}

.ana-material-item[style*="display: none"] {
	display: none !important;
}

.ana-material-item span {
	color: var(--ana-green);
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
}

.ana-material-item h3,
.ana-compact-list h3,
.ana-message-list h3 {
	color: var(--ana-purple);
	font-size: 17px;
	font-weight: 800;
	line-height: 1.3;
	margin: 8px 0;
}

.ana-material-item p,
.ana-compact-list p,
.ana-message-list p {
	color: var(--ana-muted);
	font-size: 14px;
	line-height: 1.55;
	margin: 0 0 12px;
}

.ana-compact-list,
.ana-message-list {
	display: grid;
	gap: 12px;
}

.ana-compact-list article,
.ana-message-list article {
	border-bottom: 1px solid var(--ana-line);
	padding-bottom: 14px;
}

.ana-compact-list article:last-child,
.ana-message-list article:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.ana-compact-list time,
.ana-message-list time {
	color: var(--ana-green);
	display: block;
	font-size: 12px;
	font-weight: 800;
}

.ana-listing-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ana-listing-card {
	background: #fff;
	border: 1px solid var(--ana-line);
	border-radius: 8px;
	display: flex;
	flex-direction: column;
	min-height: 190px;
	padding: 22px;
}

.ana-message-list .ana-listing-card,
.ana-event-list .ana-listing-card {
	border-bottom: 1px solid var(--ana-line);
	padding: 22px;
}

.ana-listing-card h3 {
	color: var(--ana-purple);
	font-size: 18px;
	font-weight: 800;
	line-height: 1.35;
	margin: 10px 0 8px;
}

.ana-listing-card p,
.ana-listing-card .ana-message-body {
	color: var(--ana-muted);
	font-size: 14px;
	line-height: 1.65;
}

.ana-listing-card .ana-message-body p {
	margin: 0 0 12px;
}

.ana-listing-card time {
	color: var(--ana-green);
	font-size: 12px;
	font-weight: 800;
	margin-top: auto;
	padding-top: 14px;
}

.ana-listing-label {
	color: var(--ana-pink);
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
}

.ana-event-location {
	border-left: 3px solid var(--ana-green);
	padding-left: 10px;
}

.ana-empty,
.ana-area-notice {
	background: #f4f9f5;
	border-left: 4px solid var(--ana-green);
	border-radius: 4px;
	color: var(--ana-muted);
	margin: 0;
	padding: 16px;
}

.ana-login-panel {
	background: #fff;
	border: 1px solid var(--ana-line);
	border-radius: 8px;
	box-shadow: 0 10px 30px rgba(88, 31, 84, 0.08);
	margin: 20px auto;
	max-width: 520px;
	padding: 34px;
}

.ana-access-grid {
	align-items: start;
	display: grid;
	gap: 22px;
	grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
	margin: 0 auto;
	max-width: 1040px;
}

.ana-access-grid .ana-login-panel {
	margin: 0;
	max-width: none;
}

.ana-register-panel {
	background: #fff;
	border: 1px solid var(--ana-line);
	border-radius: 8px;
	box-shadow: 0 10px 30px rgba(88, 31, 84, 0.08);
	padding: 34px;
}

.ana-login-panel h2,
.ana-register-panel h2 {
	color: var(--ana-purple);
	font-size: 26px;
	font-weight: 800;
	margin: 0 0 10px;
}

.ana-login-panel > p,
.ana-register-panel > p {
	color: var(--ana-muted);
	font-size: 14px;
	line-height: 1.6;
	margin: 0;
}

.ana-register-form {
	display: grid;
	gap: 8px;
	margin-top: 22px;
}

.ana-register-form label {
	color: var(--ana-ink);
	font-size: 13px;
	font-weight: 700;
	margin-top: 5px;
}

.ana-register-form input {
	background: #fff;
	border: 1px solid var(--ana-line);
	border-radius: 4px;
	font-size: 16px;
	min-height: 48px;
	padding: 10px 13px;
	width: 100%;
}

.ana-register-form input:focus {
	border-color: var(--ana-pink);
	box-shadow: 0 0 0 3px rgba(193, 37, 143, 0.12);
	outline: none;
}

.ana-register-form button {
	background: var(--ana-pink);
	border: 0;
	border-radius: 999px;
	color: #fff;
	cursor: pointer;
	font-size: 15px;
	font-weight: 800;
	margin-top: 12px;
	min-height: 48px;
	padding: 12px 18px;
}

.ana-privacy-consent {
	align-items: start;
	display: grid;
	gap: 10px;
	grid-template-columns: 20px 1fr;
	margin-top: 10px !important;
}

.ana-privacy-consent input {
	height: 18px;
	margin: 2px 0 0;
	min-height: 0;
	width: 18px;
}

.ana-privacy-consent span {
	color: var(--ana-muted);
	font-size: 12px;
	font-weight: 400;
	line-height: 1.5;
}

#ana-loginform {
	margin-top: 24px;
}

#ana-loginform label {
	color: var(--ana-ink);
	display: block;
	font-weight: 700;
	margin-bottom: 8px;
}

#ana-loginform input[type="text"],
#ana-loginform input[type="password"] {
	border: 1px solid var(--ana-line);
	border-radius: 4px;
	font-size: 16px;
	margin-bottom: 16px;
	padding: 12px 14px;
	width: 100%;
}

#ana-loginform input[type="submit"] {
	background: var(--ana-pink);
	border: 0;
	border-radius: 999px;
	color: #fff;
	cursor: pointer;
	font-size: 15px;
	font-weight: 800;
	padding: 13px 18px;
	text-transform: uppercase;
	width: 100%;
}

.ana-login-help {
	color: var(--ana-pink);
	display: inline-block;
	font-weight: 700;
	margin-top: 14px;
}

.ana-video-modal[hidden] {
	display: none;
}

.ana-video-modal {
	align-items: center;
	display: flex;
	inset: 0;
	justify-content: center;
	padding: 20px;
	position: fixed;
	z-index: 100000;
}

.ana-video-modal-backdrop {
	background: rgba(25, 15, 30, 0.82);
	inset: 0;
	position: absolute;
}

.ana-video-modal-dialog {
	background: #fff;
	border-radius: 8px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.35);
	max-width: 960px;
	overflow: hidden;
	position: relative;
	width: 100%;
	z-index: 1;
}

.ana-video-modal-head {
	align-items: center;
	display: flex;
	justify-content: space-between;
	padding: 14px 18px;
}

.ana-video-modal-head h2 {
	color: var(--ana-purple);
	font-size: 20px;
	font-weight: 800;
	margin: 0;
}

.ana-video-close {
	align-items: center;
	background: var(--ana-purple);
	border: 0;
	border-radius: 50%;
	color: #fff;
	cursor: pointer;
	display: flex;
	font-size: 28px;
	height: 42px;
	justify-content: center;
	line-height: 1;
	width: 42px;
}

.ana-video-frame {
	aspect-ratio: 16 / 9;
	background: #111;
	width: 100%;
}

.ana-video-frame iframe {
	border: 0;
	height: 100%;
	width: 100%;
}

body.ana-video-modal-open {
	overflow: hidden;
}

.ana-portal-layout {
	align-items: start;
	display: grid;
	gap: 24px;
	grid-template-columns: 270px minmax(0, 1fr);
	min-height: 680px;
}

.ana-portal-sidebar {
	background: var(--ana-purple);
	border-radius: 8px;
	color: #fff;
	display: flex;
	flex-direction: column;
	min-height: 680px;
	overflow: hidden;
	padding: 24px 16px 16px;
	position: sticky;
	top: 20px;
}

.ana-portal-brand {
	border-bottom: 1px solid rgba(255, 255, 255, 0.18);
	padding: 2px 8px 22px;
}

.ana-portal-brand .ana-area-kicker {
	color: var(--ana-yellow);
}

.ana-portal-brand strong {
	display: block;
	font-size: 26px;
	font-weight: 800;
	line-height: 1.2;
	margin-bottom: 8px;
}

.ana-portal-brand p {
	color: rgba(255, 255, 255, 0.78);
	font-size: 13px;
	line-height: 1.5;
	margin: 0;
}

.ana-portal-menu {
	display: grid;
	gap: 5px;
	margin: 18px 0;
}

.ana-portal-menu a {
	align-items: center;
	border-radius: 6px;
	color: rgba(255, 255, 255, 0.9);
	display: grid;
	font-size: 14px;
	font-weight: 700;
	gap: 10px;
	grid-template-columns: 28px 1fr;
	min-height: 48px;
	padding: 8px 12px;
	text-decoration: none;
}

.ana-portal-menu a:hover,
.ana-portal-menu a:focus,
.ana-portal-menu a.is-active {
	background: #fff;
	color: var(--ana-purple);
	outline: none;
	text-decoration: none;
}

.ana-menu-icon {
	align-items: center;
	background: rgba(255, 255, 255, 0.14);
	border-radius: 50%;
	display: flex;
	font-size: 15px;
	height: 28px;
	justify-content: center;
	width: 28px;
}

.ana-portal-menu a.is-active .ana-menu-icon,
.ana-portal-menu a:hover .ana-menu-icon,
.ana-portal-menu a:focus .ana-menu-icon {
	background: var(--ana-soft);
}

.ana-sidebar-profile {
	align-items: center;
	background: rgba(255, 255, 255, 0.1);
	border-radius: 8px;
	display: grid;
	gap: 10px;
	grid-template-columns: 44px 1fr;
	margin-top: auto;
	padding: 12px;
}

.ana-profile-avatar {
	align-items: center;
	background: var(--ana-pink);
	border-radius: 50%;
	display: flex;
	font-size: 14px;
	font-weight: 800;
	height: 44px;
	justify-content: center;
	width: 44px;
}

.ana-sidebar-profile strong,
.ana-sidebar-profile span {
	display: block;
	line-height: 1.35;
}

.ana-sidebar-profile strong {
	font-size: 13px;
}

.ana-sidebar-profile span {
	color: rgba(255, 255, 255, 0.7);
	font-size: 11px;
}

.ana-sidebar-profile a {
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	grid-column: 1 / -1;
	text-decoration: underline;
}

.ana-portal-sidebar .ana-area-logout {
	background: transparent;
	border: 1px solid rgba(255, 255, 255, 0.35);
	border-radius: 6px;
	margin-top: 12px;
	width: 100%;
}

.ana-portal-main {
	min-width: 0;
}

.ana-portal-header {
	align-items: end;
	background: linear-gradient(135deg, #fff7fb 0%, #f3fbf6 100%);
	border: 1px solid var(--ana-line);
	border-radius: 8px;
	display: flex;
	gap: 24px;
	justify-content: space-between;
	margin-bottom: 18px;
	padding: 26px 30px;
}

.ana-portal-header h1 {
	color: var(--ana-purple);
	font-size: 30px;
	font-weight: 800;
	line-height: 1.2;
	margin: 0;
}

.ana-portal-header p {
	color: var(--ana-muted);
	font-size: 14px;
	line-height: 1.55;
	margin: 0;
	max-width: 410px;
	text-align: right;
}

.ana-content-panel {
	background: #fff;
	border: 1px solid var(--ana-line);
	border-radius: 8px;
	box-shadow: 0 10px 30px rgba(88, 31, 84, 0.06);
	min-height: 340px;
	padding: 30px;
}

.ana-overview-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-bottom: 18px;
}

.ana-overview-grid a {
	background: #fff;
	border: 1px solid var(--ana-line);
	border-left: 5px solid var(--ana-green);
	border-radius: 8px;
	color: var(--ana-ink);
	display: grid;
	gap: 5px;
	min-height: 128px;
	padding: 20px;
	text-decoration: none;
}

.ana-overview-grid a:hover,
.ana-overview-grid a:focus {
	border-color: var(--ana-pink);
	box-shadow: 0 8px 22px rgba(88, 31, 84, 0.1);
	outline: none;
	text-decoration: none;
}

.ana-overview-grid span {
	color: var(--ana-purple);
	font-size: 15px;
	font-weight: 800;
}

.ana-overview-grid strong {
	color: var(--ana-pink);
	font-size: 28px;
	line-height: 1.2;
}

.ana-overview-grid small {
	color: var(--ana-muted);
	font-size: 12px;
}

.ana-profile-panel {
	max-width: 720px;
}

.ana-profile-panel .ana-profile-list {
	display: grid;
	gap: 0 24px;
	grid-template-columns: 1fr 1fr;
}

.ana-profile-panel .ana-profile-list dd {
	min-height: 44px;
}

@media (max-width: 991px) {
	.ana-access-grid {
		grid-template-columns: 1fr;
	}

	.ana-portal-layout {
		grid-template-columns: 1fr;
	}

	.ana-portal-sidebar {
		min-height: auto;
		position: static;
	}

	.ana-portal-menu {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.ana-sidebar-profile {
		margin-top: 8px;
	}

	.ana-portal-sidebar .ana-area-logout {
		width: auto;
	}

	.ana-listing-grid {
		grid-template-columns: 1fr;
	}

	.ana-area-nav {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		position: static;
	}

	.ana-area-card,
	.ana-area-card-wide {
		grid-column: span 12;
	}

	.ana-timeline {
		gap: 14px;
		grid-template-columns: 1fr;
	}

	.ana-timeline::before {
		bottom: 16px;
		height: auto;
		left: 17px;
		right: auto;
		top: 16px;
		width: 2px;
	}

	.ana-timeline-item {
		align-items: center;
		display: grid;
		gap: 12px;
		grid-template-columns: 36px 1fr;
		text-align: left;
	}

	.ana-timeline-dot {
		margin: 0;
	}
}

@media (max-width: 640px) {
	.ana-area-wrap {
		padding: 0;
	}

	.ana-page-titlebar {
		margin-bottom: 18px;
		padding: 15px 0;
	}

	.ana-page-titlebar h1 {
		font-size: 22px;
	}

	.ana-area-hero {
		display: block;
		padding: 24px;
	}

	.ana-area-hero h1,
	.ana-login-panel h1 {
		font-size: 28px;
	}

	.ana-area-logout {
		margin-top: 18px;
	}

	.ana-area-card,
	.ana-login-panel {
		padding: 20px;
	}

	.ana-material-list {
		grid-template-columns: 1fr;
	}

	.ana-area-nav,
	.ana-material-tabs {
		grid-template-columns: 1fr 1fr;
	}

	.ana-area-nav a,
	.ana-material-tabs button {
		font-size: 13px;
		min-height: 52px;
	}

	.ana-portal-sidebar {
		padding: 18px 12px 12px;
	}

	.ana-portal-menu {
		grid-template-columns: 1fr 1fr;
	}

	.ana-portal-menu a {
		font-size: 12px;
		grid-template-columns: 24px 1fr;
		min-height: 50px;
		padding: 7px 8px;
	}

	.ana-menu-icon {
		height: 24px;
		width: 24px;
	}

	.ana-portal-header {
		align-items: start;
		display: block;
		padding: 22px;
	}

	.ana-portal-header h1 {
		font-size: 26px;
	}

	.ana-portal-header p {
		margin-top: 10px;
		text-align: left;
	}

	.ana-content-panel {
		min-height: 0;
		padding: 20px;
	}

	.ana-overview-grid,
	.ana-profile-panel .ana-profile-list {
		grid-template-columns: 1fr;
	}
}
