:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#e5e5e5;background-color:#0a0a0a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;color:#e5e5e5;background-color:#0a0a0a}#root{width:100%;margin:0 auto}a{font-weight:500;color:#e5e5e5;text-decoration:inherit}a:hover{color:#fff}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#fff;color:#000;cursor:pointer;transition:border-color .25s}button:hover{border-color:#e5e5e5}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;color:#e5e5e5;background-color:#0a0a0a}.App{min-height:100vh}main{padding-top:80px}@media (max-width: 768px){.section-title{font-size:2rem}.container{padding:0 1rem}.btn{font-size:1rem;padding:.875rem 1.75rem}}.header{position:fixed;top:0;left:0;right:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;border-bottom:1px solid #1f1f1f}.header-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:.6rem}.logo h2{margin:0;font-size:1.5rem;font-weight:700;color:#fff}.logo-img{width:28px;height:28px;display:block}.nav-list{display:flex;list-style:none;margin:0;padding:0;gap:2rem}.nav-list li button{background:none;border:none;font-size:1rem;font-weight:500;color:#cfcfcf;cursor:pointer;transition:color .3s ease;padding:.5rem 0}.nav-list li button:hover{color:#fff}.mobile-menu-toggle{display:none;flex-direction:column;cursor:pointer;gap:4px}.mobile-menu-toggle span{width:25px;height:3px;background-color:#fff;transition:all .3s ease}@media (max-width: 768px){.nav{position:absolute;top:100%;left:0;right:0;background:#0a0a0a;border-top:1px solid #1f1f1f;transform:translateY(-100%);opacity:0;visibility:hidden;transition:all .3s ease}.nav-open{transform:translateY(0);opacity:1;visibility:visible}.nav-list{flex-direction:column;padding:1rem 2rem;gap:1rem}.mobile-menu-toggle{display:flex}}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0a0a0a;color:#fff;padding-top:80px}.hero-container{max-width:1200px;margin:0 auto;padding:0 2rem;text-align:center}.hero-content{max-width:800px;margin:0 auto}.hero-title{font-size:4rem;font-weight:700;margin:0 0 1rem;line-height:1.2;color:#fff}.hero-subtitle{font-size:2rem;font-weight:600;margin:0 0 1rem;color:#cfcfcf}.hero-location{font-size:1.25rem;margin:0 0 2rem;color:#a3a3a3}.hero-tagline{font-size:1.5rem;margin:0 0 3rem;color:#fff;font-weight:500}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{padding:1rem 2rem;font-size:1.1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-block}.btn-primary{background:#fff;color:#000}.btn-primary:hover{background:#e5e5e5;transform:translateY(-2px);box-shadow:0 10px 25px #ffffff26}.btn-secondary{background:transparent;color:#fff;border:2px solid #ffffff}.btn-secondary:hover{background:#fff;color:#000;transform:translateY(-2px);box-shadow:0 10px 25px #ffffff26}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.5rem}.hero-tagline{font-size:1.25rem}.hero-buttons{flex-direction:column;align-items:center}.btn{width:200px}}.about{padding:5rem 0;background:#0a0a0a}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.section-title{font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:3rem;color:#fff}.about-content{max-width:800px;margin:0 auto}.about-text p{font-size:1.1rem;line-height:1.8;margin-bottom:1.5rem;color:#d1d1d1}.about-text p:last-child{margin-bottom:0}@media (max-width: 768px){.about{padding:3rem 0}.section-title{font-size:2rem}.about-text p{font-size:1rem}}.skills{padding:5rem 0;background:#0a0a0a}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:3rem}.skill-category{background:#121212;padding:2rem;border-radius:12px;border:1px solid #1f1f1f}.category-title{font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;color:#fff;text-transform:uppercase;letter-spacing:.5px}.skills-list{display:flex;flex-wrap:wrap;gap:.75rem}.skill-tag{background:#000;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;transition:all .3s ease}.skill-tag:hover{background:#333;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}@media (max-width: 768px){.skills{padding:3rem 0}.skills-grid{grid-template-columns:1fr;gap:1.5rem}.skill-category{padding:1.5rem}.category-title{font-size:1.25rem}}.experience{padding:5rem 0;background:#0a0a0a}.experience-timeline{margin-top:3rem}.experience-item{background:#121212;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 16px #0006;border:1px solid #1f1f1f;transition:transform .3s ease,box-shadow .3s ease}.experience-item:hover{transform:translateY(-4px);box-shadow:0 8px 25px #0000001a}.experience-header{margin-bottom:1.5rem}.company-name{font-size:1.5rem;font-weight:700;color:#fff;margin:0 0 .5rem}.position-title{font-size:1.25rem;font-weight:600;color:#cfcfcf;margin:0 0 .5rem}.location{font-size:1rem;color:#a3a3a3;margin:0 0 .25rem}.duration{font-size:.9rem;color:#b5b5b5;margin:0;font-weight:500}.description-list{list-style:none;padding:0;margin:0 0 1.5rem}.description-list li{position:relative;padding-left:1.5rem;margin-bottom:.75rem;line-height:1.6;color:#d1d1d1}.description-list li:before{content:"•";position:absolute;left:0;color:#fff;font-weight:700}.description-list li:last-child{margin-bottom:0}.technologies{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{background:#1a1a1a;color:#e5e5e5;padding:.25rem .75rem;border-radius:15px;font-size:.8rem;font-weight:500;border:1px solid #2a2a2a}@media (max-width: 768px){.experience{padding:3rem 0}.experience-item{padding:1.5rem;margin-bottom:1.5rem}.company-name{font-size:1.25rem}.position-title{font-size:1.1rem}}.education{padding:5rem 0;background:#0a0a0a}.education-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:2rem;margin-top:3rem}.education-item{background:#121212;border-radius:12px;padding:2rem;border:1px solid #1f1f1f;transition:transform .3s ease,box-shadow .3s ease}.education-item:hover{transform:translateY(-4px);box-shadow:0 10px 30px #0009}.education-header{margin-bottom:1.5rem}.institution-name{font-size:1.5rem;font-weight:700;color:#fff;margin:0 0 .5rem}.degree-title{font-size:1.25rem;font-weight:600;color:#cfcfcf;margin:0 0 .5rem}.education-location{font-size:1rem;color:#a3a3a3;margin:0 0 .25rem}.education-duration{font-size:.9rem;color:#b5b5b5;margin:0;font-weight:500}.courses-section{border-top:1px solid #1f1f1f;padding-top:1.5rem}.courses-title{font-size:1.1rem;font-weight:600;color:#fff;margin:0 0 1rem}.courses-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:.5rem}.courses-list li{font-size:.9rem;color:#d1d1d1;position:relative;padding:.25rem 0 .25rem 1rem}.courses-list li:before{content:"•";position:absolute;left:0;color:#fff;font-weight:700}@media (max-width: 768px){.education{padding:3rem 0}.education-grid{grid-template-columns:1fr;gap:1.5rem}.education-item{padding:1.5rem}.institution-name{font-size:1.25rem}.degree-title{font-size:1.1rem}.courses-list{grid-template-columns:1fr}}.projects{padding:5rem 0;background:#0a0a0a}.project-filters{display:flex;justify-content:center;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}.filter-btn{padding:.75rem 1.5rem;border:2px solid #ffffff;background:transparent;color:#fff;border-radius:25px;font-weight:600;cursor:pointer;transition:all .3s ease}.filter-btn:hover,.filter-btn.active{background:#fff;color:#000}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem}.project-card{background:#121212;border-radius:12px;padding:2rem;box-shadow:0 4px 16px #0006;border:1px solid #1f1f1f;transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px #0009}.project-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.project-title{font-size:1.25rem;font-weight:700;color:#fff;margin:0;flex:1}.project-category{padding:.25rem .75rem;border-radius:15px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.project-category.personal{background:#1f1f1f;color:#fff}.project-category.client{background:#262626;color:#cfcfcf}.project-description{margin-bottom:1.5rem}.project-description ul{list-style:none;padding:0;margin:0}.project-description li{position:relative;padding-left:1.5rem;margin-bottom:.75rem;line-height:1.6;color:#d1d1d1;font-size:.95rem}.project-description li:before{content:"•";position:absolute;left:0;color:#fff;font-weight:700}.project-description li:last-child{margin-bottom:0}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tech-tag{background:#1a1a1a;color:#e5e5e5;border:1px solid #2a2a2a;padding:.25rem .6rem;border-radius:6px;font-size:.8rem;font-weight:600}.project-meta{display:flex;gap:1rem;color:#a3a3a3;font-size:.85rem;margin-bottom:1rem}.project-links{display:flex;gap:1rem}.project-link{padding:.5rem 1rem;background:#fff;color:#000;text-decoration:none;border-radius:6px;font-size:.9rem;font-weight:600;transition:all .3s ease}.project-link:hover{background:#e5e5e5;transform:translateY(-2px);box-shadow:0 4px 12px #ffffff26}.projects-loading,.projects-error{text-align:center;color:#e5e5e5;padding:2rem 0}@media (max-width: 768px){.projects{padding:3rem 0}.project-filters{margin-bottom:2rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.project-card{padding:1.5rem}.project-header{flex-direction:column;gap:1rem}.project-links{flex-direction:column}}.contact-section{padding:5rem 0;background:#0a0a0a;color:#e5e5e5;min-height:100vh;display:flex;align-items:center}.contact-container{max-width:1200px;margin:0 auto;padding:0 2rem}.contact-header{text-align:center;margin-bottom:4rem}.contact-title{font-size:3rem;font-weight:700;margin-bottom:1rem;color:#fff}.contact-subtitle{font-size:1.2rem;line-height:1.6;color:#a3a3a3;max-width:600px;margin:0 auto}.contact-content{display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:start;justify-content:center;justify-items:center}.contact-form-container{background:#121212;border-radius:12px;padding:2.5rem;border:1px solid #1f1f1f;box-shadow:0 4px 20px #0006}.form-title{font-size:1.5rem;font-weight:600;margin-bottom:2rem;color:#fff}.contact-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column}.form-label{font-size:.9rem;font-weight:500;margin-bottom:.5rem;color:#d1d1d1}.form-input,.form-textarea{padding:1rem;border:2px solid #2a2a2a;border-radius:8px;background:#0a0a0a;color:#e5e5e5;font-size:1rem;transition:all .3s ease}.form-input::placeholder,.form-textarea::placeholder{color:#777}.form-input:focus,.form-textarea:focus{outline:none;border-color:#e5e5e5;background:#0f0f0f;box-shadow:0 0 0 3px #ffffff14}.form-textarea{resize:vertical;min-height:120px}.submit-btn{padding:1rem 2rem;background:#fff;color:#000;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem;position:relative;overflow:hidden}.submit-btn:hover{background:#e5e5e5;transform:translateY(-2px);box-shadow:0 8px 25px #ffffff26}.submit-btn:active{transform:translateY(0)}.submit-btn.submitting{background:#666;cursor:not-allowed}.submit-btn.submitting:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid transparent;border-top:2px solid #ffffff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success-message{margin-top:1rem;padding:1rem;background:#0f1a0f;border:1px solid #1e3a1e;border-radius:8px;color:#a7f3d0;font-weight:500;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.contact-info-container{display:flex;flex-direction:column;gap:2rem;width:100%;max-width:800px;margin:0 auto}.info-title{font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;color:#fff}.contact-info-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}.contact-card{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:#121212;border-radius:12px;border:1px solid #1f1f1f;transition:all .3s ease}.contact-card:hover{transform:translateY(-2px);background:#151515;box-shadow:0 8px 25px #0006}.card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#000;border-radius:12px;color:#fff;flex-shrink:0;transition:all .3s ease}.contact-card:hover .card-icon{background:#333;transform:scale(1.05)}.card-content{flex:1}.card-title{font-size:1.1rem;font-weight:600;margin-bottom:.25rem;color:#fff}.card-link,.card-value{color:#d1d1d1;text-decoration:none;font-weight:500;transition:color .3s ease}.card-link:hover{color:#fff;text-decoration:underline}.card-description{font-size:.9rem;color:#a3a3a3;margin-top:.25rem}.response-time{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#121212;border-radius:12px;border:1px solid #1f1f1f;width:100%}.response-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#000;border-radius:10px;color:#fff;flex-shrink:0}.response-time h4{font-size:1rem;font-weight:600;margin-bottom:.25rem;color:#fff}.response-time p{font-size:.9rem;color:#a3a3a3;margin:0}@media (max-width: 1024px){.contact-content{grid-template-columns:1fr;gap:3rem}.contact-form-container{order:2}.contact-info-container{order:1}}@media (max-width: 768px){.contact-section{padding:3rem 0}.contact-container{padding:0 1rem}.contact-title{font-size:2.5rem}.contact-subtitle{font-size:1.1rem}.contact-form-container{padding:2rem}.form-row{grid-template-columns:1fr}.contact-card{padding:1.25rem;gap:1rem}.card-icon{width:40px;height:40px}}@media (max-width: 480px){.contact-title{font-size:2rem}.contact-form-container{padding:1.5rem}.contact-card{flex-direction:column;text-align:center;gap:1rem}.card-icon{width:48px;height:48px}}.footer{background:#000;color:#fff;padding:2rem 0;text-align:center}.footer-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.footer-text{font-size:1rem;margin:0;color:#ccc}.footer-copyright{font-size:.9rem;margin:0;color:#999}@media (max-width: 768px){.footer{padding:1.5rem 0}.footer-text{font-size:.9rem}.footer-copyright{font-size:.8rem}}
