/**
 * Premium Glassmorphic Styles for eMintage Memberships.
 * Color-aligned with eMintage.com guidelines.
 */

:root {
	--em-main-bg: #0A192F;          /* Deep Space Navy */
	--em-panel-bg: #112240;         /* Navy Blue Accent */
	--em-primary-accent: #3EB489;   /* Mint Green (Brand Text) */
	--em-secondary-accent: #64ffda; /* Teal / Hyper-Cyan (Highlight) */
	--em-border-color: #233554;     /* Slate Blue */
	--em-muted-text: #8892b0;       /* Slate Gray */
	--em-alert-text: #ff4d4d;       /* Crimson Red */
	--em-primary-text: #FFFFFF;     /* Pure White */
	
	/* Glassmorphic values using brand colors */
	--em-glass-bg: rgba(17, 34, 64, 0.85);
	--em-glass-border: rgba(35, 53, 84, 0.7);
	--em-glass-shadow: 0 12px 35px rgba(10, 25, 47, 0.5);
}

/* Glass panel base styling - Cockpit Dark Theme */
.em-glass-panel {
	background: var(--em-glass-bg);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border: 1px solid var(--em-glass-border);
	border-radius: 16px;
	box-shadow: var(--em-glass-shadow);
	padding: 26px;
	transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
	color: var(--em-primary-text) !important;
}
.em-glass-panel:hover {
	transform: translateY(-2px);
	border-color: var(--em-secondary-accent);
	box-shadow: 0 16px 45px rgba(100, 255, 218, 0.1);
}

/* CONTAINER & GENERAL */
.em-dashboard-container {
	margin: 30px auto;
	max-width: 1100px;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
	color: var(--em-primary-text);
}

.em-dashboard-container h2,
.em-dashboard-container h3 {
	color: var(--em-primary-accent) !important; /* Mint Green Header */
	font-weight: 800;
	letter-spacing: -0.5px;
}

/* ----------------------------------------------------
 * GATED CONTENT LOCK SCREEN STYLES 
 * ---------------------------------------------------- */
.em-lock-screen-wrapper {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 50px 20px;
	background: radial-gradient(circle at top, #112240 0%, #0A192F 100%);
	border-radius: 20px;
	border: 1px solid var(--em-border-color);
	box-shadow: 0 10px 30px rgba(0,0,0,0.3);
}
.em-lock-card {
	background: rgba(17, 34, 64, 0.95);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border: 1px solid var(--em-glass-border);
	border-radius: 24px;
	box-shadow: 0 20px 50px rgba(0,0,0,0.4);
	padding: 45px;
	text-align: center;
	max-width: 520px;
	width: 100%;
}
.em-lock-icon-container {
	background: linear-gradient(135deg, var(--em-alert-text), #d63031);
	width: 76px;
	height: 76px;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 auto 24px auto;
	box-shadow: 0 8px 20px rgba(255, 77, 77, 0.4);
	animation: lock-wobble 4s ease-in-out infinite;
}
.em-lock-svg {
	color: var(--em-primary-text);
	width: 34px;
	height: 34px;
}
.em-lock-card h2 {
	font-size: 28px;
	margin-top: 0;
	margin-bottom: 12px;
}
.em-lock-intro {
	color: var(--em-muted-text);
	font-size: 15px;
	line-height: 1.6;
	margin-bottom: 30px;
}

/* Form Gating inside Dark Lock Screen */
.em-login-form-container {
	text-align: left;
	background: var(--em-main-bg);
	border: 1px solid var(--em-border-color);
	border-radius: 16px;
	padding: 26px;
	margin-bottom: 26px;
}
.em-login-form-container h3 {
	margin-top: 0;
	margin-bottom: 18px;
	font-size: 16px;
	color: var(--em-primary-text) !important;
}
.em-login-form-container p {
	margin-bottom: 18px;
}
.em-login-form-container label {
	font-size: 13px;
	font-weight: 600;
	color: var(--em-muted-text);
	display: block;
	margin-bottom: 6px;
	letter-spacing: 0.3px;
}
.em-login-form-container input[type="text"],
.em-login-form-container input[type="password"] {
	width: 100%;
	padding: 12px 16px;
	border-radius: 8px;
	border: 1px solid var(--em-border-color);
	background: var(--em-panel-bg);
	color: var(--em-primary-text);
	box-sizing: border-box;
	transition: all 0.2s;
}
.em-login-form-container input[type="text"]:focus,
.em-login-form-container input[type="password"]:focus {
	border-color: var(--em-secondary-accent);
	outline: none;
	box-shadow: 0 0 0 3px rgba(100, 255, 218, 0.15);
}
.em-login-form-container input[type="submit"] {
	background: linear-gradient(135deg, var(--em-primary-accent), var(--em-secondary-accent));
	color: var(--em-main-bg);
	border: none;
	font-weight: 800;
	padding: 14px 20px;
	border-radius: 8px;
	width: 100%;
	cursor: pointer;
	box-shadow: 0 4px 12px rgba(100, 255, 218, 0.2);
	transition: all 0.2s;
}
.em-login-form-container input[type="submit"]:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 18px rgba(100, 255, 218, 0.35);
}

.em-buy-notice {
	border-top: 1px solid var(--em-border-color);
	padding-top: 26px;
	text-align: center;
}
.em-buy-notice p {
	font-size: 14px;
	color: var(--em-muted-text);
	line-height: 1.5;
	margin-bottom: 20px;
}
.em-action-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 28px;
	border-radius: 8px;
	font-weight: 800;
	font-size: 14px;
	text-decoration: none !important;
	transition: all 0.2s;
	cursor: pointer;
	border: none;
}
.em-buy-btn {
	background: linear-gradient(135deg, var(--em-primary-accent), var(--em-secondary-accent));
	color: var(--em-main-bg) !important;
	box-shadow: 0 4px 15px rgba(100, 255, 218, 0.2);
}
.em-buy-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 20px rgba(100, 255, 218, 0.35);
}
.em-arrow-icon {
	width: 16px;
	height: 16px;
	margin-left: 6px;
	fill: var(--em-main-bg);
}

/* Logged in unauthorized notice */
.em-unauthorized-notice {
	padding: 15px 0 0 0;
}
.em-error-badge {
	background: rgba(255, 77, 77, 0.15);
	color: var(--em-alert-text);
	border: 1px solid rgba(255, 77, 77, 0.3);
	font-weight: 700;
	font-size: 12px;
	padding: 6px 14px;
	border-radius: 12px;
	display: inline-block;
	margin-bottom: 18px;
}
.em-unauthorized-notice p {
	font-size: 14px;
	color: var(--em-muted-text);
	line-height: 1.6;
	margin-bottom: 28px;
}
.em-action-buttons {
	display: flex;
	gap: 15px;
	justify-content: center;
}
.em-logout-btn {
	background: var(--em-panel-bg);
	color: var(--em-muted-text) !important;
	border: 1px solid var(--em-border-color);
}
.em-logout-btn:hover {
	background: var(--em-border-color);
	color: var(--em-primary-text) !important;
}

/* ----------------------------------------------------
 * MEMBERS DASHBOARD STYLES 
 * ---------------------------------------------------- */
.em-dashboard-user-card {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 24px;
	flex-wrap: wrap;
	gap: 20px;
}
.em-user-profile-info {
	display: flex;
	align-items: center;
	gap: 18px;
}
.em-avatar img {
	border-radius: 50%;
	border: 3px solid var(--em-border-color);
	box-shadow: 0 4px 15px rgba(0,0,0,0.3);
}
.em-welcome-back {
	font-size: 13px;
	color: var(--em-muted-text);
	font-weight: 500;
	display: block;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}
.em-user-details h2 {
	margin: 2px 0;
	font-size: 24px;
	font-weight: 800;
	color: var(--em-primary-text) !important;
}
.em-user-email {
	margin: 0;
	color: var(--em-muted-text);
	font-size: 13px;
}
.em-user-meta-actions {
	display: flex;
	align-items: center;
	gap: 15px;
}
.em-badge {
	font-size: 12px;
	font-weight: bold;
	padding: 6px 14px;
	border-radius: 20px;
}
.em-active-badge {
	background: var(--em-main-bg);
	color: var(--em-primary-accent); /* Glowing Mint active status */
	border: 1px solid var(--em-primary-accent);
	box-shadow: 0 0 12px rgba(62, 180, 137, 0.2);
}
.em-inactive-badge {
	background: var(--em-panel-bg);
	color: var(--em-muted-text);
	border: 1px solid var(--em-border-color);
}
.em-btn {
	text-decoration: none !important;
	padding: 10px 18px;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 700;
	transition: all 0.2s;
}
.em-logout-small-btn {
	background: rgba(255, 77, 77, 0.1);
	color: var(--em-alert-text) !important;
	border: 1px solid rgba(255, 77, 77, 0.2);
}
.em-logout-small-btn:hover {
	background: var(--em-alert-text);
	color: var(--em-main-bg) !important;
}

/* Dashboard Panel Layout Grid */
.em-dashboard-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}
.em-column-card h3 {
	margin-top: 0;
	margin-bottom: 6px;
	font-size: 20px;
	font-weight: 800;
}
.em-card-subtitle {
	margin: 0 0 24px 0;
	font-size: 13px;
	color: var(--em-muted-text);
	line-height: 1.5;
}

/* Tools List Panel */
.em-tools-list,
.em-memberships-list {
	list-style: none;
	padding: 0;
	margin: 0;
}
.em-tools-list li,
.em-memberships-list li {
	margin-bottom: 14px;
}
.em-tool-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: var(--em-main-bg);
	padding: 16px 20px;
	border-radius: 12px;
	border: 1px solid var(--em-border-color);
	transition: all 0.2s;
}
.em-tool-item:hover {
	transform: translateX(4px);
	border-color: var(--em-secondary-accent);
	box-shadow: 0 4px 12px rgba(100, 255, 218, 0.08);
}
.em-tool-info {
	display: flex;
	align-items: center;
	gap: 14px;
}
.em-tool-icon {
	font-size: 24px;
}
.em-tool-text strong {
	display: block;
	font-size: 15px;
	color: var(--em-primary-text);
}
.em-tool-tag {
	font-size: 10px;
	font-weight: 700;
	color: var(--em-secondary-accent); /* Teal tag */
	text-transform: uppercase;
	letter-spacing: 0.5px;
}
.em-tool-launch-btn {
	background: linear-gradient(135deg, var(--em-primary-accent), var(--em-secondary-accent));
	color: var(--em-main-bg) !important;
	padding: 8px 16px;
	border-radius: 6px;
	font-size: 12px;
	font-weight: 800;
	text-decoration: none !important;
	box-shadow: 0 3px 8px rgba(100, 255, 218, 0.15);
	transition: all 0.2s;
}
.em-tool-launch-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 5px 15px rgba(100, 255, 218, 0.3);
}

/* Memberships lists rows */
.em-membership-item-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: var(--em-main-bg);
	padding: 16px 20px;
	border-radius: 12px;
	border: 1px solid var(--em-border-color);
}
.em-membership-row-info strong {
	display: block;
	font-size: 15px;
	color: var(--em-primary-text);
}
.em-expiry-subtitle {
	font-size: 12px;
	color: var(--em-muted-text);
}

/* Status Badges on Cards */
.em-status-tag {
	font-size: 11px;
	font-weight: bold;
	padding: 4px 12px;
	border-radius: 12px;
	text-transform: capitalize;
}
.em-status-tag-active {
	background-color: rgba(62, 180, 137, 0.15);
	color: var(--em-primary-accent);
	border: 1px solid rgba(62, 180, 137, 0.3);
}
.em-status-tag-expired {
	background-color: rgba(255, 77, 77, 0.15);
	color: var(--em-alert-text);
	border: 1px solid rgba(255, 77, 77, 0.3);
}
.em-status-tag-cancelled {
	background-color: rgba(136, 146, 176, 0.15);
	color: var(--em-muted-text);
	border: 1px solid rgba(136, 146, 176, 0.3);
}

/* Empty states */
.em-empty-tools-state {
	text-align: center;
	padding: 30px 10px;
}
.em-empty-svg {
	width: 50px;
	height: 50px;
	color: var(--em-muted-text);
	margin-bottom: 14px;
}
.em-empty-tools-state p {
	color: var(--em-muted-text);
	font-size: 14px;
	margin-bottom: 18px;
}
.em-column-action-btn {
	background: linear-gradient(135deg, var(--em-primary-accent), var(--em-secondary-accent));
	color: var(--em-main-bg) !important;
	padding: 10px 22px;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 800;
	text-decoration: none !important;
	box-shadow: 0 4px 12px rgba(100, 255, 218, 0.2);
	display: inline-block;
}

/* -----------------------------
 * RESPONSIVENESS MEDIA QUERIES 
 * ----------------------------- */
@media (max-width: 768px) {
	.em-dashboard-grid {
		grid-template-columns: 1fr;
	}
	.em-dashboard-user-card {
		flex-direction: column;
		align-items: flex-start;
	}
	.em-user-meta-actions {
		width: 100%;
		justify-content: space-between;
	}
	.em-action-buttons {
		flex-direction: column;
		gap: 10px;
	}
	.em-lock-card {
		padding: 30px 20px;
	}
}

/* Gated Icon Keyframes */
@keyframes lock-wobble {
	0% { transform: rotate(0deg) scale(1); }
	45% { transform: rotate(0deg) scale(1); }
	50% { transform: rotate(-8deg) scale(1.03); }
	55% { transform: rotate(8deg) scale(1.03); }
	60% { transform: rotate(-4deg) scale(1.03); }
	65% { transform: rotate(4deg) scale(1.03); }
	70% { transform: rotate(0deg) scale(1); }
	100% { transform: rotate(0deg) scale(1); }
}
