@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap');

body,
button,
input,
select,
textarea,
.ci-toast,
.tag-option,
.btn,
.nav-link {
	font-family: 'Poppins', sans-serif;
}

body {
	overflow-x: hidden;
}

.ci-portal {
	font-family: 'Poppins', sans-serif;
	display: flex;
	background: #ffffff;
	color: #000000;
	border: 1px solid #e4e4e4;
	border-radius: 12px;
	box-shadow: 0 16px 32px rgba(0, 0, 0, 0.08);
	overflow: hidden;
	max-width: 1200px;
	margin: 32px auto;
	min-height: 680px;
}

.ci-portal .sidebar {
	width: 280px;
	background: #0e0e0e;
	color: #fdfdfd;
	display: flex;
	flex-direction: column;
	padding: 24px 20px;
	gap: 24px;
}

.ci-portal .sidebar .logo {
	font-size: 20px;
	font-weight: 600;
	line-height: 1.3;
	display: flex;
	align-items: center;
	gap: 12px;
}

.ci-portal .sidebar .logo .brand-icon {
	width: 40px;
	height: 40px;
	object-fit: contain;
}

.ci-portal .sidebar .logo .brand-text {
	display: flex;
	flex-direction: column;
}

.ci-portal .sidebar .logo span {
	display: block;
	font-size: 13px;
	font-weight: 400;
	color: #bbbbbb;
	margin-top: 4px;
}

.ci-portal .sidebar .logout-btn {
	width: 100%;
	margin-top: 8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 8px 12px;
	font-size: 13px;
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.4);
	background: transparent;
}

.ci-portal .sidebar .logout-btn img {
	width: 18px;
	height: 18px;
}

.ci-portal .nav-group + .nav-group {
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding-top: 16px;
}
.hidden {
	display: none !important;
}

.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

.alert {
	border-radius: 12px;
	padding: 12px 16px;
	margin-top: 16px;
	font-size: 14px;
	font-weight: 500;
}

.alert.warning {
	background: #fff4f1;
	border: 1px solid rgba(237, 28, 36, 0.2);
	color: #b04720;
}

.icon-btn {
	margin-bottom: 16px;
	gap: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
}

.icon-btn .icon-person {
	font-size: 18px;
}

.icon-btn .icon-img {
	width: 18px;
	height: 18px;
	object-fit: contain;
}

.cliente-login-panel {
	display: none;
}

.cliente-login-panel.open {
	display: block;
	margin-bottom: 16px;
}

.resumo-vinculos {
	margin-bottom: 20px;
	background: #f7f7f7 !important;
}

.aluno-resumo-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 12px;
}

.aluno-card {
	border: 1px solid #ededed;
	border-radius: 12px;
	padding: 12px;
	background: #fff;
}

.aluno-card.destacado {
	border-color: #ed1c24;
	box-shadow: 0 8px 20px rgba(237, 28, 36, 0.12);
}

.aluno-card h4 {
	margin: 0 0 6px;
	font-size: 15px;
}

.aluno-card ul {
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: 13px;
	line-height: 1.4;
}

.trilha-actions {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	gap: 8px;
}

.trilha-actions .btn {
	width: 100%;
}

.table-actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	justify-content: flex-start;
}

.table.small td,
.table.small th {
	font-size: 13px;
	padding: 8px 12px;
}

.steps-bar {
	display: flex;
	gap: 12px;
	margin-bottom: 20px;
	flex-wrap: wrap;
}

.step-pill {
	flex: 1;
	min-width: 120px;
	padding: 10px 12px;
	border-radius: 999px;
	border: 1px solid #e0e0e0;
	background: #fff;
	font-weight: 600;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.step-pill.active {
	border-color: #ed1c24;
	color: #ed1c24;
	box-shadow: 0 8px 18px rgba(237, 28, 36, 0.15);
}

.step-pill.locked,
.nav-link.locked {
	opacity: 0.4;
	cursor: not-allowed;
}

.ci-portal .nav-group h4 {
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #ed1c24;
	margin-bottom: 10px;
}

.ci-portal .nav-group .nav-link,
.ci-portal .nav-group .group-toggle {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	background: transparent;
	border: none;
	color: inherit;
	text-align: left;
	font-size: 14px;
	padding: 8px 12px;
	border-radius: 8px;
	cursor: pointer;
	transition: background 0.2s, color 0.2s;
}

.ci-portal .nav-group .nav-link:hover,
.ci-portal .nav-group .group-toggle:hover {
	background: rgba(255, 255, 255, 0.08);
}

.ci-portal .nav-group .nav-link.active {
	background: #ed1c24;
	color: #ffffff;
}

.ci-portal .nav-group .nav-link.locked {
	pointer-events: none;
}

.ci-portal .nav-group .submenu {
	display: none;
	padding-left: 12px;
}

.ci-portal .nav-group .submenu.open {
	display: block;
}

.ci-portal .nav-group .submenu .nav-link {
	font-size: 13px;
	margin-top: 4px;
}

.ci-portal .main {
	flex: 1;
	background: #f7f7f7;
	padding: 32px;
	overflow-y: auto;
}

.ci-portal .main-header {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-bottom: 24px;
}

.ci-portal .main-header h1 {
	margin: 0;
	font-size: 24px;
	font-weight: 600;
	color: #151515;
}

.ci-portal .main-header .muted {
	color: #6b6b6b;
	font-size: 14px;
}

.view {
	display: none;
	gap: 24px;
}

.view.active {
	display: block;
}

.card,
.card3 {
	background: #ffffff;
	border-radius: 16px;
	padding: 24px;
	box-sizing: border-box;
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.06);
	margin-bottom: 24px;
}

.card3.full {
	width: 100%;
}

.card3.card-nested {
	margin-top: 24px;
	background: #fafafa;
}

.card3 h2 {
	margin-top: 0;
	margin-bottom: 16px;
	font-size: 18px;
	font-weight: 600;
}

.card3 .intro,
.card .intro {
	color: #555555;
	font-size: 14px;
	margin-bottom: 20px;
}

.description {
	margin-top: -4px;
	color: #6b6b6b;
	font-size: 14px;
	margin-bottom: 18px;
}

.form-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin-bottom: 12px;
	width: 100%;
}

.form-grid .form-control {
	display: flex;
	flex-direction: column;
	gap: 6px;
	flex: 1 1 260px;
	min-width: 240px;
}

.form-grid .form-control.full {
	flex-basis: 100%;
	min-width: 100%;
}

.form-grid .form-control textarea {
	min-height: 90px;
}

.form-grid select,
.form-grid input,
.form-grid textarea {
	width: 100%;
	box-sizing: border-box;
	border-radius: 12px;
	padding: 12px 14px;
	border: 1px solid #e0e0e0;
	font-size: 14px;
	background: #fff;
	outline: none;
}

.form-grid select:focus,
.form-grid input:focus,
.form-grid textarea:focus {
	border-color: #8a8a8a;
	box-shadow: none;
}

.form-grid select[multiple] {
	min-height: 160px;
}

.input-currency {
	display: flex;
	align-items: center;
	border: 1px solid #e0e0e0;
	border-radius: 12px;
	background: #fff;
	padding: 0 12px 0 16px;
	gap: 8px;
}

.input-currency .currency-affix.hidden {
	display: none;
}

.input-currency input {
	border: none!important;
	background: transparent;
	padding: 12px 0;
	border-radius: 12px;
	font-size: 14px;
	width: 100%;
}

.input-currency span {
	font-weight: 600;
	color: #8a8a8a;
	font-size: 13px;
}

.checkbox-group {
	display: flex;
	gap: 18px;
	flex-wrap: wrap;
}

.radio-group {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.radio-group label {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-weight: 500;
	color: #444;
}

.checkbox-group label {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 14px;
	font-weight: 500;
	color: #444;
}

.checkbox-control .checkbox-inline {
	display: flex;
	align-items: center;
	gap: 8px;
	font-weight: 500;
	color: #444;
}

.checkbox-field {
	flex-direction: row;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

.checkbox-field label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 600;
	margin: 0;
}

.checkbox-field input[type='checkbox'] {
	margin: 0;
}
input[type='checkbox'] {
	width:fit-content!important;
}
.checkbox-field .note {
	margin: 0;
	flex-basis: 100%;
}

.user-form .password-note {
	padding-top: 0;
}

.user-form .note {
	display: block;
	width: 100%;
	margin: 0;
}

.spacer {
	height: 20px;
}

.tag-selector {
	border: 1px solid #e0e0e0;
	border-radius: 16px;
	padding: 12px;
	background: #fff;
	display: flex;
	flex-direction: column;
	gap: 12px;
	min-height: 160px;
}

.tag-selector-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	min-height: 32px;
}

.tag-selector-tags .tag {
	background: #efefef;
	border-radius: 999px;
	padding: 6px 12px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: 500;
}

.tag-selector-tags .tag button {
	border: none;
	background: transparent;
	font-size: 14px;
	line-height: 1;
	cursor: pointer;
	color: #333;
}

.tag-selector-tags .placeholder {
	color: #9d9d9d;
	font-size: 13px;
}

.tag-selector-options {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	max-height: 180px;
	overflow-y: auto;
}

.tag-option {
	border: 1px solid #d8d8d8;
	border-radius: 999px;
	padding: 6px 12px;
	background: #fff;
	font-size: 13px;
	cursor: pointer;
}

.tag-option.selected {
	background: #ed1c24;
	color: #fff;
	border-color: #ed1c24;
}

.tag-option.disabled {
	opacity: 0.4;
	cursor: not-allowed;
	border-style: dashed;
}

.tag-option.disabled {
	opacity: 0.4;
	cursor: not-allowed;
	border-style: dashed;
}

.filters {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin-bottom: 16px;
}

.filters-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
}

.filters input,
.filters select {
	flex: 1;
	min-width: 180px;
	border-radius: 999px;
	border: 1px solid #e0e0e0;
	padding: 12px 16px;
	font-size: 13px;
	background: #fff;
}

.filters input::placeholder,
.filters select::placeholder {
	font-size: 13px;
}

.filters .btn {
	flex: 0 0 auto;
}

.form-row {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin-bottom: 16px;
	align-items: flex-end;
}

.form-row > div {
	flex: 1 1 260px;
}

.form-row .btn {
	flex: 0 0 auto;
	margin-left: 16px;
}

.form-row label {
	font-size: 13px;
	font-weight: 500;
	display: block;
	margin-bottom: 6px;
	color: #3c3c3c;
}

.form-row input[type="text"],
.form-row input[type="number"],
.form-row input[type="email"],
.form-row input[type="date"],
.form-row select,
.form-row textarea {
	width: 100%;
	min-width: 200px;
	padding: 12px 14px;
	border-radius: 10px;
	border: 1px solid #d0d0d0;
	font-size: 14px;
	background: #ffffff;
}

.form-row.turma-row {
	gap: 8px;
}

.periodo-valor-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
}

.periodo-valor-field label {
	font-size: 13px;
	font-weight: 500;
	display: block;
	margin-bottom: 6px;
	color: #3c3c3c;
}

.lista .linha {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}

.lista .linha .nome,
.lista .linha .curso {
	flex: 1 1 50%;
	min-width: 220px;
}

.lista .linha .valor {
	flex: 1 1 50%;
	min-width: 220px;
}

.periodo-note {
	font-size: 12px;
	color: #6f6f6f;
	margin-top: 4px;
}

.woocommerce-embed {
	margin-top: 16px;
}

.woocommerce-embed .woocommerce {
	font-family: 'Poppins', sans-serif;
}

.woocommerce-embed .woocommerce form.checkout {
	background: #ffffff;
	border-radius: 18px;
	padding: 24px;
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.05);
}

.woocommerce-embed .woocommerce form .form-row {
	display: block;
	width: 100%;
	float: left;
}
#billing_country_field {
	display:none;
}
.woocommerce-embed .woocommerce input.input-text,
.woocommerce-embed .woocommerce textarea,
.woocommerce-embed .woocommerce select {
	border-radius: 12px;
	border: 1px solid #d0d0d0;
	padding: 12px 14px;
	height: 44px;
	font-size: 14px;
	font-family: 'Poppins', sans-serif;
}

.woocommerce-embed .woocommerce .col2-set {
	display: block;
}

.woocommerce-embed .woocommerce .col2-set .col-1,
.woocommerce-embed .woocommerce .col2-set .col-2 {
	width: 100%;
}

.woocommerce-embed .woocommerce .col2-set .col-2 {
	margin-top: 32px;
}
.woocommerce form .form-row select {
	height:44px;
	border-radius:14px;
	border:1px solid #d0d0d0;
}
.woocommerce-embed .woocommerce-billing-fields__field-wrapper,
.woocommerce-embed .woocommerce-shipping-fields__field-wrapper,
.woocommerce-embed .woocommerce-additional-fields__field-wrapper {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 0px 10px;
	margin-top: 12px;
}
.form-row.place-order {
	float:unset!important;
	background:#f9f9f9;
	font-size:14px;
	display:contents!important;
}
.woocommerce-terms-and-conditions-wrapper {
	margin:20px;
}
.woocommerce #payment #place_order, .woocommerce-page #payment #place_order {
	font-size:16px;
	background-color:#ed1c24;
	color:#fff;
	border-radius:500px;
	padding:20px;
	margin:20px;
}
.woocommerce-embed .woocommerce .form-row-first,
.woocommerce-embed .woocommerce .form-row-last {
	width: auto;
	margin: 0;
}

.woocommerce-embed .woocommerce .form-row-first,
.woocommerce-embed .woocommerce .form-row-last,
.woocommerce-embed .woocommerce .form-row {
	float: none;
}

.woocommerce-embed .woocommerce .form-row-wide {
	grid-column: 1 / -1;
}

.woocommerce-embed .woocommerce-form-coupon-toggle {
	display: none !important;
}

.woocommerce-embed #order_comments_field {
	display: none !important;
}

.ci-custom-coupon {
	border: 1px solid #e8e8e8;
	border-radius: 14px;
	padding: 18px;
	background: #fafafa;
	margin-bottom: 28px;
}

.ci-custom-coupon label {
	font-weight: 600;
	font-size: 14px;
	color: #333;
	display: block;
	margin-bottom: 10px;
}

.ci-custom-coupon .coupon-row {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}

.ci-custom-coupon .coupon-row input {
	flex: 1 1 240px;
	border-radius: 999px;
	padding: 12px 16px;
	border: 1px solid #d0d0d0;
	font-size: 14px;
}

.ci-custom-coupon .coupon-row .btn {
	flex: 0 0 auto;
	border-radius: 999px;
	padding: 12px 22px;
	font-size: 14px;
}

.ci-custom-coupon .coupon-feedback {
	margin-top: 8px;
	font-size: 13px;
	color: #c62828;
}

.ci-custom-coupon .coupon-list {
	margin-top: 16px;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.ci-custom-coupon .coupon-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: #fff;
	border: 1px solid #e0e0e0;
	border-radius: 999px;
	padding: 6px 12px;
	font-size: 13px;
}

.ci-custom-coupon .coupon-pill button {
	border: none;
	background: transparent;
	font-size: 12px;
	color: #ed1c24;
	cursor: pointer;
}

.woocommerce-embed .woocommerce-checkout-review-order {
	background: #f9f9f9;
	border-radius: 16px;
	padding: 16px 20px;
}

.woocommerce-embed .woocommerce table.shop_table {
	border-radius: 12px;
	overflow: hidden;
}

.woocommerce-embed.checkout-loading {
	position: relative;
	min-height: 160px;
}

.woocommerce-embed.checkout-loading::after {
	content: 'Preparando checkout...';
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 15px;
	color: #777;
	background: rgba(255, 255, 255, 0.8);
	border-radius: 18px;
}

@media (max-width: 680px) {
	.woocommerce-embed .woocommerce-billing-fields__field-wrapper,
	.woocommerce-embed .woocommerce-shipping-fields__field-wrapper,
	.woocommerce-embed .woocommerce-additional-fields__field-wrapper {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 600px) {
	.form-row {
		flex-direction: column;
		align-items: stretch;
	}

	.form-row .btn {
		width: 100%;
		margin-left: 0;
	}
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 20px;
	border-radius: 999px;
	border: 1px solid #ed1c24;
	background: transparent;
	color: #ed1c24;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s, color 0.2s, box-shadow 0.2s;
	text-decoration: none;
	font-size: 14px;
}

.btn.primary {
	background: #ed1c24;
	color: #ffffff;
}

.btn.primary:hover {
	box-shadow: 0 12px 22px rgba(237, 28, 36, 0.25);
}

.btn.outline {
	border-color: #bdbdbd;
	color: #2a2a2a;
}

.btn.small {
	padding: 8px 14px;
	font-size: 12px;
	margin-bottom:5px;
}

.btn.danger {
	background: #ed1c24;
	color: #ffffff;
	border-color: #ed1c24;
}

.btn.outline.danger {
	background: transparent;
	color: #ed1c24;
	border-color: #ed1c24;
}

.aluno-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px;
	border-radius: 12px;
	border: 1px solid #e0e0e0;
	margin-bottom: 12px;
}

.aluno-item.disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.aluno-item.rematriculado {
	border-color: rgba(46, 204, 113, 0.55);
	background: rgba(46, 204, 113, 0.08);
	cursor: not-allowed;
}

.aluno-item.rematriculado input {
	pointer-events: none;
}

.aluno-item .aluno-info {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.aluno-item .nome {
	font-weight: 600;
	color: #1f1f1f;
}

.aluno-item .curso {
	font-size: 13px;
	color: #757575;
}

.badge-warning {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: rgba(237, 28, 36, 0.12);
	color: #a42318;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 600;
	padding: 2px 10px;
	margin-top: 4px;
}

.badge-success {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: rgba(46, 204, 113, 0.15);
	color: #1d7c3b;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 600;
	padding: 2px 10px;
	margin-top: 4px;
}

.aluno-info-note {
	font-size: 14px;
	color: #6b7280;
	margin-top: 8px;
}

.cliente-matriculas {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.cliente-matricula-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	padding: 14px 18px;
	border-radius: 16px;
	border: 1px solid #e5e7eb;
}

.cliente-matricula-row.success {
	border-color: rgba(46, 204, 113, 0.35);
	background: rgba(46, 204, 113, 0.08);
}

.cliente-matricula-row.pending {
	border-color: rgba(237, 28, 36, 0.2);
}

.cliente-matricula-info .nome {
	font-weight: 600;
	color: #111827;
}

.cliente-matricula-info .muted {
	margin-top: 4px;
	color: #6b7280;
}

#cliente-login-form h3 {
	color:#000;
	font-size:20px;
}

#cliente-login-form .form-row.spaced {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

#cliente-login-form .form-row.spaced button {
	flex: 1 1 100%;
}

#cliente-login-form .note {
	margin-top: 8px;
	font-size: 13px;
	color: #555555;
}

.cliente-matricula-info .muted.warning {
	color: #b45309;
	font-weight: 600;
	font-size:13px;
}

.cliente-matricula-status {
	text-align: right;
	font-size: 13px;
	color: #6b7280;
}

.cliente-matricula-action {
	margin-top: 10px;
}

.status-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	border-radius: 999px;
	font-weight: 600;
	font-size: 12px;
	padding: 4px 12px;
}

.status-pill.success {
	background: rgba(46, 204, 113, 0.15);
	color: #1d7c3b;
}

.status-pill.pending {
	background: rgba(237, 28, 36, 0.12);
	color: #a42318;
}

.cliente-matricula-status small {
	display: block;
	margin-top: 6px;
}

@media (max-width: 768px) {
	.cliente-matricula-row {
		flex-direction: column;
		align-items: flex-start;
	}

	.cliente-matricula-status {
		text-align: left;
	}
}

.financeiro-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.financeiro-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	padding: 16px 20px;
	border: 1px solid #e5e7eb;
	border-radius: 16px;
	background: #fff;
}

.financeiro-row .nome {
	font-weight: 600;
	color: #111827;
}

.financeiro-row .muted {
	margin-top: 4px;
	color: #6b7280;
}

.financeiro-row .valor {
	margin-top: 6px;
	color: #111827;
	font-size: 14px;
}

.financeiro-row .btn {
	white-space: nowrap;
}

.financeiro-col.info {
	flex: 1;
}

.financeiro-col.actions {
	display: flex;
	justify-content: flex-end;
	align-items: flex-start;
}

.financeiro-row.open {
	align-items: flex-start;
	flex-wrap: wrap;
}

.financeiro-row.open .financeiro-opcoes {
	flex-basis: 100%;
	width: 100%;
	margin-top: 12px;
}

.opcoes-pagamento {
	min-width: 190px;
}

@media (max-width: 768px) {
	.financeiro-row {
		flex-direction: column;
		align-items: stretch;
	}

	.opcoes-pagamento {
		width: 100%;
	}
}

.materiais-list {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.material-row {
	border: 1px solid #e5e7eb;
	border-radius: 16px;
	padding: 16px 20px;
	background: #fff;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.material-row .material-head {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 10px;
}

.material-row .material-head .nome {
	font-weight: 600;
	color: #111827;
}

.material-row .material-meta {
	font-size: 13px;
	color: #6b7280;
}

.material-row .material-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 8px;
}

.material-row .btn[disabled] {
	opacity: 0.6;
	cursor: not-allowed;
}

.material-status {
	font-size: 12px;
	color: #16a34a;
	font-weight: 600;
}

.checkout-host {
	width: 100%;
}

.periodo-status.pending {
	display: block;
	margin-top: 8px;
	font-size: 13px;
	color: #6f6f6f;
}

.periodo-card label {
	display: flex;
	align-items: center;
	gap: 8px;
	font-weight: 500;
}

.lista .linha {
	display: grid;
	grid-template-columns: 1fr 1fr auto;
	gap: 12px;
	padding: 12px 0;
	border-bottom: 1px solid #eaeaea;
}

.lista .linha .nome {
	font-weight: 600;
}

.lista .linha .valor {
	font-weight: 600;
	text-align: right;
}

.total {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 16px;
	padding-top: 12px;
	border-top: 1px solid #eaeaea;
	font-weight: 600;
}

.metodos-pagamento label {
	display: block;
	margin-bottom: 10px;
	font-weight: 500;
}

.muted {
	color: #6f6f6f;
}

.parental-discount {
	color: #039f02;
	font-size: 13px;
	font-weight: 600;
	margin-top: 6px;
}

.credit-note {
	color: #039f02;
	font-size: 13px;
	font-weight: 600;
	margin-top: 4px;
}

.financeiro-actions {
	margin-top: 8px;
	display: flex;
	justify-content: flex-end;
}

.financeiro-actions.stacked {
	justify-content: flex-start;
}

.financeiro-opcoes {
	margin-top: 12px;
	padding: 12px;
	border: 1px solid #e5e7eb;
	border-radius: 10px;
	background: #f9fafb;
}

.financeiro-opcoes .form-control {
	margin-bottom: 10px;
}

.financeiro-opcoes select {
	width: 100%;
	padding: 10px 12px;
	border-radius: 8px;
	border: 1px solid #d1d5db;
	font-size: 14px;
}

.parcelas-preview {
	margin-top: 8px;
}

#cliente-login-form .form-row .btn {
	margin-left:0px!important;
}

#cliente-login-form #cliente-login-senha {
	border: 1px solid #d0d0d0;
	border-radius:10px;
	width:100%;
	padding:12px 14px;
}

.parcelas-preview .table td:last-child {
	white-space: nowrap;
}

.parcelas-preview .table td .btn {
	margin-left: 10px;
}

.financeiro-confirm {
	margin-top: 12px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	align-items: flex-start;
}

.financeiro-confirm .confirm-text {
	color: #374151;
	font-size: 13px;
}

.financeiro-confirm-actions {
	display: flex;
	gap: 8px;
}

.credit-form {
	margin-bottom: 20px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.credit-search-row {
	display: flex;
	gap: 12px;
	align-items: center;
}

.credit-search-row input {
	flex: 1;
}

.credit-search-row input {
	width: 100%;
	border: 1px solid #e0e0e0;
	border-radius: 12px;
	padding: 12px 14px;
	font-size: 14px;
	background: #fff;
}

.credit-search-row input:focus {
	border-color: #8a8a8a;
	outline: none;
}

.bonus-form .input-copy {
	margin-top: 6px;
}

.indicacao-landing {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 60vh;
	background: #f5f7fb;
	padding: 24px;
}

.indicacao-landing.hidden {
	display: none;
}

.indicacao-card {
	max-width: 520px;
	width: 100%;
	background: #fff;
	border: 1px solid #e0e0e0;
	border-radius: 16px;
	padding: 24px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
}

.indicacao-logo {
	display: block;
	height: 48px;
	margin: 0 auto 12px;
}

.indicacao-form {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.indicacao-form input {
	width: 100%;
	box-sizing: border-box;
	border: 1px solid #e0e0e0;
	border-radius: 12px;
	padding: 12px 14px;
	font-size: 14px;
	background: #fff;
}

.indicacao-form button {
	width: 100%;
	box-sizing: border-box;
}

.indicacao-form input:focus {
	border-color: #8a8a8a;
	outline: none;
}

.indicacao-form .note:empty {
	display: none;
}

#parental-feedback:empty,
#bonus-feedback:empty {
	display: none;
}

.template-vars {
	margin-top: 10px;
	padding: 10px 12px;
	background: #f9fafb;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	font-size: 12px;
	color: #4b5563;
}

.template-vars ul {
	margin: 6px 0 0 16px;
	padding: 0;
}

.template-vars li {
	line-height: 1.5;
}

.ci-portal.indicacao-mode {
	display: block;
	padding: 0;
}

.ci-portal.indicacao-mode .main,
.ci-portal.indicacao-mode .sidebar {
	display: none !important;
}

.ci-portal.indicacao-mode #indicacao-landing {
	display: flex !important;
	padding: 32px 16px;
	min-height: 60vh;
}

.credit-search-results {
	display: none;
	margin-top: 8px;
	border: 1px solid #e3e3e3;
	border-radius: 10px;
	padding: 8px 12px;
	background: #fafafa;
}

.credit-search-results.visible {
	display: block;
}

.input-copy {
	display: flex;
	gap: 8px;
	align-items: center;
}
.input-copy input {
	width: 100%;
}

.credit-result-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 8px 0;
	border-bottom: 1px solid #ededed;
}

.credit-result-item:last-child {
	border-bottom: 0;
}

.credit-selected {
	border: 1px solid #cddffd;
	background: #f5f8ff;
	border-radius: 10px;
	padding: 12px;
}

.credit-selected.hidden {
	display: none;
}

.credit-inputs {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}

.credit-inputs > div {
	flex: 1;
	min-width: 220px;
}

.curso.muted {
	font-size:14px;
	margin-bottom:20px;
}
table thead:first-child tr:first-child th {
	border-block-start:none;
}
.note {
	padding: 10px 12px;
	border-radius: 10px;
	background: #f3f3f3;
	font-size: 13px;
	margin-top: 10px;
}

.wysiwyg {
	border: 1px solid #d6d6d6;
	border-radius: 12px;
	overflow: hidden;
	margin-top: 12px;
}

.wysiwyg .toolbar {
	display: flex;
	gap: 4px;
	padding: 8px;
	background: #fafafa;
	border-bottom: 1px solid #e0e0e0;
}

.wysiwyg .toolbar button {
	border: none;
	background: #ffffff;
	border-radius: 8px;
	padding: 6px 10px;
	cursor: pointer;
	font-size: 13px;
	box-shadow: inset 0 0 0 1px #e0e0e0;
}

.wysiwyg .editor {
	min-height: 140px;
	padding: 14px;
	font-size: 14px;
	line-height: 1.5;
}

.table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	border: 1px solid #f1f1f1;
	border-radius:14px;
	overflow: hidden;
	background: #ffffff;
}

.table th,
.table td {
	padding: 14px 16px;
	text-align: left;
	font-size: 14px;
	vertical-align: middle;
	border:none;
}

.table th {
	font-weight: 600;
	color: #1d1d1d;
	background: #ffebeb;
}

.table tbody tr:last-child td {
	border-bottom: none;
}

.table td small {
	display: block;
	font-size: 12px;
	color: #686868;
	margin-top: 4px;
}

.table td.actions {
	display: flex;
	flex-direction: column;
	gap: 8px;
	align-items: center;
	justify-content: center;
	gap: 6px;
}

.tag {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	background: #f0f0f0;
	font-size: 12px;
	font-weight: 600;
	color: #333333;
}

.tag.status-pendente {
	background: rgba(255, 193, 7, 0.2);
	color: #795548;
}

.tag.status-efetivada {
	background: rgba(76, 175, 80, 0.2);
	color: #256029;
}

.tag.status-analise {
	background: rgba(33, 150, 243, 0.2);
	color: #0b60a7;
}

#tabela-rematriculas {
	table-layout: fixed;
}

#tabela-rematriculas th,
#tabela-rematriculas td {
	font-size: 13px;
	line-height: 1.4;
	word-break: break-word;
	white-space: normal;
}

#tabela-rematriculas th:nth-child(1),
#tabela-rematriculas td:nth-child(1) {
	width: 30%;
}

#tabela-rematriculas th:nth-child(2),
#tabela-rematriculas td:nth-child(2) {
	width: 26%;
}

#tabela-rematriculas th:nth-child(3),
#tabela-rematriculas td:nth-child(3) {
	width: 16%;
}

#tabela-rematriculas th:nth-child(4),
#tabela-rematriculas td:nth-child(4) {
	width: 12%;
}

#tabela-rematriculas th:nth-child(5),
#tabela-rematriculas td:nth-child(5) {
	width: 16%;
}

.rematricula-aluno {
	display: flex;
	flex-direction: column;
	margin-bottom: 6px;
}

.rematricula-aluno:last-child {
	margin-bottom: 0;
}

.rematricula-aluno strong {
	font-weight: 600;
	color: #111;
}

.rematricula-aluno small {
	color: #6f6f6f;
	font-size: 12px;
}

.pedido-label {
	display: block;
	color: #4f4f4f;
	font-size: 12px;
	margin: 2px 0 6px;
}

.rematricula-contratacao {
	background: #f4f6fb;
	border-radius: 8px;
	padding: 6px 10px;
	font-size: 13px;
	margin-bottom: 6px;
}

.rematricula-contratacao:last-child {
	margin-bottom: 0;
}

.link-danger {
	color: #ed1c24;
	font-weight: 600;
	display: inline-block;
	margin-top: 4px;
}

.link-danger:hover {
	text-decoration: underline;
}

.order-details-row td {
	background: #f9f9f9;
	padding: 18px 20px;
}

.order-details-card {
	background: #ffffff;
	border: 1px solid #e4e4e4;
	border-radius: 12px;
	padding: 20px;
}

.order-details-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin-bottom: 20px;
}

.order-details-grid > div {
	flex: 1 1 260px;
}

.order-details-card h4 {
	font-size: 15px;
	margin-bottom: 8px;
	color: #2b2b2b;
}

.order-details-card ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.order-details-card li {
	font-size: 13px;
	color: #444;
	margin-bottom: 4px;
}

.order-details-card li:last-child {
	margin-bottom: 0;
}

.order-details-entries {
	margin-top: 6px;
}

.order-details-entries h4 {
	font-size: 15px;
	margin-bottom: 10px;
}

.detail-entry {
	display: flex;
	justify-content: space-between;
	gap: 20px;
	padding: 10px 0;
	border-top: 1px solid #ececec;
}

.detail-entry:first-of-type {
	border-top: none;
	padding-top: 0;
}

.detail-entry p {
	margin: 2px 0;
	font-size: 13px;
	color: #4b4b4b;
}

.detail-entry .valor {
	font-weight: 600;
}

.status-pair {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.status-pair label {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #6f6f6f;
}

.status-pair select {
	width: 100%;
}

#tabela-usuarios {
	table-layout: fixed;
}

#tabela-usuarios th,
#tabela-usuarios td {
	font-size: 13px;
	line-height: 1.4;
	word-break: break-word;
}

#tabela-usuarios th:nth-child(1),
#tabela-usuarios td:nth-child(1) {
	width: 22%;
}

#tabela-usuarios th:nth-child(2),
#tabela-usuarios td:nth-child(2) {
	width: 28%;
}

#tabela-usuarios th:nth-child(3),
#tabela-usuarios td:nth-child(3) {
	width: 18%;
}

#tabela-usuarios th:nth-child(4),
#tabela-usuarios td:nth-child(4) {
	width: 20%;
}

#tabela-usuarios th:nth-child(5),
#tabela-usuarios td:nth-child(5) {
	width: 12%;
}

.ci-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 18px;
}

.ci-grid .card3 {
	margin: 0;
}

.ci-inline-actions {
	display: flex;
	gap: 12px;
	margin-top: 16px;
	flex-wrap: wrap;
}

.ci-inline-actions.spaced {
	margin-bottom: 20px;
}

.success-view {
	text-align: center;
	padding: 60px 30px;
}

.success-view .icon-check {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #ed1c24;
	color: #ffffff;
	border-radius: 50%;
	width: 80px;
	height: 80px;
	font-size: 36px;
	margin-bottom: 20px;
}

.ci-toast {
	position: fixed;
	right: 24px;
	bottom: 24px;
	background: #151515;
	color: #ffffff;
	padding: 14px 18px;
	border-radius: 12px;
	box-shadow: 0 18px 36px rgba(0, 0, 0, 0.2);
	opacity: 0;
	transform: translateY(20px);
	pointer-events: none;
	transition: opacity 0.3s ease, transform 0.3s ease;
	z-index: 999;
	font-size: 14px;
}

.ci-toast.visible {
	opacity: 1;
	transform: translateY(0);
}

.ci-portal.admin-mode .front-nav,
.ci-portal.admin-mode #toggle-cliente-login {
	display: none !important;
}

.ci-portal.admin-mode .admin-nav {
	display: block !important;
}

.woocommerce-embed {
	margin-top: 16px;
}

.ci-admin-login {
	max-width: 640px;
	margin: 32px auto;
}

@media (max-width: 960px) {
	.ci-portal {
		flex-direction: column;
	}

	.ci-portal .sidebar {
		width: 100%;
		flex-direction: row;
		overflow-x: auto;
		padding: 16px;
	}

	.ci-portal .sidebar .nav-group {
		min-width: 160px;
	}

	.ci-portal .main {
		padding: 20px;
	}
}
.ci-admin-login {
	padding: 40px 20px;
	display: flex;
	justify-content: center;
}

.ci-admin-login .card3 {
	max-width: 640px;
	width: 100%;
}

.ci-admin-login .form-control input {
	width: 100%;
}
.table td.actions .btn {
	padding: 8px 16px;
	font-size: 12px;
}
.nav-pending {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #f59e0b;
	color: #fff;
	font-size: 10px;
	font-weight: 600;
	padding: 2px 8px;
	border-radius: 999px;
	margin-left: 8px;
}
