/** * Projects Page - Grid, Cards, Filters, GitHub CTA */ /* Projects Grid */ .projects-bento { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--space-lg); } .projects-section { margin-bottom: var(--space-2xl); } .projects-section + .projects-section { margin-top: var(--space-3xl); padding-top: var(--space-2xl); border-top: 1px solid var(--border-color); } /* Project Card */ .project-card { background: var(--bg-card); border: 1px solid var(--border-color); border-radius: var(--radius-xl); overflow: hidden; transition: var(--transition); position: relative; } .project-card:hover { border-color: var(--primary-color); transform: translateY(-4px); box-shadow: var(--shadow-lg); } .project-card.featured { grid-column: span 8; display: grid; grid-template-columns: 1fr 1fr; } .project-card.featured .project-image { height: 100%; min-height: 320px; } .project-card.regular { grid-column: span 4; } .project-card.small { grid-column: span 3; } .project-image { position: relative; height: 200px; overflow: hidden; background: var(--bg-elevated); } .project-image img { width: 100%; height: 100%; object-fit: cover; transition: var(--transition-slow); } .project-card:hover .project-image img { transform: scale(1.05); } .project-image-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--bg-elevated) 0%, var(--bg-card) 100%); } .project-image-placeholder i { font-size: 3rem; color: var(--border-light); } .project-logo { position: absolute; top: var(--space-md); left: var(--space-md); width: 48px; height: 48px; background: var(--bg-dark); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; border: 1px solid var(--border-color); } .project-logo i { font-size: 1.25rem; color: var(--primary-color); } .project-logo-small { width: 56px; height: 56px; background: var(--primary-muted); border-radius: var(--radius-lg); display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-md); } .project-logo-small i { font-size: 1.5rem; color: var(--primary-color); } .project-status { position: absolute; top: var(--space-md); right: var(--space-md); padding: 0.3rem 0.7rem; border-radius: var(--radius-full); font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; } .project-status.primary { background: var(--primary-muted); color: var(--primary-color); } .project-status.success, .project-status.completed { background: rgba(34, 197, 94, 0.2); color: var(--success-color); } .project-status.warning { background: rgba(245, 158, 11, 0.2); color: var(--warning-color); } .project-status.info { background: rgba(59, 130, 246, 0.2); color: var(--info-color); } .project-status.beta { background: var(--primary-muted); color: var(--primary-color); } .project-status.secondary { background: var(--bg-elevated); color: var(--text-secondary); } .project-content { padding: var(--space-lg); } .project-card.small .project-content { text-align: center; display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; min-height: 200px; } .project-title { font-size: 1.25rem; margin-bottom: var(--space-sm); display: flex; align-items: center; gap: var(--space-sm); flex-wrap: wrap; } .project-card.small .project-title { font-size: 1rem; justify-content: center; } .project-users { font-size: 0.8rem; color: var(--primary-color); font-weight: 500; display: inline-flex; align-items: center; gap: 0.25rem; } .project-description { color: var(--text-secondary); font-size: 0.9rem; margin-bottom: var(--space-md); line-height: 1.6; } .project-features { list-style: none; margin: 0 0 var(--space-md) 0; padding: 0; } .project-features li { display: flex; align-items: flex-start; gap: var(--space-sm); font-size: 0.85rem; color: var(--text-secondary); margin-bottom: var(--space-sm); } .project-features li i { color: var(--primary-color); margin-top: 0.2em; flex-shrink: 0; } .project-tech { display: flex; flex-wrap: wrap; gap: var(--space-sm); margin-bottom: var(--space-md); } .project-card.small .project-tech { justify-content: center; margin-bottom: 0; } .project-links { display: flex; gap: var(--space-sm); flex-wrap: wrap; } .project-link { display: inline-flex; align-items: center; gap: var(--space-sm); color: var(--text-secondary); font-size: 0.85rem; padding: var(--space-sm) var(--space-md); background: var(--bg-elevated); border-radius: var(--radius-sm); transition: var(--transition); text-decoration: none; } .project-link:hover { color: var(--primary-color); background: var(--primary-muted); } /* Filters */ .filters-section { margin-bottom: var(--space-2xl); } .filters-wrapper { display: flex; flex-wrap: wrap; gap: var(--space-xl); align-items: center; } .filter-group { display: flex; align-items: center; gap: var(--space-md); } .filter-label { font-size: 0.9rem; color: var(--text-muted); font-weight: 500; } .filter-buttons { display: flex; gap: var(--space-sm); } .filter-btn { display: inline-flex; align-items: center; gap: var(--space-sm); padding: var(--space-sm) var(--space-md); background: var(--bg-card); border: 1px solid var(--border-color); border-radius: var(--radius-md); color: var(--text-secondary); font-size: 0.85rem; font-weight: 500; text-decoration: none; transition: var(--transition); } .filter-btn:hover { border-color: var(--primary-color); color: var(--primary-color); } .filter-btn.active { background: var(--primary-color); border-color: var(--primary-color); color: var(--text-primary); } .filter-select { background: var(--bg-card); border: 1px solid var(--border-color); border-radius: var(--radius-md); padding: var(--space-sm) var(--space-md); color: var(--text-primary); font-size: 0.85rem; cursor: pointer; min-width: 180px; } .filter-select:focus { outline: none; border-color: var(--primary-color); } /* GitHub CTA */ .github-cta { grid-column: span 3; display: flex; align-items: center; justify-content: center; min-height: 200px; } .github-cta-content { text-align: center; } .github-cta-content i { font-size: 3rem; color: var(--text-muted); margin-bottom: var(--space-md); } .github-cta-content p { font-size: 0.9rem; color: var(--text-secondary); margin-bottom: var(--space-md); } .github-cta-section { margin-top: var(--space-2xl); } .github-cta-card { background: var(--bg-card); border: 1px solid var(--border-color); border-radius: var(--radius-xl); padding: var(--space-2xl); display: flex; align-items: center; gap: var(--space-xl); transition: var(--transition); } .github-cta-card:hover { border-color: var(--primary-color); } .github-cta-card > i { font-size: 3rem; color: var(--text-muted); } .github-cta-text { flex: 1; } .github-cta-text h3 { margin-bottom: var(--space-sm); } .github-cta-text p { margin: 0; }