section.projects.svelte-sbau9s{--card-max-width: 900px;--card-fixed-height: 300px;--image-ratio: 35%;--bg-card: #1c1c1f;--bg-border: #2d2d30;--accent-blue: #3b82f6;--glow-color: rgba(59, 130, 246, .4);--site-button-background: #3b82f6;--github-button-background: #1C3552;--moreinfo-button-background: #FF5B5B}.projects-container.svelte-sbau9s{display:flex;flex-direction:column;gap:2rem;max-width:var(--card-max-width);margin:0 auto;padding:2rem 1rem}.project-card.svelte-sbau9s{display:flex;flex-direction:row;background:var(--bg-card);border-radius:16px;border:1px solid var(--bg-border);overflow:hidden;height:var(--card-fixed-height);transition:transform .3s cubic-bezier(.4,0,.2,1),border-color .3s ease,box-shadow .3s ease}.project-card.svelte-sbau9s:hover{transform:translateY(-6px);border-color:var(--accent-blue);box-shadow:0 12px 30px -5px var(--glow-color)}.project-image.svelte-sbau9s{flex:0 0 var(--image-ratio);background:#252529;overflow:hidden}.project-image.svelte-sbau9s img:where(.svelte-sbau9s){width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.project-card.svelte-sbau9s:hover .project-image:where(.svelte-sbau9s) img:where(.svelte-sbau9s){transform:scale(1.08)}.project-info.svelte-sbau9s{flex:1;padding:2.5rem 3rem;display:flex;flex-direction:column}.text-top.svelte-sbau9s{flex-grow:1;display:flex;flex-direction:column;min-height:0}h3.svelte-sbau9s{margin:0 0 .5rem;font-size:2.2rem;font-weight:700;color:#fff;line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}p.svelte-sbau9s{margin:0 0 1rem;font-size:1.1rem;color:#a1a1aa;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.tags.svelte-sbau9s{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1rem}.tag.svelte-sbau9s{color:#fff;padding:4px 12px;border-radius:6px;font-size:1rem;font-weight:700;letter-spacing:.05em;border:none;text-shadow:0px 1px 2px rgba(0,0,0,.2)}.link-area.svelte-sbau9s{margin-top:auto;padding-top:1rem}.project-link.svelte-sbau9s{display:inline-block;background:var(--site-button-background);color:#fff;padding:.8rem 2.2rem;border-radius:8px;text-decoration:none;font-weight:600;transition:background .2s ease,filter .2s ease;margin-right:15px}.github-link.svelte-sbau9s{display:inline-block;background:var(--github-button-background);color:#fff;padding:.8rem 2.2rem;border-radius:8px;text-decoration:none;font-weight:600;transition:background .2s ease,filter .2s ease;margin-right:15px}.moreinfo-link.svelte-sbau9s{display:inline-block;background:var(--moreinfo-button-background);color:#fff;padding:.8rem 2.2rem;border-radius:8px;text-decoration:none;font-weight:600;transition:background .2s ease,filter .2s ease;margin-right:15px}.project-link.svelte-sbau9s:hover,.github-link.svelte-sbau9s:hover,.moreinfo-link.svelte-sbau9s:hover{background:#252529;filter:brightness(1.1)}@media(max-width:850px){.project-card.svelte-sbau9s{flex-direction:column;height:auto;min-height:0}.project-image.svelte-sbau9s{flex:0 0 auto;width:100%;border-bottom:1px solid var(--bg-border)}.project-image.svelte-sbau9s img:where(.svelte-sbau9s){object-fit:contain;width:100%;height:200px;display:block}.project-info.svelte-sbau9s{padding:1.5rem;gap:1rem}h3.svelte-sbau9s{font-size:1.5rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-link.svelte-sbau9s{display:block;text-align:center;background:var(--site-button-background);color:#fff;padding:.75rem;border-radius:8px;font-weight:600;margin-top:1rem}.github-link.svelte-sbau9s{display:block;text-align:center;background:var(--github-button-background);color:#fff;padding:.75rem;border-radius:8px;font-weight:600;margin-top:1rem}.moreinfo-link.svelte-sbau9s{display:block;text-align:center;background:var(--moreinfo-button-background);color:#fff;padding:.75rem;border-radius:8px;font-weight:600;margin-top:1rem}}div.image-wrapper.svelte-1uimds2{flex:1;display:flex;justify-content:center;align-items:center;width:100%}.hover-image.svelte-1uimds2{max-width:450px;width:80%;height:auto;object-fit:contain;transition:transform .4s cubic-bezier(.175,.885,.32,1.275),filter .4s ease;filter:brightness(1) contrast(1) drop-shadow(2px 0 0 #000000) drop-shadow(-2px 0 0 #000000) drop-shadow(0 2px 0 #000000) drop-shadow(0 -2px 0 #000000)}.hover-image.svelte-1uimds2:hover{transform:translateY(-15px) scale(1.02);filter:drop-shadow(0 0 25px rgba(6,122,255,.8))}
