a.project-card{color:inherit;text-decoration:none;display:block}.project-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:18px;transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s cubic-bezier(.22,1,.36,1),border-color .35s;position:relative}.project-card__skeleton{z-index:1;background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%) 0 0/200% 100%;animation:1.4s linear infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}[data-theme=dark] .project-card__skeleton{background:linear-gradient(90deg,#111d11 25%,#162416 50%,#111d11 75%) 0 0/200% 100%}.project-card--featured{border-color:#fbbf24;box-shadow:0 0 0 1px #fbbf2433,0 4px 20px #fbbf2414}.project-card--featured:hover{border-color:#f59e0b;box-shadow:0 20px 50px #00000021,0 4px 16px #fbbf2433}.project-card__badges{z-index:5;pointer-events:none;flex-direction:column;align-items:flex-end;gap:4px;display:flex;position:absolute;top:12px;right:12px}.project-card__badge{letter-spacing:.6px;text-transform:uppercase;border-radius:100px;align-items:center;gap:4px;padding:4px 10px;font-size:10px;font-weight:800;display:inline-flex}.project-card__badge--featured{color:#78350f;background:linear-gradient(135deg,#f59e0b,#fbbf24);box-shadow:0 2px 10px #fbbf2466}.project-card__badge--new{background:linear-gradient(135deg, var(--green-600), var(--green-500));color:#fff;box-shadow:0 2px 10px #22c55e66}.project-card__shine{z-index:10;pointer-events:none;border-radius:18px;transition:background .1s;position:absolute;inset:0}.project-card:before{content:"";background:linear-gradient(135deg, var(--green-500), #86efac);opacity:0;z-index:0;-webkit-mask-composite:xor;border-radius:18px;padding:1px;transition:opacity .35s;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.project-card:hover{border-color:#d1fae5;transform:translateY(-8px)scale(1.01);box-shadow:0 20px 50px #00000021,0 4px 16px #16a34a14}.project-card:hover:before{opacity:1}.project-card__image-wrap{aspect-ratio:16/10;background:#f3f4f6;border-radius:18px 18px 0 0;position:relative;overflow:hidden}.project-card__image{object-fit:cover;z-index:2;opacity:0;width:100%;height:100%;transition:opacity .3s,transform .5s cubic-bezier(.22,1,.36,1);display:block;position:relative}.project-card__image--loaded{opacity:1}.project-card:hover .project-card__image{transform:scale(1.06)}.project-card__placeholder{background:linear-gradient(135deg,#0d160d 0%,#111d11 100%);flex-direction:column;justify-content:center;align-items:center;gap:10px;width:100%;height:100%;display:flex}.project-card__placeholder-initials{background:linear-gradient(135deg, var(--green-700), var(--green-500));color:#fff;letter-spacing:1px;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:18px;font-weight:800;display:flex;box-shadow:0 0 20px #22c55e4d}.project-card__placeholder-name{color:#ffffff59;text-align:center;padding:0 16px;font-size:12px;font-weight:500}.project-card__overlay{opacity:0;background:linear-gradient(#14321940 0%,#0f2814a6 45%,#0a140ceb 100%);flex-direction:column;justify-content:flex-end;align-items:flex-start;padding:20px;transition:opacity .3s;display:flex;position:absolute;inset:0}.project-card:hover .project-card__overlay{opacity:1}.project-card__overlay-title{color:#fff;margin:0 0 6px;font-size:16px;font-weight:700;line-height:1.3;transition:transform .3s 50ms;transform:translateY(6px)}.project-card__overlay-desc{color:#ffffffd9;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0 0 14px;font-size:13px;line-height:1.5;transition:transform .3s 80ms;display:-webkit-box;overflow:hidden;transform:translateY(6px)}.project-card:hover .project-card__overlay-title,.project-card:hover .project-card__overlay-desc{transform:translateY(0)}.project-card__overlay-btn{color:var(--green-700);opacity:0;background:#fff;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:700;text-decoration:none;transition:opacity .3s .12s,transform .3s .12s;display:inline-flex;transform:translateY(4px)}.project-card:hover .project-card__overlay-btn{opacity:1;transform:translateY(0)}.project-card__overlay-btn:hover{background:var(--green-50);transform:translateY(-2px)!important}.project-card__overlay-soon{color:#ffffff59;letter-spacing:.5px;border:1px solid #ffffff26;border-radius:100px;padding:5px 12px;font-size:12px;font-weight:600}.project-card__body{z-index:1;background:#fff;flex-direction:column;gap:6px;padding:14px 16px 16px;display:flex;position:relative}.project-card__meta-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.project-card__grade-badge{background:var(--green-50);color:var(--green-600);letter-spacing:.5px;border:1px solid var(--green-200);border-radius:100px;flex-shrink:0;align-items:center;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.project-card__project-name{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;letter-spacing:-.3px;background:linear-gradient(90deg, #0f172a 50%, var(--green-600) 50%);-webkit-text-fill-color:transparent;background-position:0%;background-size:200% 100%;-webkit-background-clip:text;background-clip:text;margin:0;font-size:17px;font-weight:800;line-height:1.25;transition:background-position .4s cubic-bezier(.22,1,.36,1);overflow:hidden}.project-card:hover .project-card__project-name{background-position:-100%}.project-card__student{color:#9ca3af;align-items:center;gap:5px;min-width:0;font-size:12px;font-weight:500;display:flex}.project-card__student span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.project-card__student svg{color:#d1d5db;flex-shrink:0}.project-card__student--clickable{cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;transition:color .15s}.project-card__student--clickable:hover{color:var(--green-600)}.project-card__student--clickable:hover svg{color:var(--green-500)}.project-card__desc-snippet{color:#6b7280;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:12px;line-height:1.45;display:-webkit-box;overflow:hidden}.project-card__tags{flex-wrap:wrap;gap:4px;margin-top:2px;display:flex}.project-card__tag{color:#6b7280;letter-spacing:.3px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:100px;padding:2px 7px;font-size:10px;font-weight:600}[data-theme=dark] .project-card{background:var(--bg-card);border-color:var(--border-card)}[data-theme=dark] .project-card:hover{border-color:var(--green-700);box-shadow:0 20px 50px #0006,0 4px 16px #16a34a26}[data-theme=dark] .project-card__body{background:var(--bg-card)}[data-theme=dark] .project-card__image-wrap{background:#0d160d}[data-theme=dark] .project-card__project-name{background:linear-gradient(90deg, var(--text) 50%, var(--green-400) 50%);-webkit-text-fill-color:transparent;background-position:0%;background-size:200% 100%;-webkit-background-clip:text;background-clip:text;transition:background-position .4s cubic-bezier(.22,1,.36,1)}[data-theme=dark] .project-card:hover .project-card__project-name{background-position:-100%}[data-theme=dark] .project-card__student,[data-theme=dark] .project-card__student svg{color:var(--text-subtle)}[data-theme=dark] .project-card__grade-badge{background:#16a34a1f;border-color:#16a34a40}[data-theme=dark] .project-card__desc-snippet{color:var(--text-muted)}[data-theme=dark] .project-card__tag{color:var(--text-subtle);background:#ffffff0d;border-color:#ffffff1a}[data-theme=dark] .project-card__student--clickable:hover{color:var(--green-400)}
