*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:#fafafa;color:#212121;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}section{max-width:960px;margin:5rem auto;padding:0 1rem}h1,h2{font-weight:700;color:#111;margin-bottom:1rem;line-height:1.2;letter-spacing:-.02em}.hero{background-color:#fff;text-align:center;padding:8rem 1rem 10rem;box-shadow:0 12px 24px #0000000f;border-radius:12px}.hero h1{font-size:3.5rem;margin-bottom:.5rem;color:#222}.hero p{font-size:1.25rem;font-weight:500;color:#555;margin-bottom:2.5rem}.cta{padding:.85rem 2.2rem;font-size:1.125rem;font-weight:600;background:linear-gradient(90deg,#2563eb,#1d4ed8);border:none;border-radius:8px;color:#fff;cursor:pointer;box-shadow:0 6px 15px #2563eb59;transition:box-shadow .3s ease,transform .2s ease}.cta:hover,.cta:focus{box-shadow:0 8px 25px #2563eb80;transform:translateY(-3px);outline:none}.about{display:flex;align-items:center;gap:3rem;flex-wrap:wrap;padding-top:4rem}.about img{width:180px;height:180px;border-radius:50%;object-fit:cover;box-shadow:0 12px 30px #0000001a;flex-shrink:0}.about div{flex:1}.about p{font-size:1.125rem;color:#424242;max-width:600px;line-height:1.5}.projects h2{margin-bottom:2rem;text-align:center}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2.5rem}.project-card{background:#fff;border-radius:12px;box-shadow:0 10px 25px #00000012;padding:1.75rem 1.5rem;transition:box-shadow .3s ease,transform .3s ease;cursor:pointer;display:flex;flex-direction:column;justify-content:center}.project-card:hover,.project-card:focus-within{box-shadow:0 16px 40px #0000001f;transform:translateY(-5px);outline:none}.skills ul{list-style:none;padding:0;display:flex;gap:1.75rem;flex-wrap:wrap;justify-content:center;margin-top:1.5rem}.skills li{background:#f0f4ff;padding:.7rem 1.3rem;border-radius:20px;font-weight:600;font-size:1rem;color:#2563eb;box-shadow:0 4px 12px #2563eb1f;-webkit-user-select:none;user-select:none}.contact{max-width:540px;margin:0 auto 8rem;text-align:center}.contact h2{margin-bottom:2rem}.contact form{display:flex;flex-direction:column;gap:1.5rem}.contact input,.contact textarea{padding:1rem 1.25rem;font-size:1rem;border-radius:8px;border:1.5px solid #d1d5db;transition:border-color .3s ease;resize:vertical;font-family:inherit}.contact input:focus,.contact textarea:focus{border-color:#2563eb;outline:none;box-shadow:0 0 8px #2563eb66}.contact button{padding:1rem 2.25rem;font-size:1.125rem;font-weight:700;background:#2563eb;border:none;border-radius:10px;color:#fff;cursor:pointer;box-shadow:0 8px 20px #2563eb59;transition:background .3s ease,transform .2s ease}.contact button:hover,.contact button:focus{background:#1e40af;transform:translateY(-3px);outline:none}.social-links{margin-top:2rem;display:flex;justify-content:center;gap:2rem}.social-links a{color:#2563eb;font-size:1.8rem;transition:color .3s ease}.social-links a:hover,.social-links a:focus{color:#1e40af;outline:none}@media (max-width: 768px){.about{flex-direction:column;align-items:center}.about div{text-align:center}}h1,h2{font-weight:700;color:#1e3a8a;margin-bottom:1rem;line-height:1.2;letter-spacing:-.02em}
