/* =====================================================================
   EAI Member Directory — Frontend Styles
   ===================================================================== */

/* ─── Directory wrapper ─────────────────────────────────────────────── */
.eai-directory { max-width: 1200px; margin: 0 auto; }

/* ─── Filters ───────────────────────────────────────────────────────── */
.eai-filters { margin-bottom: 28px; display: flex; flex-direction: column; gap: 10px; }
.eai-filter-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.eai-filter-sep { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: #999; padding: 0 4px; flex-shrink: 0; }
.eai-filter-btn {
	display: inline-block;
	padding: 7px 16px;
	border: 1.5px solid #ddd;
	border-radius: 100px;
	background: #fff;
	color: #444;
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	transition: all .2s;
}
.eai-filter-btn:hover  { border-color: #2d6a4f; color: #2d6a4f; }
.eai-filter-btn.active { background: #2d6a4f; border-color: #2d6a4f; color: #fff; }

/* ─── Grid ──────────────────────────────────────────────────────────── */
.eai-grid {
	display: grid;
	gap: 24px;
}
.eai-cols-2 { grid-template-columns: repeat(2, 1fr); }
.eai-cols-3 { grid-template-columns: repeat(3, 1fr); }
.eai-cols-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
	.eai-cols-3, .eai-cols-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 580px) {
	.eai-cols-2, .eai-cols-3, .eai-cols-4 { grid-template-columns: 1fr; }
}

/* ─── Card ──────────────────────────────────────────────────────────── */
.eai-card {
	border-radius: 10px;
	overflow: hidden;
	box-shadow: 0 2px 12px rgba(0,0,0,.07);
	background: #fff;
	transition: box-shadow .2s, transform .2s;
}
.eai-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,.12); transform: translateY(-3px); }
.eai-card.eai-hidden { display: none; }

.eai-card-inner {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	color: inherit;
}

.eai-card-logo {
	height: 120px;
	background: #f0faf4;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}
.eai-card-logo img { max-height: 100px; max-width: 80%; object-fit: contain; }
.eai-card-logo-placeholder {
	width: 70px; height: 70px;
	border-radius: 50%;
	background: #2d6a4f;
	display: flex; align-items: center; justify-content: center;
}
.eai-card-logo-placeholder span { color: #fff; font-size: 28px; font-weight: 700; }

.eai-card-body { padding: 20px 20px 12px; flex: 1; }
.eai-card-title {
	font-size: 16px;
	font-weight: 700;
	color: #1b4332;
	margin: 0 0 6px;
	line-height: 1.3;
}
.eai-card-type {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .5px;
	color: #2d6a4f;
	background: #e8f5e9;
	padding: 2px 8px;
	border-radius: 4px;
	margin-bottom: 8px;
}
.eai-card-city { font-size: 13px; color: #777; margin-bottom: 10px; }
.eai-card-excerpt { font-size: 13px; line-height: 1.55; color: #555; margin: 0; }

.eai-card-footer { padding: 12px 20px; border-top: 1px solid #f0f0f0; }
.eai-read-more { font-size: 13px; font-weight: 600; color: #2d6a4f; }

/* ─── Single member page ─────────────────────────────────────────────  */
.eai-single-wrap { max-width: 1100px; margin: 0 auto; padding: 0 20px 60px; }

/* Back-to-directory bar */
.eai-back-bar { padding: 20px 0 0; }
.eai-back-bar-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 14px;
	font-weight: 600;
	color: #2d6a4f;
	text-decoration: none;
	padding: 8px 16px;
	border: 1.5px solid #2d6a4f;
	border-radius: 100px;
	transition: all .2s;
}
.eai-back-bar-link:hover {
	background: #2d6a4f;
	color: #fff;
}

.eai-single-header {
	display: flex;
	align-items: center;
	gap: 24px;
	padding: 32px 0 24px;
	border-bottom: 2px solid #e8f5e9;
	margin-bottom: 32px;
}
.eai-single-logo img { max-height: 100px; max-width: 160px; object-fit: contain; }
.eai-single-title { font-size: 30px; font-weight: 800; color: #1b4332; margin: 0 0 8px; }
.eai-single-type {
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .6px;
	color: #2d6a4f;
	background: #e8f5e9;
	padding: 4px 12px;
	border-radius: 100px;
}

.eai-single-body { display: grid; grid-template-columns: 280px 1fr; gap: 40px; }
@media (max-width: 760px) { .eai-single-body { grid-template-columns: 1fr; } }

/* Sidebar */
.eai-contact-card {
	background: #f9fafb;
	border: 1px solid #e4e4e4;
	border-radius: 10px;
	padding: 24px;
	position: sticky;
	top: 80px;
}
.eai-contact-card h3 { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: #999; margin: 0 0 16px; }
.eai-ci { display: flex; gap: 10px; margin-bottom: 12px; align-items: flex-start; font-size: 14px; line-height: 1.5; }
.eai-ci-icon { font-size: 16px; flex-shrink: 0; margin-top: 1px; }
.eai-ci a { color: #2d6a4f; text-decoration: none; }
.eai-ci a:hover { text-decoration: underline; }
.eai-back-link { display: inline-block; margin-top: 20px; font-size: 13px; color: #2d6a4f; text-decoration: none; font-weight: 600; }
.eai-back-link:hover { text-decoration: underline; }

/* Content sections */
.eai-section { margin-bottom: 36px; }
.eai-section h2 {
	font-size: 16px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .6px;
	color: #2d6a4f;
	margin: 0 0 12px;
	padding-bottom: 8px;
	border-bottom: 2px solid #e8f5e9;
}
.eai-section p { font-size: 15px; line-height: 1.75; color: #444; margin: 0; }

.eai-no-results { color: #999; font-size: 15px; text-align: center; padding: 40px 0; }
