.modal-backdrop.svelte-1frpe4w{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:svelte-1frpe4w-fadeIn .3s ease}@keyframes svelte-1frpe4w-fadeIn{0%{opacity:0}to{opacity:1}}.modal-content.svelte-1frpe4w{background:#fff;border-radius:16px;max-width:90vw;max-height:90vh;width:900px;overflow-y:auto;position:relative;box-shadow:0 25px 50px -12px #00000040;animation:svelte-1frpe4w-slideUp .3s ease}@keyframes svelte-1frpe4w-slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.loading-overlay.svelte-1frpe4w{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.loading-spinner.svelte-1frpe4w{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #4f46e5;border-radius:50%;animation:svelte-1frpe4w-spin 1s linear infinite;margin-bottom:16px}@keyframes svelte-1frpe4w-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.close-btn.svelte-1frpe4w{position:absolute;top:20px;right:20px;background:none;border:none;font-size:24px;cursor:pointer;z-index:10;color:#666;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn.svelte-1frpe4w:hover{background:#f3f4f6;color:#000}.nav-btn.svelte-1frpe4w{position:absolute;top:50%;transform:translateY(-50%);background:#fffffff2;border:none;width:60px;height:60px;border-radius:50%;font-size:28px;cursor:pointer;z-index:1001;transition:all .3s ease;box-shadow:0 8px 25px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;color:#374151;font-weight:700}.nav-btn.svelte-1frpe4w:hover{background:#fff;transform:translateY(-50%) scale(1.1);box-shadow:0 12px 35px #0003;color:#111827}.nav-btn.svelte-1frpe4w:active{transform:translateY(-50%) scale(.95)}.nav-btn.prev.svelte-1frpe4w{left:min(400px,calc(50vw - 550px))}.nav-btn.next.svelte-1frpe4w{right:min(400px,calc(50vw - 550px))}.project-details.svelte-1frpe4w{padding:30px}.project-header.svelte-1frpe4w{display:flex;gap:20px;margin-bottom:32px;align-items:flex-start}.project-icon.svelte-1frpe4w{width:80px;height:80px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.project-icon.svelte-1frpe4w img:where(.svelte-1frpe4w){width:60px;height:60px;object-fit:contain}.project-icon.svelte-1frpe4w span:where(.svelte-1frpe4w){color:#fff;font-size:2rem;font-weight:600}.project-info.svelte-1frpe4w{flex:1}.project-info.svelte-1frpe4w h1:where(.svelte-1frpe4w){margin:0 0 8px;font-size:2rem;color:#1a1a1a}.project-description.svelte-1frpe4w{font-size:1.1rem;line-height:1.6;color:#666;margin:0 0 16px}.project-meta.svelte-1frpe4w{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.language-tag.svelte-1frpe4w{padding:6px 12px;border-radius:12px;color:#fff;font-size:.9rem;font-weight:600}.stars.svelte-1frpe4w,.forks.svelte-1frpe4w{font-size:.9rem;color:#666;display:flex;align-items:center;gap:4px}.github-info.svelte-1frpe4w{background:#f8f9fa;padding:24px;border-radius:12px;margin-bottom:32px}.github-info.svelte-1frpe4w h3:where(.svelte-1frpe4w){margin:0 0 20px;color:#1a1a1a;font-size:1.2rem}.info-grid.svelte-1frpe4w{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item.svelte-1frpe4w{display:flex;flex-direction:column;gap:4px}.info-item.svelte-1frpe4w strong:where(.svelte-1frpe4w){color:#374151;font-size:.9rem}.commit-info.svelte-1frpe4w{display:flex;flex-direction:column;gap:2px}.commit-message.svelte-1frpe4w{color:#111827;font-weight:500}.commit-date.svelte-1frpe4w{color:#6b7280;font-size:.8rem}.topics-section.svelte-1frpe4w{grid-column:1 / -1}.topics-list.svelte-1frpe4w{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.topic-badge.svelte-1frpe4w{background:#e5e7eb;color:#374151;padding:4px 8px;border-radius:6px;font-size:.8rem;font-weight:500}.readme-section.svelte-1frpe4w{margin-bottom:32px}.readme-section.svelte-1frpe4w h3:where(.svelte-1frpe4w){margin:0 0 20px;color:#1a1a1a;font-size:1.2rem}.readme-content.svelte-1frpe4w{background:#fafafa;border:1px solid #e5e7eb;border-radius:8px;padding:20px;max-height:400px;overflow-y:auto}.readme-content.svelte-1frpe4w h1,.readme-content.svelte-1frpe4w h2,.readme-content.svelte-1frpe4w h3{color:#1a1a1a;margin-top:0}.readme-content.svelte-1frpe4w pre{background:#f3f4f6;padding:12px;border-radius:6px;overflow-x:auto}.readme-content.svelte-1frpe4w code{background:#f3f4f6;padding:2px 4px;border-radius:3px;font-size:.9em}.no-readme.svelte-1frpe4w{color:#6b7280;font-style:italic;text-align:center;padding:40px}.action-buttons.svelte-1frpe4w{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.btn-primary.svelte-1frpe4w,.btn-secondary.svelte-1frpe4w{padding:12px 24px;border-radius:8px;text-decoration:none;font-weight:600;transition:all .2s ease;text-align:center;display:flex;align-items:center;gap:8px}.btn-primary.svelte-1frpe4w{background:#4f46e5;color:#fff}.btn-primary.svelte-1frpe4w:hover{background:#4338ca;transform:translateY(-1px)}.btn-secondary.svelte-1frpe4w{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.btn-secondary.svelte-1frpe4w:hover{background:#e5e7eb;transform:translateY(-1px)}@media (max-width: 1200px){.nav-btn.prev.svelte-1frpe4w{left:20px}.nav-btn.next.svelte-1frpe4w{right:20px}}@media (max-width: 768px){.modal-content.svelte-1frpe4w{width:95vw;height:95vh;border-radius:12px}.project-details.svelte-1frpe4w{padding:20px}.project-header.svelte-1frpe4w{flex-direction:column;text-align:center}.nav-btn.svelte-1frpe4w{width:50px;height:50px;font-size:24px}.nav-btn.prev.svelte-1frpe4w{left:10px}.nav-btn.next.svelte-1frpe4w{right:10px}.action-buttons.svelte-1frpe4w{flex-direction:column}.info-grid.svelte-1frpe4w{grid-template-columns:1fr}}@media (max-width: 480px){.nav-btn.svelte-1frpe4w{width:45px;height:45px;font-size:20px}.nav-btn.prev.svelte-1frpe4w{left:5px}.nav-btn.next.svelte-1frpe4w{right:5px}}section.svelte-71z0ag{display:flex;flex-direction:column;max-width:100%;width:100%;min-height:100vh;justify-content:start;align-items:center;background:#fff}h2.svelte-71z0ag{margin-bottom:8px;font-size:3rem;font-weight:600;color:#1a1a1a;text-align:center}section.svelte-71z0ag>.wrapText:where(.svelte-71z0ag){display:flex;flex-direction:column;width:100%;max-width:600px;background:none;border:none;margin-bottom:5vh;cursor:pointer}section.svelte-71z0ag>.wrapText:where(.svelte-71z0ag) p:where(.svelte-71z0ag){font-size:1.4rem;font-weight:700;margin:0;text-align:center;color:#666}section.svelte-71z0ag>.wrapText:where(.svelte-71z0ag)>.hint:where(.svelte-71z0ag){position:relative;font-size:.6rem;text-align:center;color:#666}section.svelte-71z0ag>.wrapText:where(.svelte-71z0ag) .hint:where(.svelte-71z0ag):after{content:"Projects are fetched live from my GitHub repositories using the GitHub API. The app parses repository topics(used as parameters) and metadata to auto-generate and update project cards, no manual code needed.";position:absolute;opacity:0;transition:.3s;width:70%;height:auto;text-wrap:wrap;pointer-events:none;line-height:1.4;top:0;left:50%}section.svelte-71z0ag>.wrapText:where(.svelte-71z0ag) .hint:where(.svelte-71z0ag):hover:after{top:-30px;left:80%;background:#000c;color:#fff;padding:5px 10px;border-radius:4px;font-size:12px;z-index:10;opacity:1}.filters.svelte-71z0ag{display:flex;justify-content:center;align-items:center;gap:30px;width:100%;max-width:800px;margin:0 0 50px;padding:20px;background:#f8f9fa;border-radius:12px;box-shadow:0 2px 8px #0000000d;flex-wrap:wrap}.filters.svelte-71z0ag>div:where(.svelte-71z0ag){display:flex;flex-direction:column;align-items:center;gap:8px}.filters.svelte-71z0ag label:where(.svelte-71z0ag){font-size:.9rem;font-weight:500;color:#555;text-transform:uppercase;letter-spacing:.5px}.filters.svelte-71z0ag select:where(.svelte-71z0ag){padding:8px 12px;border:2px solid #e1e5e9;border-radius:6px;background:#fff;font-size:.9rem;color:#333;cursor:pointer;transition:all .2s ease;min-width:120px}.filters.svelte-71z0ag select:where(.svelte-71z0ag):hover{border-color:#4f46e5}.filters.svelte-71z0ag select:where(.svelte-71z0ag):focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.projects-container.svelte-71z0ag{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;width:100%;max-width:1200px;perspective:1200px;justify-items:center;margin-bottom:30px}.project-card.svelte-71z0ag{display:flex;flex-direction:column;background:#fff;border-radius:12px;width:100%;max-width:350px;min-height:400px;box-shadow:5px 5px 5px #000,5px 5px 5px 5px #0000;text-shadow:2px 0 #000000,-2px 0 #000000,0 2px #000000,0 -2px #000000,1px 1px #000000,-1px -1px #000000,1px -1px #000000,-1px 1px #000000;transition:all .4s ease;overflow:hidden;border:1px solid #e5e7eb;position:relative;cursor:pointer}.project-card.svelte-71z0ag:hover{transform:scale(1.05) translateY(-10px);filter:brightness(.95)}.project-card.svelte-71z0ag h3:where(.svelte-71z0ag){text-transform:uppercase;color:#fff;margin:0;font-size:1.3rem;font-weight:600;padding:20px 20px 16px;background:inherit}.project-card.svelte-71z0ag img:where(.svelte-71z0ag){width:100%;height:auto;padding-left:10vw;padding-right:10vw;padding-top:20px;padding-bottom:20px;max-width:220px;object-fit:contain;background:#fff;border-radius:8px;justify-self:center;align-self:center}.project-card.svelte-71z0ag>p:where(.svelte-71z0ag){padding:0 20px;margin:16px 0;font-size:.9rem;line-height:1.5;color:#fff;flex-grow:1}.project-card.svelte-71z0ag>div:where(.svelte-71z0ag):nth-of-type(2){padding:0 20px 16px;display:flex;flex-direction:column;gap:12px}.project-link.svelte-71z0ag{display:inline-block;color:#fff;text-decoration:none;font-weight:600;font-size:.85rem;padding:10px 16px;border-radius:6px;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer}.project-link.svelte-71z0ag:hover{transform:translateY(-1px);text-decoration:underline}.topics.svelte-71z0ag{top:20px;right:10px;position:absolute}.topics.svelte-71z0ag ul:where(.svelte-71z0ag){list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px}.topics.svelte-71z0ag li:where(.svelte-71z0ag){display:flex;align-items:center;background:#c7c7c7b3;color:#494949e6;padding:4px 10px;border-radius:12px;font-size:.7rem;font-weight:500;border:1px solid rgba(255,255,255,.2);transition:all .2s ease;text-align:center}.topics.svelte-71z0ag li:where(.svelte-71z0ag):hover{background:#ffffff4d;border-color:#fff6}.language-bubble.svelte-71z0ag{display:flex;align-items:center;border-radius:12px;border:1px solid rgba(255,255,255,.2);transition:all .2s ease;text-align:center;color:#fff!important;font-weight:600!important;border:2px solid rgba(255,255,255,.4)!important;padding:5px 12px!important;font-size:1rem!important;cursor:pointer}.language-bubble.svelte-71z0ag:hover{border-color:#000000c4!important}.projects-container.svelte-71z0ag>p:where(.svelte-71z0ag){grid-column:1 / -1;text-align:center;font-size:1.1rem;color:#888;padding:60px 20px;background:#f8f9fa;border-radius:12px;border:2px dashed #ddd}@media (max-width: 768px){h2.svelte-71z0ag{font-size:2.5rem}.filters.svelte-71z0ag{flex-direction:column;gap:20px;padding:20px 15px}.filters.svelte-71z0ag>div:where(.svelte-71z0ag){width:90%}.filters.svelte-71z0ag select:where(.svelte-71z0ag){width:90%}.projects-container.svelte-71z0ag{width:80%;grid-template-columns:1fr;gap:20px}.project-card.svelte-71z0ag{max-width:90%}section.svelte-71z0ag>.wrapText:where(.svelte-71z0ag) .hint:where(.svelte-71z0ag){display:flex;flex-direction:column;justify-content:center;align-items:center}section.svelte-71z0ag>.wrapText:where(.svelte-71z0ag) .hint:where(.svelte-71z0ag):after{position:relative;left:0;top:-50px}section.svelte-71z0ag>.wrapText:where(.svelte-71z0ag) .hint:where(.svelte-71z0ag):hover:after{left:0;top:10px}}@media (max-width: 480px){h2.svelte-71z0ag{font-size:2rem}.project-card.svelte-71z0ag h3:where(.svelte-71z0ag){font-size:1.2rem;padding:16px 16px 12px}.project-card.svelte-71z0ag>p:where(.svelte-71z0ag){padding:0 16px}.project-card.svelte-71z0ag>div:where(.svelte-71z0ag):nth-of-type(2){padding:0 16px 12px}}
