/* ============================================================
 * Calculadora de Aviso Previo MZ  -  frontend (v1.0.0)
 *
 * Design: DM Sans + DM Serif Display, teal/dourado, layout limpo.
 * ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=DM+Sans:wght@400;500;600;700&display=swap');

.cap-wrapper * { margin: 0; padding: 0; box-sizing: border-box; }

.cap-wrapper {
	--cap-primary: #13919B;
	--cap-primary-dark: #0F7A83;
	--cap-primary-light: #E8F6F7;
	--cap-primary-glow: rgba(19, 145, 155, 0.08);
	--cap-secondary: #BC9266;
	--cap-secondary-dark: #A77B4F;
	--cap-secondary-light: #FBF5EE;
	--cap-secondary-glow: rgba(188, 146, 102, 0.1);
	--cap-bg: #FFFFFF;
	--cap-surface: #F7F8FA;
	--cap-surface2: #F0F1F4;
	--cap-border: #DFE2E8;
	--cap-text: #1A2B2D;
	--cap-text-dim: #5A6B6E;
	--cap-text-muted: #8A969A;
	--cap-success: #1E8F4E;
	--cap-warning: #B8770F;
	--cap-danger: #D94444;
	--cap-radius: 14px;
	--cap-radius-sm: 10px;

	font-family: 'DM Sans', sans-serif;
	color: var(--cap-text);
	max-width: 760px;
	margin: 0 auto;
	padding: 40px 20px 60px;
	background: transparent;
	line-height: 1.5;
}

/* ============ Cabecalho ============ */
.cap-wrapper .cap-header {
	text-align: center;
	margin-bottom: 28px;
}
.cap-wrapper .cap-badge {
	display: inline-block;
	font-size: 11px; font-weight: 600;
	letter-spacing: 1.5px; text-transform: uppercase;
	color: var(--cap-primary);
	background: var(--cap-primary-light);
	border: 1px solid rgba(19,145,155,0.15);
	padding: 6px 16px; border-radius: 100px;
	margin-bottom: 16px;
}
.cap-wrapper .cap-header h1 {
	font-family: 'DM Serif Display', serif;
	font-size: clamp(26px, 5vw, 38px);
	font-weight: 400; line-height: 1.15;
	margin-bottom: 10px;
	color: var(--cap-text);
}
.cap-wrapper .cap-header h1 span { color: var(--cap-primary); }
.cap-wrapper .cap-header p {
	font-size: 15px; color: var(--cap-text-dim);
	max-width: 540px; margin: 0 auto; line-height: 1.6;
}

/* ============ Barra de estado ============ */
.cap-wrapper .cap-barra-estado {
	display: flex; align-items: center; justify-content: space-between;
	flex-wrap: wrap; gap: 12px;
	background: var(--cap-primary);
	color: #fff;
	padding: 12px 20px;
	border-radius: var(--cap-radius);
	margin-bottom: 18px;
	box-shadow: 0 4px 14px rgba(19,145,155,0.18);
}
.cap-wrapper .cap-estado-user {
	display: inline-flex; align-items: center; gap: 8px;
	font-size: 14px; font-weight: 600;
}
.cap-wrapper .cap-estado-dot {
	width: 8px; height: 8px; border-radius: 50%;
	background: #65d68b;
	box-shadow: 0 0 0 3px rgba(101,214,139,0.25);
}
.cap-wrapper .cap-estado-badge {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 7px 14px; border-radius: 100px;
	font-size: 13px; font-weight: 600;
}
.cap-wrapper .cap-estado-pro {
	background: linear-gradient(135deg, var(--cap-secondary) 0%, var(--cap-secondary-dark) 100%);
	color: #fff;
}
.cap-wrapper .cap-estado-creditos {
	background: linear-gradient(135deg, #f4b73e 0%, #d49228 100%);
	color: #fff;
}
.cap-wrapper .cap-estado-creditos small {
	opacity: 0.9; font-weight: 600; font-size: 11px;
	margin-left: 3px;
}
.cap-wrapper .cap-estado-free {
	background: rgba(255,255,255,0.18); color: #fff;
}
.cap-wrapper .cap-estado-aviso {
	background: rgba(255,235,140,0.22); color: #fff;
}

/* ============ Aviso de uso ============ */
.cap-wrapper .cap-aviso-uso {
	margin-bottom: 16px;
	padding: 11px 16px;
	background: var(--cap-primary-light);
	border-left: 3px solid var(--cap-primary);
	border-radius: 0 8px 8px 0;
	color: var(--cap-text-dim);
	font-size: 13.5px;
	animation: cap-slideUp 0.3s ease;
}
@keyframes cap-slideUp {
	from { opacity: 0; transform: translateY(-6px); }
	to { opacity: 1; transform: translateY(0); }
}

/* ============ Toggle tabela sectores ============ */
.cap-wrapper .cap-table-toggle {
	display: flex; align-items: center; justify-content: center; gap: 8px;
	width: 100%; padding: 12px;
	background: var(--cap-bg);
	border: 1px solid var(--cap-border);
	border-radius: var(--cap-radius);
	color: var(--cap-text-dim);
	font-family: 'DM Sans', sans-serif;
	font-size: 13px; font-weight: 500;
	cursor: pointer; transition: all 0.2s;
	margin-bottom: 14px;
}
.cap-wrapper .cap-table-toggle:hover {
	border-color: var(--cap-primary);
	color: var(--cap-text);
}
.cap-wrapper .cap-table-toggle .cap-arrow {
	transition: transform 0.3s;
	font-size: 11px;
}
.cap-wrapper .cap-table-toggle.cap-open .cap-arrow {
	transform: rotate(180deg);
}
.cap-wrapper .cap-sector-table-wrap {
	max-height: 0; overflow: hidden;
	transition: max-height 0.4s ease;
}
.cap-wrapper .cap-sector-table-wrap.cap-open {
	max-height: 900px;
}
.cap-wrapper .cap-sector-table {
	width: 100%; border-collapse: collapse;
	background: var(--cap-bg);
	border: 1px solid var(--cap-border);
	border-radius: var(--cap-radius);
	overflow: hidden;
	margin-bottom: 16px;
	font-size: 13px;
}
.cap-wrapper .cap-sector-table thead th {
	background: var(--cap-surface);
	padding: 10px 14px; text-align: left;
	font-weight: 600; font-size: 11px;
	text-transform: uppercase; letter-spacing: 0.7px;
	color: var(--cap-text-muted);
	border-bottom: 1px solid var(--cap-border);
}
.cap-wrapper .cap-sector-table thead th:last-child { text-align: right; }
.cap-wrapper .cap-sector-table tbody td {
	padding: 9px 14px;
	border-bottom: 1px solid var(--cap-surface2);
	color: var(--cap-text-dim);
}
.cap-wrapper .cap-sector-table tbody td:last-child {
	text-align: right; font-weight: 600;
	color: var(--cap-text); white-space: nowrap;
}
.cap-wrapper .cap-sector-table tbody tr:last-child td { border-bottom: none; }
.cap-wrapper .cap-sector-table tbody tr:hover td { background: var(--cap-primary-light); }

/* ============ Card de formulario ============ */
.cap-wrapper .cap-card {
	background: var(--cap-bg);
	border: 1px solid var(--cap-border);
	border-radius: var(--cap-radius);
	padding: 28px 24px;
	margin-bottom: 16px;
	box-shadow: 0 1px 4px rgba(0,0,0,0.04);
}
.cap-wrapper .cap-card-title {
	font-size: 12px; font-weight: 600;
	letter-spacing: 0.8px; text-transform: uppercase;
	color: var(--cap-text-muted);
	margin-bottom: 22px;
	display: flex; align-items: center; gap: 8px;
}
.cap-wrapper .cap-card-dot {
	width: 6px; height: 6px; border-radius: 50%;
	background: var(--cap-primary);
}
.cap-wrapper .cap-field { margin-bottom: 20px; }
.cap-wrapper .cap-field:last-child { margin-bottom: 0; }
.cap-wrapper .cap-field label {
	display: block;
	font-size: 14px; font-weight: 500;
	color: var(--cap-text-dim);
	margin-bottom: 6px;
}
.cap-wrapper .cap-input-wrap {
	position: relative; display: flex; align-items: center;
}
.cap-wrapper .cap-prefix {
	position: absolute; left: 14px;
	font-size: 14px; font-weight: 600;
	color: var(--cap-text-muted); pointer-events: none;
}
.cap-wrapper .cap-suffix {
	position: absolute; right: 14px;
	font-size: 13px; color: var(--cap-text-muted);
	pointer-events: none;
}
.cap-wrapper input[type="number"],
.cap-wrapper input[type="text"],
.cap-wrapper input[type="email"],
.cap-wrapper input[type="tel"],
.cap-wrapper input[type="date"],
.cap-wrapper select,
.cap-wrapper textarea {
	width: 100%;
	background: var(--cap-bg);
	border: 1.5px solid var(--cap-border);
	border-radius: var(--cap-radius-sm);
	padding: 12px 14px;
	font-family: 'DM Sans', sans-serif;
	font-size: 15px; font-weight: 500;
	color: var(--cap-text);
	outline: none; transition: all 0.2s;
	-moz-appearance: textfield;
}
.cap-wrapper input[type="number"]::-webkit-inner-spin-button,
.cap-wrapper input[type="number"]::-webkit-outer-spin-button { -webkit-appearance: none; }
.cap-wrapper input:focus, .cap-wrapper select:focus, .cap-wrapper textarea:focus {
	border-color: var(--cap-primary);
	box-shadow: 0 0 0 3px var(--cap-primary-glow);
}
.cap-wrapper .cap-has-prefix input { padding-left: 48px; }
.cap-wrapper select {
	appearance: none; cursor: pointer;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235A6B6E' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat; background-position: right 12px center;
	background-color: var(--cap-bg);
	padding-right: 38px;
}

.cap-wrapper .cap-sector-chip {
	display: inline-flex; align-items: center; gap: 6px;
	margin-top: 6px; padding: 5px 10px;
	background: var(--cap-primary-light);
	border: 1px solid rgba(19,145,155,0.15);
	border-radius: 6px;
	font-size: 12px; color: var(--cap-primary);
	font-weight: 600;
}
.cap-wrapper .cap-sector-chip .cap-chip-label {
	font-weight: 400; color: var(--cap-text-dim);
}

.cap-wrapper .cap-row2 {
	display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.cap-wrapper .cap-row3 {
	display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px;
}
@media (max-width: 540px) {
	.cap-wrapper .cap-row2, .cap-wrapper .cap-row3 {
		grid-template-columns: 1fr;
	}
}

/* ============ Botao calcular ============ */
.cap-wrapper .cap-btn-calc {
	width: 100%; padding: 14px;
	background: var(--cap-primary); color: #fff;
	font-family: 'DM Sans', sans-serif;
	font-size: 15px; font-weight: 700;
	border: none; border-radius: var(--cap-radius-sm);
	cursor: pointer; transition: all 0.2s;
	margin-top: 6px;
}
.cap-wrapper .cap-btn-calc:hover {
	background: var(--cap-primary-dark);
	box-shadow: 0 4px 16px rgba(19,145,155,0.25);
}
.cap-wrapper .cap-btn-calc:active { transform: scale(0.99); }
.cap-wrapper .cap-btn-calc.cap-ocupado { opacity: 0.6; cursor: wait; }

.cap-wrapper .cap-error-msg {
	display: none;
	padding: 10px 14px;
	background: #FEF2F2;
	border: 1px solid #FECACA;
	border-radius: 8px;
	color: var(--cap-danger);
	font-size: 13px;
	margin-top: 10px;
	animation: cap-slideUp 0.3s ease;
}
.cap-wrapper .cap-error-msg.cap-visible { display: block; }

/* ============ Card de resultado ============ */
.cap-wrapper .cap-result-card {
	background: var(--cap-bg);
	border: 2px solid var(--cap-secondary);
	border-radius: var(--cap-radius);
	padding: 28px 24px;
	margin-top: 20px;
	display: none;
	box-shadow: 0 2px 12px rgba(188,146,102,0.12);
}
.cap-wrapper .cap-result-card.cap-visible {
	display: block;
	animation: cap-slideUpBig 0.35s ease;
}
@keyframes cap-slideUpBig {
	from { opacity: 0; transform: translateY(12px); }
	to { opacity: 1; transform: translateY(0); }
}
.cap-wrapper .cap-result-header {
	text-align: center; margin-bottom: 24px;
}
.cap-wrapper .cap-result-label {
	font-size: 12px; font-weight: 600;
	letter-spacing: 1px; text-transform: uppercase;
	color: var(--cap-secondary);
	margin-bottom: 6px;
}
.cap-wrapper .cap-result-amount {
	font-family: 'DM Serif Display', serif;
	font-size: clamp(30px, 6vw, 46px);
	line-height: 1.1;
	color: var(--cap-text);
}
.cap-wrapper .cap-result-amount small {
	font-size: 0.5em; color: var(--cap-text-muted);
	font-family: 'DM Sans', sans-serif; font-weight: 500;
}
.cap-wrapper .cap-result-divider {
	height: 1px; background: var(--cap-border);
	margin: 20px 0;
}

/* Step blocks */
.cap-wrapper .cap-step-block {
	background: var(--cap-surface);
	border: 1px solid var(--cap-border);
	border-radius: 10px;
	padding: 18px;
	margin-bottom: 10px;
}
.cap-wrapper .cap-sb-header {
	display: flex; align-items: center; gap: 10px;
	margin-bottom: 10px;
}
.cap-wrapper .cap-sb-num {
	flex-shrink: 0;
	width: 26px; height: 26px;
	border-radius: 50%;
	background: var(--cap-primary-light);
	border: 1px solid rgba(19,145,155,0.2);
	display: flex; align-items: center; justify-content: center;
	font-size: 12px; font-weight: 700;
	color: var(--cap-primary);
}
.cap-wrapper .cap-sb-title {
	font-size: 13px; font-weight: 600;
	color: var(--cap-text);
}
.cap-wrapper .cap-sb-calc {
	background: var(--cap-bg);
	border: 1px solid var(--cap-border);
	border-radius: 8px;
	padding: 12px 14px;
	line-height: 1.8;
}
.cap-wrapper .cap-line {
	display: flex; justify-content: space-between; align-items: center;
}
.cap-wrapper .cap-line-label {
	color: var(--cap-text-muted); font-size: 13px;
}
.cap-wrapper .cap-line-value {
	font-weight: 600; color: var(--cap-text);
	font-size: 14px;
}
.cap-wrapper .cap-line-op {
	color: var(--cap-text-muted);
	font-size: 13px; text-align: center;
	padding: 2px 0; letter-spacing: 2px;
}
.cap-wrapper .cap-line-result {
	border-top: 1px solid var(--cap-border);
	padding-top: 8px; margin-top: 4px;
}
.cap-wrapper .cap-line-result .cap-line-value {
	color: var(--cap-primary); font-size: 16px; font-weight: 700;
}

/* Total block */
.cap-wrapper .cap-total-block {
	background: var(--cap-secondary-light);
	border: 1.5px solid rgba(188,146,102,0.3);
	border-radius: 10px;
	padding: 18px;
	margin-top: 6px;
}
.cap-wrapper .cap-total-block .cap-sb-num {
	background: var(--cap-secondary);
	color: #fff; border: none;
}
.cap-wrapper .cap-total-block .cap-sb-calc {
	border-color: rgba(188,146,102,0.2);
}
.cap-wrapper .cap-total-block .cap-line-result {
	border-top-color: rgba(188,146,102,0.3);
	border-top-width: 1.5px;
}
.cap-wrapper .cap-total-block .cap-line-result .cap-line-label {
	color: var(--cap-secondary); font-weight: 600;
}
.cap-wrapper .cap-total-block .cap-line-result .cap-line-value {
	color: var(--cap-secondary); font-size: 18px;
}

.cap-wrapper .cap-legal-note {
	margin-top: 18px;
	padding: 14px;
	background: var(--cap-primary-light);
	border-left: 3px solid var(--cap-primary);
	border-radius: 0 8px 8px 0;
	font-size: 12.5px; line-height: 1.6;
	color: var(--cap-text-dim);
}
.cap-wrapper .cap-legal-note strong {
	color: var(--cap-text); font-weight: 600;
}

/* ============ Rodape ============ */
.cap-wrapper .cap-footer {
	text-align: center; margin-top: 32px;
	padding-top: 20px;
	border-top: 1px solid var(--cap-border);
	font-size: 11.5px; color: var(--cap-text-muted);
	line-height: 1.7;
}
.cap-wrapper .cap-footer strong { color: var(--cap-text-dim); }

/* ============================================================
 * PAYWALL PAGO
 * ============================================================ */
.cap-wrapper .cap-paywall {
	background: var(--cap-bg);
	border: 2px solid var(--cap-secondary);
	border-radius: var(--cap-radius);
	padding: 32px 28px;
	margin-bottom: 16px;
	box-shadow: 0 2px 12px rgba(188,146,102,0.12);
}
.cap-wrapper .cap-paywall-cabecalho {
	text-align: center; margin-bottom: 26px;
}
.cap-wrapper .cap-paywall-icone {
	display: inline-flex; align-items: center; justify-content: center;
	width: 64px; height: 64px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--cap-secondary) 0%, var(--cap-secondary-dark) 100%);
	color: #fff; font-size: 26px;
	margin-bottom: 16px;
	box-shadow: 0 6px 18px rgba(188,146,102,0.25);
}
.cap-wrapper .cap-paywall-cabecalho h3 {
	font-family: 'DM Serif Display', serif;
	font-size: 26px; font-weight: 400;
	margin-bottom: 8px;
	color: var(--cap-text);
}
.cap-wrapper .cap-paywall-cabecalho p {
	color: var(--cap-text-dim);
	max-width: 480px; margin: 0 auto;
	font-size: 14.5px; line-height: 1.6;
}

.cap-wrapper .cap-pacotes {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 14px;
	margin-bottom: 22px;
}
.cap-wrapper .cap-pacote {
	background: var(--cap-bg);
	border: 1.5px solid var(--cap-border);
	border-radius: var(--cap-radius);
	padding: 22px 18px;
	position: relative;
	transition: all 0.25s ease;
}
.cap-wrapper .cap-pacote:hover {
	border-color: var(--cap-primary);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0,0,0,0.07);
}
.cap-wrapper .cap-pacote-destaque {
	border-color: var(--cap-secondary);
	border-width: 2px;
	background: linear-gradient(180deg, var(--cap-secondary-light) 0%, var(--cap-bg) 50%);
}
.cap-wrapper .cap-pacote-fita {
	position: absolute; top: -10px; left: 50%;
	transform: translateX(-50%);
	background: var(--cap-secondary);
	color: #fff;
	font-size: 10.5px; font-weight: 700;
	letter-spacing: 0.8px; text-transform: uppercase;
	padding: 4px 12px; border-radius: 100px;
	box-shadow: 0 3px 10px rgba(188,146,102,0.3);
}
.cap-wrapper .cap-pacote-nome {
	font-size: 14px; font-weight: 700;
	color: var(--cap-text);
	margin-bottom: 6px;
	letter-spacing: 0.2px;
}
.cap-wrapper .cap-pacote-preco {
	font-family: 'DM Serif Display', serif;
	font-size: 30px; line-height: 1.2;
	color: var(--cap-secondary);
	margin-bottom: 4px;
}
.cap-wrapper .cap-pacote-periodo {
	font-size: 11px; color: var(--cap-text-muted);
	text-transform: uppercase; letter-spacing: 0.6px;
	font-weight: 600;
	margin-bottom: 12px;
}
.cap-wrapper .cap-pacote-descricao {
	font-size: 13px; color: var(--cap-text-dim);
	margin-bottom: 16px; line-height: 1.5;
	min-height: 36px;
}
.cap-wrapper .cap-btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: 6px; padding: 10px 14px;
	border-radius: var(--cap-radius-sm);
	font-family: 'DM Sans', sans-serif;
	font-weight: 600; font-size: 13.5px;
	text-decoration: none; border: none;
	cursor: pointer; transition: all 0.2s;
	width: 100%;
}
.cap-wrapper .cap-btn-whatsapp {
	background: #25d366; color: #fff;
}
.cap-wrapper .cap-btn-whatsapp:hover {
	background: #1ebe57; transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(37,211,102,0.3);
}
.cap-wrapper .cap-btn-primario {
	background: var(--cap-primary); color: #fff;
}
.cap-wrapper .cap-btn-primario:hover {
	background: var(--cap-primary-dark);
	box-shadow: 0 4px 12px rgba(19,145,155,0.25);
}

.cap-wrapper .cap-passos-subscricao {
	background: var(--cap-primary-light);
	border-radius: 10px;
	padding: 18px 20px;
	margin-bottom: 18px;
}
.cap-wrapper .cap-passos-subscricao h4 {
	font-size: 13px; font-weight: 700;
	color: var(--cap-primary);
	margin-bottom: 10px; text-transform: uppercase;
	letter-spacing: 0.7px;
}
.cap-wrapper .cap-passos-subscricao ol {
	margin-left: 18px; font-size: 13.5px;
	color: var(--cap-text-dim); line-height: 1.6;
}
.cap-wrapper .cap-passos-subscricao li { margin-bottom: 4px; }

.cap-wrapper .cap-resgate {
	background: var(--cap-surface);
	border: 1px dashed var(--cap-border);
	border-radius: 10px;
	padding: 18px 20px;
}
.cap-wrapper .cap-resgate h4 {
	font-size: 13px; font-weight: 700;
	color: var(--cap-text); margin-bottom: 10px;
	text-transform: uppercase; letter-spacing: 0.7px;
}
.cap-wrapper .cap-resgate-form {
	display: flex; gap: 8px;
}
.cap-wrapper .cap-resgate-form input {
	flex: 1;
	text-transform: uppercase;
	font-family: ui-monospace, 'SF Mono', monospace;
}
.cap-wrapper .cap-resgate-form button {
	width: auto; padding: 12px 18px;
}
.cap-wrapper .cap-resgate-msg {
	margin-top: 10px; font-size: 13px;
	color: var(--cap-text-dim);
}
.cap-wrapper .cap-resgate-msg.cap-erro { color: var(--cap-danger); }
.cap-wrapper .cap-resgate-msg.cap-ok { color: var(--cap-success); font-weight: 600; }

/* ============================================================
 * REFERRAL PANEL
 * ============================================================ */
.cap-wrapper .cap-referral {
	background: var(--cap-bg);
	border: 1px solid var(--cap-border);
	border-radius: var(--cap-radius);
	padding: 22px 24px;
	margin-bottom: 16px;
	box-shadow: 0 1px 4px rgba(0,0,0,0.04);
}
.cap-wrapper .cap-referral-paywall {
	margin: 22px 0;
	background: linear-gradient(135deg, var(--cap-secondary-light) 0%, #fff5d6 100%);
	border-color: rgba(188,146,102,0.4);
	border-left: 4px solid var(--cap-secondary);
}
.cap-wrapper .cap-referral-cabecalho {
	display: flex; align-items: flex-start; gap: 14px;
	margin-bottom: 18px;
}
.cap-wrapper .cap-referral-icone {
	flex-shrink: 0;
	width: 44px; height: 44px; border-radius: 50%;
	background: linear-gradient(135deg, var(--cap-secondary) 0%, var(--cap-secondary-dark) 100%);
	color: #fff; font-size: 19px;
	display: flex; align-items: center; justify-content: center;
	box-shadow: 0 2px 6px rgba(188,146,102,0.25);
}
.cap-wrapper .cap-referral-titulo h4 {
	margin: 0 0 4px;
	font-family: 'DM Sans', sans-serif;
	font-size: 16px; font-weight: 700;
	color: var(--cap-text);
}
.cap-wrapper .cap-referral-titulo p {
	margin: 0;
	font-size: 13.5px; color: var(--cap-text-dim);
	line-height: 1.5;
}
.cap-wrapper .cap-referral-link {
	margin-bottom: 14px;
}
.cap-wrapper .cap-referral-link label {
	display: block;
	font-size: 11.5px; font-weight: 700;
	color: var(--cap-text-muted);
	margin-bottom: 6px;
	text-transform: uppercase; letter-spacing: 0.3px;
}
.cap-wrapper .cap-referral-link-campo { display: flex; gap: 8px; }
.cap-wrapper .cap-ref-link {
	flex: 1; padding: 10px 14px;
	background: var(--cap-surface);
	border: 1.5px solid var(--cap-border);
	border-radius: 8px;
	font-family: ui-monospace, 'SF Mono', monospace;
	font-size: 13px;
	color: var(--cap-text);
}
.cap-wrapper .cap-ref-link:focus {
	outline: none; border-color: var(--cap-primary);
	background: #fff;
}
.cap-wrapper .cap-btn-copiar {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 10px 16px;
	background: var(--cap-primary); color: #fff;
	border: none; border-radius: 8px;
	font-weight: 600; font-size: 13px;
	cursor: pointer; transition: all 0.2s ease;
	white-space: nowrap;
	width: auto;
}
.cap-wrapper .cap-btn-copiar:hover {
	background: var(--cap-primary-dark);
	transform: translateY(-1px);
}
.cap-wrapper .cap-btn-copiar-ok {
	background: var(--cap-success) !important;
}
.cap-wrapper .cap-referral-share {
	display: flex; align-items: center; flex-wrap: wrap; gap: 8px;
	margin-bottom: 16px;
	padding: 12px 0;
	border-top: 1px solid var(--cap-surface2);
	border-bottom: 1px solid var(--cap-surface2);
}
.cap-wrapper .cap-referral-share-label {
	font-size: 12.5px; font-weight: 600;
	color: var(--cap-text-muted); margin-right: 4px;
}
.cap-wrapper .cap-share-btn {
	display: inline-flex; align-items: center; justify-content: center;
	width: 38px; height: 38px;
	border-radius: 50%;
	color: #fff; font-size: 15px;
	text-decoration: none; border: none;
	cursor: pointer; transition: all 0.2s;
}
.cap-wrapper .cap-share-btn:hover {
	transform: translateY(-2px) scale(1.05);
	box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}
.cap-wrapper .cap-share-wa { background: #25d366; }
.cap-wrapper .cap-share-fb { background: #1877f2; }
.cap-wrapper .cap-share-tg { background: #0088cc; }
.cap-wrapper .cap-share-em { background: #6b7280; }
.cap-wrapper .cap-share-nat { background: linear-gradient(135deg, var(--cap-primary) 0%, var(--cap-primary-dark) 100%); }
.cap-wrapper .cap-referral-progresso { margin-bottom: 8px; }
.cap-wrapper .cap-referral-barra {
	height: 8px; background: var(--cap-surface2);
	border-radius: 6px; overflow: hidden;
	margin-bottom: 6px;
}
.cap-wrapper .cap-referral-barra-fill {
	height: 100%;
	background: linear-gradient(90deg, var(--cap-secondary) 0%, var(--cap-primary) 100%);
	border-radius: 6px;
	transition: width 0.4s ease;
}
.cap-wrapper .cap-referral-progresso-texto {
	font-size: 12.5px; color: var(--cap-text-dim);
}
.cap-wrapper .cap-referral-progresso-texto strong { color: var(--cap-text); }
.cap-wrapper .cap-referral-reset {
	margin-top: 6px;
	font-size: 11.5px; color: var(--cap-text-muted);
}
.cap-wrapper .cap-referral-reset strong {
	color: var(--cap-text-dim); font-weight: 700;
}
.cap-wrapper .cap-referral-nota {
	margin: 12px 0 0;
	font-size: 11.5px; color: var(--cap-text-muted);
}

/* ============================================================
 * MODAL DE LEAD (registo)
 * ============================================================ */
.cap-lead-overlay {
	display: none;
	position: fixed; inset: 0;
	background: rgba(26,43,45,0.55);
	backdrop-filter: blur(4px);
	z-index: 99999;
	align-items: center; justify-content: center;
	padding: 20px;
	font-family: 'DM Sans', sans-serif;
}
.cap-lead-overlay.cap-aberto {
	display: flex;
	animation: cap-fadeIn 0.2s ease;
}
@keyframes cap-fadeIn { from { opacity: 0; } to { opacity: 1; } }
.cap-lead-modal {
	background: #fff;
	border-radius: var(--cap-radius);
	max-width: 460px; width: 100%;
	max-height: 92vh; overflow-y: auto;
	box-shadow: 0 24px 60px rgba(0,0,0,0.3);
	position: relative;
	animation: cap-slideUpBig 0.35s ease;
}
.cap-lead-fechar {
	position: absolute; top: 12px; right: 12px;
	background: rgba(255,255,255,0.95);
	border: 1px solid #DFE2E8; color: #5A6B6E;
	width: 32px; height: 32px;
	border-radius: 50%; font-size: 20px;
	cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	z-index: 2;
}
.cap-lead-cabecalho {
	background: linear-gradient(135deg, #13919B 0%, #0F7A83 100%);
	color: #fff;
	padding: 30px 24px 24px;
	border-radius: var(--cap-radius) var(--cap-radius) 0 0;
	text-align: center;
}
.cap-lead-icone {
	width: 56px; height: 56px;
	border-radius: 50%;
	background: rgba(255,255,255,0.18);
	display: inline-flex; align-items: center; justify-content: center;
	font-size: 22px; margin-bottom: 12px;
}
.cap-lead-cabecalho h3 {
	font-family: 'DM Serif Display', serif;
	font-size: 22px; font-weight: 400;
	margin-bottom: 6px;
}
.cap-lead-cabecalho p {
	font-size: 13.5px; opacity: 0.9; line-height: 1.55;
}
.cap-lead-form { padding: 22px 24px 24px; }
.cap-lead-campo { margin-bottom: 14px; }
.cap-lead-campo label {
	display: block;
	font-size: 13px; font-weight: 600;
	color: #5A6B6E;
	margin-bottom: 5px;
}
.cap-lead-campo input,
.cap-lead-campo select {
	width: 100%;
	background: #fff;
	border: 1.5px solid #DFE2E8;
	border-radius: 10px;
	padding: 11px 13px;
	font-family: 'DM Sans', sans-serif;
	font-size: 14.5px; color: #1A2B2D;
	outline: none; transition: all 0.2s;
}
.cap-lead-campo input:focus, .cap-lead-campo select:focus {
	border-color: #13919B;
	box-shadow: 0 0 0 3px rgba(19,145,155,0.08);
}
.cap-lead-msg {
	display: none; padding: 10px 14px;
	background: #FEF2F2; border: 1px solid #FECACA;
	border-radius: 8px; color: #D94444;
	font-size: 13px; margin-bottom: 14px;
}
.cap-lead-msg.cap-visible { display: block; }
.cap-lead-msg.cap-ok {
	background: #ECFDF5; border-color: #A7F3D0; color: #047857;
}
.cap-lead-msg.cap-ok code {
	background: #fff; padding: 2px 6px; border-radius: 4px;
	font-family: 'DM Sans', monospace; font-size: 12px;
	color: #064E3B; border: 1px solid #A7F3D0;
}
.cap-lead-msg.cap-erro {
	background: #FEF2F2; border-color: #FECACA; color: #D94444;
}
.cap-lead-form button {
	width: 100%; padding: 13px;
	background: #13919B; color: #fff;
	border: none; border-radius: 10px;
	font-family: 'DM Sans', sans-serif;
	font-size: 14.5px; font-weight: 700;
	cursor: pointer; transition: all 0.2s;
}
.cap-lead-form button:hover {
	background: #0F7A83;
	box-shadow: 0 4px 14px rgba(19,145,155,0.25);
}
.cap-lead-rodape {
	margin-top: 14px; font-size: 11.5px;
	color: #8A969A; text-align: center;
	line-height: 1.5;
}
.cap-lead-login {
	margin-top: 8px; font-size: 12.5px;
	color: #8A969A; text-align: center;
}
.cap-lead-login a {
	color: #13919B; font-weight: 600;
	text-decoration: none;
}
.cap-lead-login a:hover { text-decoration: underline; }

@media (max-width: 540px) {
	.cap-wrapper .cap-referral { padding: 18px 16px; }
	.cap-wrapper .cap-referral-link-campo { flex-direction: column; }
	.cap-wrapper .cap-btn-copiar { width: 100%; justify-content: center; }
	.cap-wrapper .cap-referral-share { justify-content: center; }
	.cap-wrapper .cap-paywall { padding: 24px 18px; }
	.cap-lead-overlay { padding: 0; align-items: stretch; }
	.cap-lead-modal { max-width: 100%; max-height: 100vh; border-radius: 0; }
	.cap-lead-cabecalho { border-radius: 0; }
	.cap-wrapper .cap-barra-estado { flex-direction: column; align-items: stretch; text-align: center; padding: 14px 16px; }
	.cap-wrapper .cap-resgate-form { flex-direction: column; }
	.cap-wrapper .cap-resgate-form button { width: 100%; }
}
