@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_fd091ad6-module__giF-bG__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_fd091ad6-module__giF-bG__variable{--font-sans:"Inter", "Inter Fallback"}
@font-face{font-family:Fraunces;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/85fcf895b86d74a6-s.12xb_oat076h..woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5307092570128b5a-s.0dld-t76zw9ln.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/b67966e0b83b2cd0-s.p.04y9-s23ppywx.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fraunces Fallback;src:local(Times New Roman);ascent-override:84.71%;descent-override:22.09%;line-gap-override:0.0%;size-adjust:115.45%}.fraunces_486f330e-module__n5mBRa__className{font-family:Fraunces,Fraunces Fallback;font-style:normal}.fraunces_486f330e-module__n5mBRa__variable{--font-serif:"Fraunces", "Fraunces Fallback"}
@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/13bf9871fe164e7f-s.0s19wthhh_6~m.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/cc545e633e20c56d-s.0dza.stei.9v7.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/71b036adf157cdcf-s.03nf~dfjdkf~..woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/89b21bb081cb7469-s.0gfhww.tctz1o.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/3fe682a82f50d426-s.09q3q1i5159bl.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/70bc3e132a0a741e-s.p.1409xf.ylxg8g.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_6104e6b7-module__s6uLTa__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_6104e6b7-module__s6uLTa__variable{--font-mono:"JetBrains Mono", "JetBrains Mono Fallback"}
*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#14110f;--bg-secondary:#1f1a16;--bg-tertiary:#2a2320;--purple-primary:#d97757;--purple-secondary:#c46440;--purple-accent:#e8a87c;--text-primary:#f5eee4;--text-secondary:#b8a99a;--text-muted:#8a7a6e}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:10px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg, var(--purple-primary), var(--purple-secondary));border:2px solid var(--bg-secondary);border-radius:10px;transition:all .3s}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg, var(--purple-secondary), var(--purple-accent));border-color:var(--bg-primary);transform:scale(1.1)}::-webkit-scrollbar-thumb:active{background:var(--purple-accent)}::-webkit-scrollbar-corner{background:var(--bg-secondary)}.modal-screenshot{text-align:center;width:100%;margin:15px 0}.modal-project-image{border-radius:8px;width:100%;max-width:850px;box-shadow:0 4px 20px #0003}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:8px}.modal-content::-webkit-scrollbar-thumb{background:linear-gradient(135deg, var(--purple-primary), var(--purple-secondary));border:1px solid var(--bg-tertiary);border-radius:8px}.modal-content::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg, var(--purple-secondary), var(--purple-accent));transform:scale(1.2)}*{scrollbar-width:thin;scrollbar-color:var(--purple-primary) var(--bg-secondary)}.carousel::-webkit-scrollbar{height:4px}.carousel::-webkit-scrollbar-track{background:0 0}.carousel::-webkit-scrollbar-thumb{background:var(--purple-primary);opacity:.5;border-radius:4px}.carousel::-webkit-scrollbar-thumb:hover{opacity:1}body{font-family:var(--font-sans), "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;background:var(--bg-primary);color:var(--text-primary);font-feature-settings:"ss01", "cv11";line-height:1.65;overflow-x:hidden}.bg-animation{z-index:-1;pointer-events:none;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.bg-animation:before{content:"";filter:blur(80px);pointer-events:none;background:radial-gradient(circle,#d9775738,#0000 65%);border-radius:50%;width:60vmin;height:60vmin;position:absolute;top:-10%;left:50%;transform:translate(-50%)}.bg-animation:after{content:"";opacity:.08;mix-blend-mode:overlay;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:absolute;inset:0}nav{-webkit-backdrop-filter:blur(14px);z-index:1000;background:#14110fd9;border-bottom:1px solid #d9775714;width:100%;padding:1rem 0;transition:all .3s;position:fixed;top:0}.nav-container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 2rem;display:flex}.logo{width:50px;height:50px}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.nav-links{gap:2rem;list-style:none;display:flex}.nav-links a{color:var(--text-secondary);text-decoration:none;transition:color .3s;position:relative}.nav-links a:hover{color:var(--purple-accent)}.nav-links a:after{content:"";background:var(--purple-primary);width:0;height:2px;transition:width .3s;position:absolute;bottom:-5px;left:0}.nav-links a:hover:after{width:100%}.hero{text-align:center;justify-content:center;align-items:center;min-height:100vh;padding:8rem 2rem 4rem;display:flex;position:relative}.hero-content h1{font-family:var(--font-serif), "Fraunces", Georgia, serif;letter-spacing:-.02em;color:var(--text-primary);font-feature-settings:"ss01", "ss02";margin-bottom:1.5rem;font-size:clamp(2.5rem,6vw,4.375rem);font-weight:400;line-height:1.05}.hero-content .tagline{color:var(--purple-accent);letter-spacing:.02em;font-size:1.15rem;font-weight:400;font-family:var(--font-mono), "JetBrains Mono", "Menlo", monospace;margin-bottom:1.5rem}.hero-content p{color:var(--text-secondary);max-width:620px;margin:0 auto 2.25rem;font-size:1.05rem;line-height:1.7}.cursor{color:var(--purple-accent);animation:1s infinite blink}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.cta-buttons{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.btn{cursor:pointer;border:none;border-radius:25px;align-items:center;gap:8px;padding:12px 24px;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex;position:relative;overflow:hidden}.btn:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.btn:hover:before{left:100%}.btn-primary{background:linear-gradient(135deg, var(--purple-primary), var(--purple-secondary));color:#fff;box-shadow:0 4px 15px #d977574d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px #d9775759}.btn-secondary{color:var(--purple-accent);border:2px solid var(--purple-primary);background:0 0;box-shadow:0 0 20px #d9775733}.btn-secondary:hover{background:var(--purple-primary);color:#fff;transform:translateY(-2px);box-shadow:0 12px 28px #d9775759}section{width:100%;max-width:1200px;margin:0 auto;padding:5rem 2rem;overflow-x:hidden}.section-title{font-family:var(--font-serif), "Fraunces", Georgia, serif;letter-spacing:-.02em;text-align:center;color:var(--text-primary);font-feature-settings:"ss01", "ss02";margin-bottom:3rem;font-size:clamp(2rem,3.5vw,2.75rem);font-weight:400;position:relative}.section-title:after{content:"";background:var(--purple-primary);opacity:.6;width:40px;height:2px;position:absolute;bottom:-14px;left:50%;transform:translate(-50%)}.about{background:var(--bg-secondary);max-width:100%;margin:0;padding:5rem 2rem}.about-content{flex-direction:row;align-items:center;gap:3rem;max-width:1136px;margin:0 auto;display:flex}.about-image{aspect-ratio:1;background:var(--bg-tertiary);border-radius:24px;flex-shrink:0;width:360px;position:relative;overflow:hidden;box-shadow:0 20px 60px #0006,0 0 0 1px #d9775726}.about-image img{object-fit:cover;object-position:center;border-radius:24px;width:100%;height:100%}.about-text strong{color:var(--purple-accent)}.about-text p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1.1rem}.skills-container{flex-wrap:wrap;justify-content:center;gap:2rem;display:flex}.skill-category{background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:20px;flex:300px;width:100%;padding:2rem;transition:all .3s;position:relative;overflow:hidden}.skill-category:before{content:"";background:linear-gradient(90deg, var(--purple-primary), var(--purple-accent));width:100%;height:4px;transition:transform .3s;position:absolute;top:0;left:0;transform:scaleX(0)}.skill-category:hover:before{transform:scaleX(1)}.skill-category:hover{border-color:#d9775773;transform:translateY(-4px);box-shadow:0 20px 40px #00000059}.skill-category h3{color:var(--purple-accent);align-items:center;gap:10px;margin-bottom:1rem;display:flex;position:relative}.skill-category h3 i{opacity:.9;font-size:1.25rem}.skill-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:14px;display:grid}.skill-tile{border:1px solid var(--bg-tertiary);cursor:pointer;background:#2a232080;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:14px 8px;transition:transform .3s,border-color .3s,box-shadow .3s,background .3s;display:flex;position:relative;overflow:hidden}.skill-tile:before{content:"";opacity:0;pointer-events:none;background:radial-gradient(circle at 50% 0,#e8a87c2e,#0000 70%);transition:opacity .3s;position:absolute;inset:0}.skill-tile:hover{border-color:var(--purple-primary);background:#2a2320d9;transform:translateY(-4px);box-shadow:0 10px 25px #d9775740}.skill-tile:hover:before{opacity:1}.skill-tile-visual{justify-content:center;align-items:center;width:44px;height:44px;display:flex}.skill-tile-logo{object-fit:contain;filter:grayscale()brightness(1.8)contrast(.9);width:100%;height:100%;transition:filter .3s,transform .3s}.skill-tile:hover .skill-tile-logo{filter:grayscale(0)brightness()contrast();transform:scale(1.08)}.skill-tile-icon{color:var(--text-secondary);font-size:1.8rem;transition:color .3s,transform .3s}.skill-tile:hover .skill-tile-icon{color:var(--purple-accent);transform:scale(1.1)}.skill-tile-label{color:var(--text-muted);text-align:center;font-size:.72rem;line-height:1.25;transition:color .3s}.skill-tile:hover .skill-tile-label{color:var(--text-primary)}.projects-container{flex-wrap:wrap;justify-content:center;gap:2rem;display:flex}.project-card{background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:20px;flex:350px;max-width:400px;transition:all .4s;position:relative;overflow:hidden}.project-card:before{content:"";opacity:0;z-index:1;pointer-events:none;background:linear-gradient(135deg,#d977571a,#c464401a);transition:opacity .3s;position:absolute;inset:0}.project-card:hover:before{opacity:1}.project-card:hover{border-color:#d9775780;transform:translateY(-6px);box-shadow:0 25px 50px #0006}.project-image{background:linear-gradient(135deg, var(--purple-primary), var(--purple-secondary));color:#fff;cursor:pointer;justify-content:center;align-items:center;height:200px;font-size:3rem;transition:transform .3s;display:flex;position:relative;overflow:hidden}.project-image:hover{transform:scale(1.05)}.project-image i{z-index:2;position:relative}.project-content{padding:1.5rem}.project-content h3{color:var(--purple-accent);margin-bottom:.5rem}.project-content p{color:var(--text-secondary);margin-bottom:1rem}.project-tech{flex-wrap:wrap;gap:8px;margin-bottom:1rem;display:flex}.tech-tag{background:var(--bg-tertiary);color:var(--purple-accent);border-radius:12px;padding:4px 8px;font-size:.8rem}.load-more-container{justify-content:center;margin-top:3rem;display:flex}.load-more-btn{padding:15px 30px;font-size:1.1rem;position:relative;overflow:hidden}.load-more-btn i{transition:transform .3s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.recommendations{background:var(--bg-secondary);padding:5rem 2rem;max-width:100%!important}.carousel-container{max-width:800px;margin:0 auto;position:relative}.carousel{scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:2rem;padding:1rem 0;display:flex;overflow-x:auto}.carousel::-webkit-scrollbar{display:none}.recommendation-card{scroll-snap-align:start;background:var(--bg-tertiary);border:1px solid var(--purple-primary);border-radius:20px;flex-flow:column;justify-content:space-between;min-width:100%;padding:2rem;display:flex;position:relative}.recommendation-card:before{content:"“";color:var(--purple-primary);opacity:.2;font-family:serif;font-size:4rem;line-height:1;position:absolute;top:10px;left:10px}.recommendation-content{color:var(--text-secondary);z-index:1;margin-bottom:1.5rem;font-style:italic;position:relative}.recommender{align-items:center;gap:1rem;display:flex}.recommender-info h4{color:var(--text-primary);margin-bottom:.2rem}.recommender-info p{color:var(--text-muted);font-size:.9rem}.carousel-nav{justify-content:center;gap:1rem;margin-top:2rem;display:flex}.carousel-dot{background:var(--bg-tertiary);border:1px solid var(--purple-primary);cursor:pointer;border-radius:50%;width:12px;height:12px;transition:all .3s}.carousel-dot.active{background:var(--purple-primary);transform:scale(1.2)}.contact{text-align:center}.contact-links{flex-wrap:wrap;justify-content:center;gap:2rem;margin-top:2rem;display:flex}.contact-link{color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:20px;flex-direction:column;flex:150px;align-items:center;gap:10px;width:120px;max-width:200px;padding:1.5rem;text-decoration:none;transition:all .3s;display:flex;position:relative;overflow:hidden}.contact-link:before{content:"";background:linear-gradient(135deg, var(--purple-primary), var(--purple-accent));z-index:-1;border-radius:50%;width:0;height:0;transition:all .4s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.contact-link:hover:before{width:300px;height:300px}.contact-link:hover{color:#fff;border-color:var(--purple-accent);transform:translateY(-6px);box-shadow:0 15px 30px #00000059}.contact-link i{color:var(--purple-primary);font-size:2.25rem;transition:color .3s,transform .3s}.contact-link:hover i{color:#fff;transform:scale(1.1)}.contact-info-1,.contact-info-2{gap:2rem;display:flex}footer{background:var(--bg-secondary);text-align:center;border-top:1px solid var(--bg-tertiary);color:var(--text-muted);margin-top:3rem;padding:2.5rem 2rem}footer p{margin:.35rem 0;font-size:.9rem}footer a{color:var(--purple-accent);border-bottom:1px solid #e8a87c66;text-decoration:none;transition:border-color .2s}footer a:hover{border-bottom-color:var(--purple-accent)}.go-to-top{background:linear-gradient(135deg, var(--purple-primary), var(--purple-secondary));color:#fff;cursor:pointer;z-index:1000;opacity:0;visibility:hidden;border:none;border-radius:50%;width:50px;height:50px;font-size:1.2rem;transition:all .3s;position:fixed;bottom:30px;right:30px;transform:translateY(20px);box-shadow:0 4px 15px #d977574d}.go-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.go-to-top:hover{transform:translateY(-2px);box-shadow:0 12px 28px #d9775759}.go-to-top:active{transform:translateY(0)}.modal{z-index:2000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#000000e6;width:100%;height:100%;animation:.3s ease-out modalFadeIn;display:none;position:fixed;top:0;left:0}.modal.show{justify-content:center;align-items:center;padding:2rem;display:flex}.modal-content{background:var(--bg-secondary);border:1px solid var(--purple-primary);opacity:0;border-radius:20px;width:100%;max-width:800px;max-height:90vh;transition:all .3s ease-out;position:relative;overflow-y:auto;transform:scale(.7)}.modal.show .modal-content{opacity:1;transform:scale(1)}.modal-header{border-bottom:1px solid var(--bg-tertiary);justify-content:space-between;align-items:flex-start;padding:2rem 2rem 1rem;display:flex}.modal-title{color:var(--purple-accent);flex:1;margin:0;font-size:1.8rem}.modal-subtitle{color:var(--text-muted);margin:.5rem 0 0;font-size:.9rem;font-style:italic}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;margin-left:1rem;font-size:2rem;transition:all .3s;display:flex}.modal-close:hover{background:var(--purple-primary);color:#fff}.modal-body{padding:1rem 2rem 2rem}.modal-image{background:linear-gradient(135deg, var(--purple-primary), var(--purple-secondary));color:#fff;border-radius:15px;justify-content:center;align-items:center;width:100%;height:200px;margin-bottom:1.5rem;font-size:3rem;display:flex;position:relative;overflow:hidden}.modal-image-photo{background:var(--bg-tertiary);height:auto;max-height:420px;padding:0}.modal-image-photo img{object-fit:contain;width:100%;height:auto;max-height:420px;display:block}.modal-description{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1rem;line-height:1.6}.modal-tech{flex-wrap:wrap;gap:10px;margin-bottom:1.5rem;display:flex}.modal-tech-tag{background:var(--bg-tertiary);color:var(--purple-accent);border:1px solid var(--purple-primary);border-radius:20px;padding:8px 16px;font-size:.85rem}.modal-features{margin-bottom:1.5rem}.modal-features h4{color:var(--text-primary);align-items:center;gap:10px;margin-bottom:1rem;display:flex}.modal-features ul{padding:0;list-style:none}.modal-features li{color:var(--text-secondary);margin-bottom:.5rem;padding-left:1.5rem;font-size:1rem;position:relative}.modal-features li:before{content:"→";color:var(--purple-accent);font-weight:700;position:absolute;left:0}.modal-links{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.modal-btn{cursor:pointer;border:none;border-radius:25px;align-items:center;gap:8px;padding:12px 24px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex;position:relative;overflow:hidden}.modal-btn-primary{background:linear-gradient(135deg, var(--purple-primary), var(--purple-secondary));color:#fff;box-shadow:0 4px 15px #d977574d}.modal-btn-secondary{color:var(--purple-accent);border:2px solid var(--purple-primary);background:0 0}.modal-btn:hover{transform:translateY(-2px);box-shadow:0 10px 22px #0000004d}.project-card:after{color:#fff;opacity:0;background:#d97757e6;border-radius:50%;justify-content:center;align-items:center;width:35px;height:35px;font-size:.9rem;transition:all .3s;display:flex;position:absolute;top:15px;right:15px;transform:scale(0)}.project-card:hover:after{opacity:1;transform:scale(1)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}html{scroll-behavior:smooth}.fade-in{animation:.6s ease-out fadeInUp}.project-description{-webkit-line-clamp:2;text-overflow:ellipsis;white-space:normal;-webkit-box-orient:vertical;max-height:3em;line-height:1.5em;display:-webkit-box;position:relative;overflow:hidden}.project-description:after{color:var(--purple-accent);font-weight:500}@media (max-width:1024px){.about-content{text-align:center;flex-direction:column;gap:1.5rem}#about .section-title{margin-bottom:3.5rem}.about-image{width:300px}.projects-container{flex-direction:column;align-items:center}.project-card{flex:100%;width:100%;max-width:600px}}@media (min-width:769px) and (max-width:1024px){.projects-container{grid-template-columns:1fr;justify-items:center;gap:2rem;display:grid}.project-card{width:100%;max-width:600px}}@media (max-width:768px){.about,.recommendations{padding:3rem 2rem;margin:0!important}section{width:100%;margin:0;padding:3rem 2rem}.hero{padding:4rem 2rem 3rem}.nav-links{gap:1.25rem;font-size:.9rem}.nav-container{padding:0 1.25rem}.about-content{text-align:center;flex-direction:column}.projects-container{flex-direction:column;align-items:center}.project-card{max-width:100%}.contact-link{flex:100%;width:90px}.skill-category{flex:100%}.cta-buttons{flex-direction:column;align-items:center}.go-to-top{width:45px;height:45px;font-size:1.1rem;bottom:20px;right:20px}.modal{padding:1rem}.modal-header,.modal-body{padding-left:1.5rem;padding-right:1.5rem}.modal-title{font-size:1.5rem}.modal-links{flex-direction:column;align-items:center}.modal-btn{justify-content:center;width:100%}::-webkit-scrollbar{background:0 0;width:0}.modal-content::-webkit-scrollbar{background:0 0;width:0}}@media (max-width:480px){.nav-container{padding:0 1rem}.nav-links{gap:.85rem;font-size:.8rem}.logo{width:38px!important;height:38px!important}.section-title{font-size:2rem}.hero-content h1{font-size:clamp(2.2rem,6vw,3rem)}.hero-content .tagline{font-size:1.3rem}.hero-content p{font-size:1rem}.about-image{width:250px}.contact-links{flex-direction:column;align-items:center}}@media (max-width:376px){.hero-content h1{font-size:clamp(2rem,7vw,2.5rem);line-height:3rem}.hero-content .tagline{font-size:1rem}.hero-content p,.about-text p,.modal-description,.recommendation-content,.modal-features li,.project-description{font-size:.95rem}.hero{padding:3rem 1rem 2rem}.about,.recommendations{padding:3rem 1rem;margin:0!important}section{padding:3rem 1rem}.section-title{font-size:1.8rem}.modal-title{font-size:1.2rem}.about-image{width:200px}}
