*{box-sizing:border-box;margin:0;padding:0}:root{--background:#fff;--foreground:#475569;--card:#f1f5f9;--card-foreground:#475569;--primary:#059669;--primary-foreground:#fff;--secondary:#10b981;--secondary-foreground:#fff;--muted:#f1f5f9;--muted-foreground:#64748b;--accent:#10b981;--accent-foreground:#fff;--border:#e5e7eb;--input:#f1f5f9;--ring:#05966980;--radius:.5rem;--font-sans:"Geist Sans",system-ui,-apple-system,sans-serif;--font-mono:"Geist Mono","Courier New",monospace}body{font-family:var(--font-sans);background-color:var(--background);color:var(--foreground);line-height:1.6}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.header{z-index:50;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fffffff2;width:100%;position:sticky;top:0}.header-content{justify-content:space-between;align-items:center;height:4rem;padding:0 1rem;display:flex}.logo{align-items:center;gap:.5rem;display:flex}.logo-icon{background-color:var(--primary);border-radius:50%;width:2rem;height:2rem}.logo-text{color:var(--foreground);font-size:1.25rem;font-weight:700}.nav{align-items:center;gap:1.5rem;display:none}.nav-link{color:var(--muted-foreground);font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-link:hover{color:var(--foreground)}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{background-color:var(--primary);color:var(--primary-foreground)}.btn-primary:hover{background-color:#059669e6}.btn-outline{color:var(--foreground);border:1px solid var(--border);background-color:#0000}.btn-outline:hover{background-color:var(--muted)}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.about-section{background-color:var(--card);padding:5rem 0}.about-grid{align-items:center;gap:3rem;max-width:72rem;margin:0 auto;display:grid}.about-content{flex-direction:column;gap:1.5rem;display:flex}.about-header{flex-direction:column;gap:1rem;display:flex}.about-title{color:var(--foreground);font-size:2.5rem;font-weight:700;line-height:1.2}.about-subtitle{color:var(--muted-foreground);font-size:1.25rem}.highlight{color:var(--primary)}.about-text{flex-direction:column;gap:1rem;display:flex}.about-paragraph{color:var(--muted-foreground);line-height:1.7}.button-group{flex-wrap:wrap;gap:.75rem;display:flex}.about-image-container{justify-content:center;display:flex}.image-wrapper{position:relative}.image-frame{background:linear-gradient(135deg,#05966933,#10b98133);border-radius:1rem;height:20rem;padding:.25rem}.profile-image{object-fit:cover;border-radius:.75rem;width:100%;height:100%}a:visited{color:inherit}.image-badge{background-color:var(--primary);border-radius:50%;justify-content:center;align-items:center;width:6rem;height:6rem;font-size:1.5rem;display:flex;position:absolute;bottom:-1rem;right:-1rem}.projects-section{background-color:var(--background);padding:5rem 0}.projects-header{text-align:center;margin-bottom:3rem}.projects-title{color:var(--foreground);margin-bottom:1rem;font-size:2.5rem;font-weight:700}.projects-subtitle{color:var(--muted-foreground);max-width:600px;margin:0 auto;font-size:1.125rem}.projects-grid{gap:2rem;margin-bottom:3rem;display:grid}.project-card{background-color:var(--card);border-radius:var(--radius);cursor:pointer;transition:transform .2s,box-shadow .2s;overflow:hidden}.project-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px #0000001a}.project-image{object-fit:cover;width:100%;height:12rem}.project-content{padding:1.5rem}.project-title{color:var(--foreground);margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.project-description{color:var(--muted-foreground);margin-bottom:1rem;line-height:1.6}.project-tags{flex-wrap:wrap;gap:.5rem;display:flex}.project-tag{background-color:var(--primary);color:var(--primary-foreground);border-radius:9999px;padding:.25rem .75rem;font-size:.75rem;font-weight:500}.projects-list{flex-direction:column;gap:4rem;max-width:72rem;margin:0 auto;display:flex}.project-item{flex-direction:column;gap:1.5rem;display:flex}.project-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.project-item-title{color:var(--foreground);font-size:1.875rem;font-weight:700}.project-links{gap:.75rem;display:flex}.project-item-description{color:var(--muted-foreground);max-width:64rem;font-size:1.125rem;line-height:1.7}.project-item-tags{flex-wrap:wrap;gap:.5rem;display:flex}.project-item-tag{background-color:var(--secondary);color:var(--secondary-foreground);border-radius:9999px;padding:.25rem .75rem;font-size:.875rem;font-weight:500}.project-screenshots{gap:1rem;display:grid}.screenshot-item{cursor:pointer;border-radius:var(--radius);border:1px solid var(--border);transition:all .3s;position:relative;overflow:hidden}.screenshot-item:hover{border-color:#05966933}.screenshot-image{object-fit:cover;width:100%;height:12rem;transition:transform .3s}.screenshot-item:hover .screenshot-image{transform:scale(1.05)}.screenshot-overlay{background-color:#0000;justify-content:center;align-items:center;transition:all .3s;display:flex;position:absolute;inset:0}.screenshot-item:hover .screenshot-overlay{background-color:#0000001a}.screenshot-icon{opacity:0;background-color:#ffffffe6;border-radius:50%;padding:.5rem;transition:opacity .3s}.screenshot-item:hover .screenshot-icon{opacity:1}.project-separator{border-top:1px solid #e5e7eb80;padding-top:2rem}.footer{background-color:var(--card);border-top:1px solid var(--border);padding:3rem 0 2rem}.footer-content{gap:2rem;margin-bottom:2rem;display:grid}.footer-section h3{color:var(--foreground);margin-bottom:1rem;font-size:1.125rem;font-weight:600}.footer-links{flex-direction:column;gap:.5rem;display:flex}.footer-link{color:var(--muted-foreground);text-decoration:none;transition:color .2s}.footer-link:hover{color:var(--foreground)}.footer-bottom{text-align:center;border-top:1px solid var(--border);color:var(--muted-foreground);padding-top:2rem;font-size:.875rem}.footer-description{color:var(--muted-foreground);font-size:.875rem;line-height:1.7}.footer-contact{color:var(--muted-foreground);font-size:.875rem}.modal-overlay{z-index:1000;background-color:#000c;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--background);border-radius:var(--radius);max-width:90vw;max-height:90vh;position:relative;overflow:auto}.modal-close{cursor:pointer;color:var(--muted-foreground);z-index:1001;background:0 0;border:none;font-size:1.5rem;position:absolute;top:1rem;right:1rem}.modal-close:hover{color:var(--foreground)}.modal-image{object-fit:cover;width:100%;height:auto}.modal-body{padding:2rem}.modal-title{color:var(--foreground);margin-bottom:1rem;font-size:1.875rem;font-weight:700}.modal-description{color:var(--muted-foreground);margin-bottom:1.5rem;line-height:1.7}.modal-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.modal-tag{background-color:var(--primary);color:var(--primary-foreground);border-radius:9999px;padding:.375rem .75rem;font-size:.875rem;font-weight:500}.icon-sm{width:1rem;height:1rem;margin-right:.5rem}.social-links{gap:1rem;display:flex}.social-link{color:var(--muted-foreground);transition:color .2s}.social-link:hover{color:var(--primary)}.social-icon{width:1.25rem;height:1.25rem}.text-balance{text-wrap:balance}.text-pretty{text-wrap:pretty}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (min-width:768px){.nav{display:flex}.about-grid{grid-template-columns:1fr 1fr}.about-title{font-size:3rem}.projects-grid{grid-template-columns:repeat(2,1fr)}.footer-content{grid-template-columns:repeat(3,1fr)}.project-item-title{font-size:2rem}.project-screenshots{grid-template-columns:repeat(3,1fr)}}@media (min-width:1024px){.projects-grid{grid-template-columns:repeat(3,1fr)}}@font-face{font-family:Amsterdam;src:local(Amsterdam),url(../media/amsterdam-four.10d8bfcf.ttf)format("truetype")}.logo{font-family:Amsterdam;font-size:30px}.logo a{text-decoration:none}
