/* PROJECTS.CSS */
.projects-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; position:relative; z-index:2; }

.proj-card {
  background:var(--card);
  border:1px solid var(--border-md);
  border-radius:12px;
  padding:1.75rem;
  display:flex;
  flex-direction:column;
  gap:0.55rem;
  position:relative;
  overflow:hidden;
  transition:border-color var(--tm),transform var(--tm),box-shadow var(--tm);
}
.proj-card::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent); opacity:0; transition:opacity var(--tm); }
.proj-card:hover { border-color:var(--border-hi); transform:translateY(-5px); box-shadow:0 25px 70px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.07); }
.proj-card:hover::before { opacity:1; }

/* All text visible on hover */
.proj-card:hover .proj-desc { color:var(--text-hi); }
.proj-card:hover .proj-stack { color:var(--muted2); }
.proj-card:hover .proj-domain { color:var(--muted2); }
.proj-card:hover .proj-num { color:var(--muted2); opacity:0.7; }

.proj-glow { position:absolute; bottom:-50px; right:-50px; width:200px; height:200px; border-radius:50%; background:radial-gradient(circle,rgba(255,255,255,0.05) 0%,transparent 70%); opacity:0; transition:opacity var(--tm); pointer-events:none; }
.proj-card:hover .proj-glow { opacity:1; }

.proj-featured { grid-column:span 2; }
.proj-all { grid-column:span 1; background:rgba(255,255,255,0.018); border-style:dashed; }

.proj-num { font-family:var(--fm); font-size:0.62rem; color:var(--muted); letter-spacing:0.1em; margin-bottom:0.15rem; opacity:0.5; transition:all var(--tf); }
.proj-emoji { font-size:1.75rem; }
.proj-title { font-family:var(--fd); font-size:1.08rem; font-weight:800; color:var(--white); line-height:1.2; }
.proj-stack { font-family:var(--fm); font-size:0.64rem; color:var(--muted); letter-spacing:0.05em; transition:color var(--tf); }
.proj-desc { font-size:0.86rem; color:var(--muted2); line-height:1.75; flex:1; transition:color var(--tf); }

.proj-footer { padding-top:0.75rem; border-top:1px solid var(--border); margin-top:auto; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:0.5rem; }
.proj-domain { font-family:var(--fm); font-size:0.6rem; color:var(--muted); letter-spacing:0.1em; text-transform:uppercase; transition:color var(--tf); }

.proj-links { display:flex; gap:0.65rem; align-items:center; }
.proj-link {
  display:inline-flex; align-items:center; gap:0.35rem;
  font-family:var(--fm); font-size:0.68rem; color:var(--muted2);
  text-decoration:none; cursor:none;
  border:1px solid var(--border); border-radius:3px;
  padding:0.2rem 0.55rem;
  transition:all var(--tf);
}
.proj-link:hover { color:var(--white); border-color:var(--border-hi); background:rgba(255,255,255,0.06); }
.proj-link svg { width:11px; height:11px; flex-shrink:0; }
