/**
 * Chamber Fusion — member portal styles.
 *
 * Tabbed self-service dashboard for [chamber_fusion_portal], plus the
 * logged-out login card. Scoped under .cf-portal, theme-agnostic.
 *
 * @package Chamber_CRM
 * @since   1.3.0
 */

.cf-portal {
	/* White-label palette (see chamber-fusion-directory.css for notes). */
	--cf-accent: var(--cf-primary-color, #1e40af);
	--cf-accent-dark: #1e3a8a;
	--cf-accent-dark: color-mix(in srgb, var(--cf-accent) 80%, #000000);
	--cf-surface: #ffffff;
	--cf-border: #e2e8f0;
	--cf-text: #1e293b;
	--cf-muted: #64748b;
	--cf-radius: 12px;

	max-width: 860px;
	margin: 0 auto;
	color: var(--cf-text);
}

/* ------------------------------------------------------------------ */
/* Header.                                                             */
/* ------------------------------------------------------------------ */

.cf-portal__header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
	margin-bottom: 18px;
}

.cf-portal__title {
	margin: 0;
	font-size: 26px;
	font-weight: 700;
}

.cf-portal__logout {
	font-size: 14px;
	color: var(--cf-muted);
	text-decoration: underline;
}

.cf-portal__logout:hover {
	color: var(--cf-accent);
}

/* ------------------------------------------------------------------ */
/* Profile completeness (gamification).                                */
/* ------------------------------------------------------------------ */

.cf-portal__health {
	display: flex;
	align-items: center;
	gap: 18px;
	margin-bottom: 22px;
	padding: 16px 20px;
	background: var(--cf-surface);
	border: 1px solid var(--cf-border);
	border-radius: var(--cf-radius);
}

/* v2.32.0 — reactive Profile-strength RING (replaces the old bar). Updates live
   on save via chamber-fusion-portal.js; the percent is server-authoritative. */
.cf-portal__ring {
	position: relative;
	flex: 0 0 auto;
	width: 84px;
	height: 84px;
}

.cf-portal__ring-svg {
	width: 100%;
	height: 100%;
	transform: rotate(-90deg);
}

.cf-portal__ring-track {
	fill: none;
	stroke: #eef2f7;
	stroke-width: 9;
}

.cf-portal__ring-fill {
	fill: none;
	stroke-width: 9;
	stroke-linecap: round;
	stroke-dasharray: 326.726; /* 2·π·52 */
	stroke-dashoffset: calc(326.726 * (1 - var(--cf-pct, 0) / 100));
	transition: stroke-dashoffset 0.6s ease, stroke 0.3s ease;
}

.cf-portal__health.is-low  .cf-portal__ring-fill { stroke: #d63638; }
.cf-portal__health.is-mid  .cf-portal__ring-fill { stroke: #dba617; }
.cf-portal__health.is-high .cf-portal__ring-fill { stroke: #00a32a; }

.cf-portal__ring-pct {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	font-weight: 800;
	color: var(--cf-text);
}

.cf-portal__health-body {
	flex: 1 1 auto;
	min-width: 0;
}

.cf-portal__health-label {
	display: block;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--cf-muted);
}

.cf-portal__health-hint {
	margin: 10px 0 0;
	font-size: 13px;
	color: var(--cf-muted);
}

.cf-portal__health-hint strong { color: var(--cf-text); }

/* ------------------------------------------------------------------ */
/* SEO tooltips (pure CSS hover/focus).                                */
/* ------------------------------------------------------------------ */

.cf-portal__tip {
	position: relative;
	display: inline-flex;
	margin-left: 4px;
	vertical-align: middle;
	cursor: help;
	outline: none;
}

.cf-portal__tip-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 15px;
	height: 15px;
	border-radius: 50%;
	background: var(--cf-border);
	color: var(--cf-muted);
	font-size: 10px;
	font-weight: 700;
	line-height: 1;
}

.cf-portal__tip:hover .cf-portal__tip-icon,
.cf-portal__tip:focus .cf-portal__tip-icon {
	background: var(--cf-accent);
	color: #ffffff;
}

.cf-portal__tip-text {
	position: absolute;
	bottom: calc(100% + 8px);
	left: 50%;
	transform: translateX(-50%);
	z-index: 30;
	width: 240px;
	padding: 10px 12px;
	border-radius: 8px;
	background: #1e293b;
	color: #ffffff;
	font-size: 12px;
	font-weight: 400;
	line-height: 1.45;
	text-transform: none;
	letter-spacing: normal;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.15s ease;
	pointer-events: none;
}

.cf-portal__tip-text::after {
	content: "";
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 6px solid transparent;
	border-top-color: #1e293b;
}

.cf-portal__tip:hover .cf-portal__tip-text,
.cf-portal__tip:focus .cf-portal__tip-text {
	opacity: 1;
	visibility: visible;
}

/* ------------------------------------------------------------------ */
/* Digital Partner upsell banner.                                      */
/* ------------------------------------------------------------------ */

.cf-portal__upsell {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
	margin-bottom: 22px;
	padding: 20px 24px;
	background: linear-gradient(135deg, var(--cf-accent) 0%, #312e81 100%);
	border-radius: var(--cf-radius);
	color: #ffffff;
}

.cf-portal__upsell-copy h3 {
	margin: 0 0 4px;
	font-size: 17px;
	font-weight: 700;
	color: #ffffff;
}

.cf-portal__upsell-copy p {
	margin: 0;
	font-size: 14px;
	color: rgba(255, 255, 255, 0.85);
}

.cf-portal__upsell-button {
	flex-shrink: 0;
	padding: 12px 26px;
	border-radius: 8px;
	background: #ffffff;
	color: var(--cf-accent);
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
	transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.cf-portal__upsell-button:hover {
	color: var(--cf-accent-dark);
	transform: translateY(-1px);
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25);
}

/* ------------------------------------------------------------------ */
/* Pending-activation banner (dual payment routing).                   */
/* ------------------------------------------------------------------ */

.cf-portal__banner {
	margin-bottom: 22px;
	padding: 18px 22px;
	background: #fcf9e8;
	border: 1px solid #dba617;
	border-left-width: 5px;
	border-radius: var(--cf-radius);
}

.cf-portal__banner-title {
	margin: 0 0 8px;
	font-size: 16px;
	font-weight: 700;
	color: #996800;
}

.cf-portal__banner-body p {
	margin: 0 0 10px;
	font-size: 14px;
	line-height: 1.55;
}

.cf-portal__banner-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 4px 0 8px;
}

.cf-portal__save--secondary {
	background: #ffffff;
	color: var(--cf-accent);
	border: 1.5px solid var(--cf-accent);
}

.cf-portal__save--secondary:hover:not(:disabled) {
	background: var(--cf-accent);
	color: #ffffff;
}

.cf-portal__banner-msg {
	font-size: 13px;
	font-weight: 600;
	min-height: 1em;
}

.cf-portal__banner-msg.is-success { color: #996800; }
.cf-portal__banner-msg.is-error   { color: #b32d2e; }

.cf-portal__check-instructions p { margin: 0 0 8px; }

/* ------------------------------------------------------------------ */
/* Tabs.                                                               */
/* ------------------------------------------------------------------ */

.cf-portal__tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	border-bottom: 2px solid var(--cf-border);
	margin-bottom: 24px;
}

.cf-portal__tab {
	padding: 12px 18px;
	margin-bottom: -2px;
	border: none;
	border-bottom: 2px solid transparent;
	background: transparent;
	font-size: 15px;
	font-weight: 600;
	color: var(--cf-muted);
	cursor: pointer;
	transition: color 0.15s ease, border-color 0.15s ease;
}

.cf-portal__tab:hover {
	color: var(--cf-accent);
}

.cf-portal__tab.is-active {
	color: var(--cf-accent);
	border-bottom-color: var(--cf-accent);
}

/* ------------------------------------------------------------------ */
/* Forms.                                                              */
/* ------------------------------------------------------------------ */

.cf-portal__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 4px 24px;
}

.cf-portal__field {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin: 0 0 16px;
}

.cf-portal__label {
	font-size: 13px;
	font-weight: 600;
	color: var(--cf-text);
	letter-spacing: 0.01em;
}

.cf-portal__form input[type="text"],
.cf-portal__form input[type="tel"],
.cf-portal__form input[type="email"],
.cf-portal__form input[type="url"],
.cf-portal__form textarea {
	width: 100%;
	padding: 10px 14px;
	border: 1px solid var(--cf-border);
	border-radius: 8px;
	font-size: 15px;
	color: var(--cf-text);
	background: var(--cf-surface);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.cf-portal__form input:focus,
.cf-portal__form textarea:focus {
	outline: none;
	border-color: var(--cf-accent);
	box-shadow: 0 0 0 3px rgba(30, 64, 175, 0.15);
}

.cf-portal__hint {
	font-size: 12px;
	color: var(--cf-muted);
}

.cf-portal__save {
	margin-top: 8px;
	padding: 12px 28px;
	border: none;
	border-radius: 8px;
	background: var(--cf-accent);
	color: #ffffff;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: background-color 0.15s ease;
}

.cf-portal__save:hover:not(:disabled) {
	background: var(--cf-accent-dark);
}

.cf-portal__save:disabled {
	opacity: 0.6;
	cursor: wait;
}

/* Inline result notice. */

.cf-portal__notice {
	margin-bottom: 18px;
	padding: 12px 16px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 500;
}

.cf-portal__notice.is-success {
	background: #edfaef;
	color: #00753a;
	border: 1px solid #00ba37;
}

.cf-portal__notice.is-error {
	background: #fcf0f1;
	color: #b32d2e;
	border: 1px solid #d63638;
}

/* Logo upload row. */

.cf-portal__logo-row {
	display: flex;
	align-items: center;
	gap: 20px;
	margin-bottom: 22px;
	padding: 16px;
	border: 1px dashed var(--cf-border);
	border-radius: var(--cf-radius);
}

.cf-portal__logo-preview {
	flex: 0 0 72px;
	width: 72px;
	height: 72px;
	border-radius: 50%;
	overflow: hidden;
	background: #f1f5f9;
	border: 1px solid var(--cf-border);
	display: flex;
	align-items: center;
	justify-content: center;
}

.cf-portal__logo-preview img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cf-portal__logo-empty {
	font-size: 11px;
	color: var(--cf-muted);
}

/* ------------------------------------------------------------------ */
/* Status tab.                                                         */
/* ------------------------------------------------------------------ */

.cf-portal__standing {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 22px;
}

.cf-portal__standing-label {
	font-size: 14px;
	font-weight: 600;
	color: var(--cf-muted);
}

.cf-portal__badge {
	display: inline-block;
	padding: 6px 18px;
	border-radius: 999px;
	font-size: 15px;
	font-weight: 700;
}

.cf-portal__badge--active  { background: #edfaef; color: #00753a; border: 1.5px solid #00ba37; }
.cf-portal__badge--pending { background: #fcf9e8; color: #996800; border: 1.5px solid #dba617; }
.cf-portal__badge--expired { background: #fcf0f1; color: #b32d2e; border: 1.5px solid #d63638; }
.cf-portal__badge--neutral { background: #f0f0f1; color: #50575e; border: 1.5px solid #c3c4c7; }

.cf-portal__facts {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 16px;
	margin: 0;
}

.cf-portal__fact {
	padding: 16px 18px;
	background: var(--cf-surface);
	border: 1px solid var(--cf-border);
	border-radius: var(--cf-radius);
}

.cf-portal__fact dt {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--cf-muted);
	margin-bottom: 6px;
}

.cf-portal__fact dd {
	margin: 0;
	font-size: 17px;
	font-weight: 700;
}

.cf-portal__fact--overdue {
	color: #b32d2e;
}

.cf-portal__billing-note {
	margin-top: 20px;
	padding: 14px 18px;
	background: #eff6ff;
	border-left: 4px solid var(--cf-accent);
	border-radius: 0 8px 8px 0;
	font-size: 14px;
	color: var(--cf-text);
}

/* ------------------------------------------------------------------ */
/* Login card (logged-out view).                                       */
/* ------------------------------------------------------------------ */

.cf-portal__login-card {
	max-width: 420px;
	margin: 0 auto;
	padding: 32px 30px;
	background: var(--cf-surface);
	border: 1px solid var(--cf-border);
	border-radius: var(--cf-radius);
	box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
}

.cf-portal__login-intro {
	color: var(--cf-muted);
	font-size: 14px;
	margin: 8px 0 20px;
}

.cf-portal__login-card form p {
	margin: 0 0 14px;
}

.cf-portal__login-card label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	margin-bottom: 6px;
}

.cf-portal__login-card input[type="text"],
.cf-portal__login-card input[type="password"] {
	width: 100%;
	padding: 10px 14px;
	border: 1px solid var(--cf-border);
	border-radius: 8px;
	font-size: 15px;
}

.cf-portal__login-card input[type="submit"] {
	width: 100%;
	padding: 12px;
	border: none;
	border-radius: 8px;
	background: var(--cf-accent);
	color: #ffffff;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
}

.cf-portal__login-card input[type="submit"]:hover {
	background: var(--cf-accent-dark);
}

.cf-portal__login-links {
	margin: 14px 0 0;
	text-align: center;
	font-size: 13px;
}
