/* ============================================================
   Luminare CRM — Frontend Portal Styles
   Mobile-first
   ============================================================ */

:root {
	--p-primary:   #7C3AED;
	--p-primary-d: #5B21B6;
	--p-primary-l: #EDE9FE;
	--p-green:     #10B981;
	--p-red:       #EF4444;
	--p-amber:     #F59E0B;
	--p-blue:      #3B82F6;
	--p-cyan:      #06B6D4;
	--p-gray:      #6B7280;
	--p-gray-l:    #F9FAFB;
	--p-gray-m:    #E5E7EB;
	--p-text:      #111827;
	--p-radius:    14px;
	--p-shadow:    0 2px 8px rgba(0,0,0,.08);
}

/* -- Reset within plugin wrapper ---------------------------- */
.lcrm-portal, .lcrm-bienvenida {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	color: var(--p-text);
	-webkit-font-smoothing: antialiased;
	line-height: 1.5;
}

/* -- Hero header -------------------------------------------- */
.lcrm-hero {
	background: linear-gradient(135deg, var(--p-primary) 0%, #4F46E5 100%);
	border-radius: var(--p-radius);
	padding: 28px 24px 24px;
	margin-bottom: 20px;
	color: #fff;
}
.lcrm-hero h1 {
	font-size: 22px;
	font-weight: 800;
	margin: 0 0 4px;
	line-height: 1.2;
}
.lcrm-hero p { margin: 0; opacity: .8; font-size: 14px; }

/* -- Bottom nav (mobile) ------------------------------------ */
.lcrm-bottom-nav {
	position: fixed;
	bottom: 0; left: 0; right: 0;
	background: #fff;
	border-top: 1px solid var(--p-gray-m);
	display: flex;
	z-index: 100;
	box-shadow: 0 -2px 12px rgba(0,0,0,.08);
}
.lcrm-bottom-nav a {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 10px 4px 8px;
	text-decoration: none;
	color: var(--p-gray);
	font-size: 10px;
	font-weight: 600;
	gap: 3px;
	transition: color .15s;
	border-top: 3px solid transparent;
}
.lcrm-bottom-nav a .nav-icon { font-size: 20px; line-height: 1; }
.lcrm-bottom-nav a.active {
	color: var(--p-primary);
	border-top-color: var(--p-primary);
}
.lcrm-portal-body { padding-bottom: 72px; } /* space for bottom nav */

/* -- Card --------------------------------------------------- */
.lcrm-p-card {
	background: #fff;
	border-radius: var(--p-radius);
	box-shadow: var(--p-shadow);
	margin-bottom: 16px;
	overflow: hidden;
}
.lcrm-p-card-header {
	padding: 16px 18px 12px;
	border-bottom: 1px solid var(--p-gray-m);
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.lcrm-p-card-header h2 {
	margin: 0;
	font-size: 15px;
	font-weight: 700;
}
.lcrm-p-card-body { padding: 16px 18px; }

/* -- Stat mini cards ---------------------------------------- */
.lcrm-p-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	margin-bottom: 16px;
}
.lcrm-p-stat {
	background: #fff;
	border-radius: 12px;
	padding: 14px 10px;
	text-align: center;
	box-shadow: var(--p-shadow);
	border-top: 3px solid var(--p-primary);
}
.lcrm-p-stat.c-green  { border-top-color: var(--p-green); }
.lcrm-p-stat.c-amber  { border-top-color: var(--p-amber); }
.lcrm-p-stat.c-blue   { border-top-color: var(--p-blue); }
.lcrm-p-stat.c-red    { border-top-color: var(--p-red); }
.lcrm-p-stat .s-num   { font-size: 26px; font-weight: 800; line-height: 1; }
.lcrm-p-stat .s-label { font-size: 11px; color: var(--p-gray); margin-top: 4px; font-weight: 500; }

/* -- Member list -------------------------------------------- */
.lcrm-member-list { list-style: none; margin: 0; padding: 0; }
.lcrm-member-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 18px;
	border-bottom: 1px solid var(--p-gray-m);
}
.lcrm-member-item:last-child { border-bottom: none; }
.lcrm-member-avatar {
	width: 38px; height: 38px; border-radius: 50%;
	background: var(--p-primary-l); color: var(--p-primary);
	font-size: 14px; font-weight: 700;
	display: flex; align-items: center; justify-content: center;
	flex-shrink: 0;
}
.lcrm-member-name   { font-size: 14px; font-weight: 600; }
.lcrm-member-meta   { font-size: 12px; color: var(--p-gray); }
.lcrm-member-badge  {
	margin-left: auto;
	font-size: 10px; font-weight: 600;
	padding: 3px 8px; border-radius: 99px;
	background: var(--p-primary-l); color: var(--p-primary);
	flex-shrink: 0;
}

/* -- Progress track card ------------------------------------ */
.lcrm-track-card {
	background: #fff;
	border-radius: 12px;
	padding: 14px 16px;
	margin-bottom: 12px;
	box-shadow: var(--p-shadow);
	display: flex;
	align-items: center;
	gap: 14px;
}
.lcrm-track-icon {
	width: 44px; height: 44px; border-radius: 12px;
	background: var(--p-primary-l); color: var(--p-primary);
	display: flex; align-items: center; justify-content: center;
	font-size: 20px; flex-shrink: 0;
}
.lcrm-track-info { flex: 1; min-width: 0; }
.lcrm-track-name { font-size: 14px; font-weight: 700; }
.lcrm-track-sub  { font-size: 12px; color: var(--p-gray); margin-top: 2px; }
.lcrm-track-bar-wrap {
	height: 6px; background: var(--p-gray-m); border-radius: 99px;
	overflow: hidden; margin-top: 6px;
}
.lcrm-track-bar {
	height: 100%; border-radius: 99px;
	background: linear-gradient(90deg, var(--p-primary), var(--p-blue));
}
.lcrm-track-status { flex-shrink: 0; }

/* -- Badge -------------------------------------------------- */
.lcrm-p-badge {
	display: inline-flex; align-items: center;
	padding: 4px 10px; border-radius: 99px;
	font-size: 11px; font-weight: 700; text-transform: uppercase;
}
.badge-green  { background: #D1FAE5; color: #065F46; }
.badge-amber  { background: #FEF3C7; color: #92400E; }
.badge-red    { background: #FEE2E2; color: #991B1B; }
.badge-gray   { background: var(--p-gray-m); color: var(--p-gray); }
.badge-purple { background: var(--p-primary-l); color: var(--p-primary-d); }

/* -- Bienvenida form ---------------------------------------- */
.lcrm-bienvenida {
	max-width: 560px;
	margin: 0 auto;
	padding: 0 4px;
}
.lcrm-form-hero {
	background: var(--lcrm-accent, var(--p-primary));
	border-radius: var(--p-radius);
	padding: 32px 24px;
	text-align: center;
	color: #fff;
	margin-bottom: 20px;
}
.lcrm-form-hero h1 { font-size: 24px; font-weight: 800; margin: 0 0 6px; color: #fff; }
.lcrm-form-hero p  { margin: 0; opacity: .85; font-size: 14px; }

.lcrm-bv-form {
	background: var(--color-base, #fff);
	border: 1px solid var(--color-base-3, #e5e7eb);
	border-radius: var(--p-radius);
	box-shadow: 0 2px 12px rgba(0,0,0,.06);
	padding: 28px 24px;
}
.lcrm-bv-group { margin-bottom: 16px; }
.lcrm-bv-group label {
	display: block;
	font-size: 12px; font-weight: 700;
	color: var(--color-contrast-2, #4b5563);
	text-transform: uppercase; letter-spacing: .5px;
	margin-bottom: 6px;
}
.lcrm-bv-group input,
.lcrm-bv-group select {
	width: 100%; box-sizing: border-box;
	padding: 11px 14px;
	border: 1.5px solid var(--color-base-3, #d1d5db);
	border-radius: 8px;
	font-size: 15px;
	font-family: inherit;
	color: var(--color-contrast, #111827);
	background: var(--color-base-2, #f9fafb);
	transition: border-color .15s, box-shadow .15s;
	-webkit-appearance: none;
}
.lcrm-bv-group input:focus,
.lcrm-bv-group select:focus {
	outline: none;
	border-color: var(--lcrm-accent, var(--p-primary));
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--lcrm-accent, var(--p-primary)) 15%, transparent);
	background: var(--color-base, #fff);
}
.lcrm-bv-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.lcrm-bv-btn {
	width: 100%;
	padding: 14px;
	background: var(--lcrm-accent, var(--p-primary));
	color: #fff;
	border: none;
	border-radius: 8px;
	font-size: 16px;
	font-weight: 700;
	cursor: pointer;
	margin-top: 8px;
	transition: opacity .15s, transform .1s;
	font-family: inherit;
}
.lcrm-bv-btn:hover  { opacity: .88; }
.lcrm-bv-btn:active { transform: scale(.98); }
.lcrm-bv-btn:disabled { opacity: .6; cursor: not-allowed; }

/* -- Success screen ----------------------------------------- */
.lcrm-bv-success {
	display: none;
	text-align: center;
	padding: 40px 20px;
}
.lcrm-bv-success.show { display: block; }
.lcrm-bv-success .check-icon {
	font-size: 64px; display: block; margin-bottom: 16px;
}
.lcrm-bv-success h2 { font-size: 22px; font-weight: 800; margin: 0 0 8px; }
.lcrm-bv-success p  { color: var(--p-gray); margin: 0; font-size: 15px; }

/* -- Duplicate warning -------------------------------------- */
.lcrm-bv-dup {
	display: none;
	background: #FEF3C7; border: 1.5px solid var(--p-amber);
	border-radius: 10px; padding: 12px 14px;
	font-size: 13px; margin-bottom: 14px;
}
.lcrm-bv-dup.show { display: block; }

/* -- Login gate --------------------------------------------- */
.lcrm-login-gate {
	text-align: center;
	padding: 48px 20px;
	background: #fff;
	border-radius: var(--p-radius);
	box-shadow: var(--p-shadow);
}
.lcrm-login-gate .gate-icon { font-size: 52px; display: block; margin-bottom: 16px; }
.lcrm-login-gate h2 { font-size: 20px; margin: 0 0 8px; }
.lcrm-login-gate p  { color: var(--p-gray); margin: 0 0 20px; }
.lcrm-login-btn {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 12px 24px;
	background: var(--p-primary); color: #fff;
	border-radius: 10px; text-decoration: none;
	font-weight: 700; font-size: 15px;
}

/* -- Search bar --------------------------------------------- */
.lcrm-p-search {
	width: 100%; box-sizing: border-box;
	padding: 11px 16px 11px 40px;
	border: 1.5px solid var(--p-gray-m);
	border-radius: 10px;
	font-size: 14px; font-family: inherit;
	background: var(--p-gray-l) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236B7280' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.099zm-5.598 1.05a5.5 5.5 0 1 1 0-11 5.5 5.5 0 0 1 0 11z'/%3E%3C/svg%3E") 12px center no-repeat;
	transition: border-color .15s;
	margin-bottom: 16px;
}
.lcrm-p-search:focus {
	outline: none;
	border-color: var(--p-primary);
	background-color: #fff;
}

/* -- Empty state -------------------------------------------- */
.lcrm-p-empty {
	text-align: center; padding: 40px 20px; color: var(--p-gray);
}
.lcrm-p-empty .ei { font-size: 40px; display: block; margin-bottom: 10px; }

/* -- Section label ------------------------------------------ */
.lcrm-p-section-label {
	font-size: 11px; font-weight: 700; text-transform: uppercase;
	letter-spacing: .6px; color: var(--p-gray);
	margin: 20px 0 10px; padding-bottom: 6px;
	border-bottom: 1px solid var(--p-gray-m);
}

/* -- Announcement card -------------------------------------- */
.lcrm-announce-card {
	background: #fff; border-radius: 12px;
	padding: 16px 18px; margin-bottom: 12px;
	box-shadow: var(--p-shadow);
	border-left: 4px solid var(--p-primary);
}
.lcrm-announce-title { font-size: 15px; font-weight: 700; margin: 0 0 6px; }
.lcrm-announce-body  { font-size: 14px; color: var(--p-gray); margin: 0 0 8px; }
.lcrm-announce-meta  { font-size: 11px; color: var(--p-gray); }

/* -- Responsive -------------------------------------------- */
@media (min-width: 640px) {
	.lcrm-bottom-nav { display: none; }
	.lcrm-portal-body { padding-bottom: 0; }
	.lcrm-portal-layout {
		display: grid;
		grid-template-columns: 220px 1fr;
		gap: 20px;
		align-items: start;
	}
	.lcrm-side-nav {
		background: #fff;
		border-radius: var(--p-radius);
		box-shadow: var(--p-shadow);
		padding: 12px 0;
		position: sticky;
		top: 24px;
	}
	.lcrm-side-nav a {
		display: flex; align-items: center; gap: 10px;
		padding: 11px 18px;
		text-decoration: none;
		font-size: 14px; font-weight: 500;
		color: var(--p-gray);
		border-left: 3px solid transparent;
		transition: all .15s;
	}
	.lcrm-side-nav a .nav-icon { font-size: 18px; }
	.lcrm-side-nav a:hover { color: var(--p-text); background: var(--p-gray-l); }
	.lcrm-side-nav a.active { color: var(--p-primary); border-left-color: var(--p-primary); background: var(--p-primary-l); }
}
