#kpProjects{
	--kp-card:#0b1220;
	--kp-muted:#9aa4b2;
	--kp-accent:#3b82f6;
	--kp-glass:rgba(0,0,0,0.04);
	--kp-radius:12px;
}
#kpProjects .kp-grid{
	display:grid;
	grid-template-columns:repeat(3, 1fr);
	gap:20px;
}
@media (max-width:980px){
	#kpProjects .kp-grid{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width:640px){
	#kpProjects .kp-grid{grid-template-columns:1fr}
}
#kpProjects .kp-card{
	position:relative;
	height:220px;
	border-radius:var(--kp-radius);
	overflow:hidden;
	background:var(--kp-card);
	cursor:pointer;
	box-shadow:0 6px 18px rgba(2,6,23,0.35);
	transition: transform .18s ease, box-shadow .18s ease;
	display:flex;
	align-items:flex-end;
	color:#e6eef7;
}
#kpProjects .kp-card:hover{ transform:translateY(-6px); box-shadow:0 12px 30px rgba(2,6,23,0.45); }
#kpProjects .kp-bg{
	position:absolute; inset:0; background-size:cover; background-position:center;
	filter:contrast(.95) saturate(.95) brightness(.6);
	transform:scale(1); transition:transform .5s ease;
}
#kpProjects .kp-card:hover .kp-bg{ transform:scale(1.06); }
#kpProjects .kp-overlay{
	position:relative; z-index:2; padding:16px; width:100%;
	background:linear-gradient(180deg, rgba(6,10,18,0) 0%, rgba(6,10,18,0.48) 40%, rgba(6,10,18,0.72) 100%);
	display:flex; flex-direction:column; gap:6px;
}
#kpProjects .kp-title{ font-weight:600; font-size:16px; }
#kpProjects .kp-desc{ font-size:13px; color:var(--kp-muted); max-height:48px; overflow:hidden; }
#kpProjects .kp-tag-row{ display:flex; gap:8px; margin-top:6px; flex-wrap:wrap }
#kpProjects .kp-tag{ font-size:12px; color:var(--kp-accent); background:rgba(59,130,246,0.08); padding:6px 8px; border-radius:8px; }

/* Modal */
.kp-modal-backdrop{ position:fixed; inset:0; background:rgba(0,0,0,0.5); display:none; align-items:center; justify-content:center; z-index:999; padding:24px; }
.kp-modal-backdrop.show{ display:flex; }
.kp-modal{ width:100%; max-width:900px; background:#ffffff; border-radius:14px; overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,0.25); color:#272727; max-height:92vh; display:flex; flex-direction:column; border:1px solid #e5e7eb; }
.kp-modal-body{ padding:18px; overflow:auto; }
.kp-modal-header{ display:flex; align-items:center; justify-content:space-between; padding:14px 18px; border-bottom:1px solid #e5e7eb; background:#ffffff; }
.kp-modal-header h2{ margin:0; font-size:18px; color:#272727 }
.kp-close-btn{ background:#ffffff; border:1px solid #e5e7eb; color:#555555; padding:8px 12px; border-radius:10px; cursor:pointer; font-weight:600; }
.kp-hero{ width:100%; height:260px; background-size:cover; background-position:center; border-radius:8px; margin-bottom:12px; }
.kp-cols{ display:grid; grid-template-columns:1fr 320px; gap:18px; }
@media (max-width:880px){ .kp-cols{ grid-template-columns: 1fr; } .kp-hero{ height:200px; } }
.kp-panel{ background:#f8f8f8; padding:12px; border-radius:10px; color:#333333; font-size:14px; border:1px solid #e5e7eb; }
.kp-panel h3{ margin:0 0 8px 0; font-size:14px; color:#272727; }
.kp-meta-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:8px; font-size:13px; color:#555555 }
