:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#3b409d;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg, #242424);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,svg{max-width:100%;height:auto;display:block}@media (max-width: 1024px){:root{font-size:15px}}@media (max-width: 768px){:root{font-size:14px}body{padding:0 .5rem}}@media (max-width: 640px){section[class$=-section]{padding:2.5rem 1rem!important;margin:1rem auto!important;width:calc(100% - 2rem)!important}}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:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.App{width:100%;display:flex;flex-direction:column;align-items:stretch}.App main{width:100%}@media (max-width: 640px){#root{padding:1rem}}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.navbar2{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(120deg,#2f2f3f 60%,#2b4272);padding:1rem 2rem;box-shadow:0 2px 4px #0000001a}.navbar2 ul{display:flex;gap:2.5rem;list-style:none;margin:0;padding:1.2rem 0}.navbar2 a{color:#d6d4c5;text-decoration:none;font-weight:700;font-size:1.05rem;transition:color .2s;letter-spacing:1px}.navbar2 a:hover{color:#fff}@media (max-width: 640px){.navbar2{padding:.5rem 1rem}.nav-toggle{display:inline-flex;flex-direction:column;gap:6px;background:transparent;border:none;margin-left:1rem;cursor:pointer}.nav-toggle .bar{display:block;width:22px;height:2px;background:gold;border-radius:2px}.navbar2 ul{display:none;flex-direction:column;gap:.8rem;align-items:center;padding:.6rem 0}.navbar2 ul.open{display:flex}.nav-toggle.open .bar:nth-child(2){opacity:0}}.hero-section{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background:#474754;color:#fff;text-align:center;padding-top:5rem}.hero-section h1{font-size:2.8rem;font-weight:700;margin-bottom:1rem}.hero-section h2{font-size:1.5rem;font-weight:400;margin-bottom:2rem}@media (max-width: 640px){.hero-section{padding-top:3.5rem}.hero-section h1{font-size:2rem}.hero-section h2{font-size:1.05rem}.hero-animation{width:48px;height:48px}}.hero-animation{width:60px;height:60px;border-radius:50%;background:#ffffff1a;box-shadow:0 0 30px #2563eb;animation:pulse 2s infinite;margin-top:2rem}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}to{transform:scale(1);opacity:1}}.download-btn{background:linear-gradient(120deg,#14171c,#18181b);color:#fff;border-radius:1rem;padding:.7rem 1.5rem;text-decoration:none;font-weight:500;font-size:1rem;transition:background .2s;display:inline-block;margin-top:2rem}.download-btn:hover{background:#272d39}.about-section{padding:7rem 2rem 4rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.about-cards{display:flex;flex-direction:row;gap:2.5rem;justify-content:center;align-items:stretch;flex-wrap:wrap;padding:2rem}.about-cards-row{display:flex;flex-direction:row;gap:2.5rem;justify-content:center;align-items:stretch;flex-wrap:wrap}.about-card{background:#18181b;color:#fff;border-radius:1.5rem;padding:2rem;box-shadow:0 4px 16px #2563eb22;text-align:center;transition:box-shadow .3s,transform .3s;display:flex;flex-direction:column;align-items:center;gap:1rem}.about-card-photo{margin-bottom:1.5rem}.about-card:hover{box-shadow:0 8px 32px #2563eb55;transform:scale(1.04)}.about-photo{width:180px;height:180px;object-fit:cover;border-radius:1.5rem;box-shadow:0 4px 16px #2563eb33;margin-bottom:1.2rem;transition:transform .3s}.about-card:hover .about-photo{transform:scale(1.08)}.about-card h2{font-size:2rem;margin-bottom:.7rem;font-weight:700;letter-spacing:1px}.about-card p{font-size:1.15rem;margin-bottom:.7rem;line-height:1.6}.about-card strong{color:#f2f4f7}.about-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;display:flex;justify-content:center;align-items:center;z-index:200}.about-modal{background:#18181b;color:#fff;border-radius:1.5rem;padding:2.5rem;box-shadow:0 4px 32px #2563eb55;max-width:600px;width:90%;position:relative;animation:fadeIn .4s ease-out}.about-card{width:100%}@media (min-width: 900px){.about-card{max-width:280px}}@media (max-width: 640px){.about-section{padding:5rem 1rem 2rem}.about-cards{padding:1rem;gap:1.5rem}.about-card{padding:1.5rem}.about-photo{width:140px;height:140px;margin-bottom:1rem}.about-card h2{font-size:1.5rem;margin-bottom:.5rem}.about-card p{font-size:1rem;margin-bottom:.5rem}}.about-modal-close{position:absolute;top:1rem;right:1rem;background:#3b5c7e;color:#fff;border:none;border-radius:50%;width:32px;height:32px;font-size:1.2rem;cursor:pointer;transition:background .3s,color .3s}.about-modal-close:hover{background:gold;color:#18181b}.about-cards-col{display:flex;flex-direction:column;gap:2.5rem;align-items:stretch}.skills-section{background:#41414f;color:#fff;padding:7rem 2rem 4rem;border-radius:2rem;max-width:1100px;margin:2rem auto 3rem;box-shadow:0 8px 32px #2563eb1f;animation:fadeIn 1s ease}.skills-carousel-wrapper{overflow:hidden;width:100%;margin-bottom:2rem}.skills-carousel{display:flex;gap:3.5rem;overflow-x:auto;scroll-behavior:auto;align-items:center;padding-bottom:1rem}.skill-logo-block{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:120px;margin:0 .5rem}.skill-logo{width:64px;height:64px;margin-bottom:.7rem;transition:transform .3s}.skill-logo-block:hover .skill-logo{transform:scale(1.12)}.skill-name{font-size:1.1rem;font-weight:600;color:#fff;letter-spacing:1px;text-align:center}@media (max-width: 640px){.skills-section{padding:3.5rem 1rem}.skill-logo{width:48px;height:48px}.skill-logo-block{min-width:90px}.skill-name{font-size:.95rem}}.work-section{padding:7rem 2rem 4rem;background:#474754;color:#fff;border-radius:2rem;box-shadow:0 8px 32px #2563eb1f;max-width:1200px;margin:0 auto 2rem}.work-cards{display:flex;gap:2.5rem;flex-wrap:wrap;justify-content:center}.work-card{background:#18181b;color:#fff;border-radius:2rem;box-shadow:0 4px 24px #2563eb1a;padding:3rem 2rem;width:100%;min-height:220px;font-size:1.15rem;display:flex;flex-direction:column;align-items:flex-start;transition:box-shadow .3s,transform .3s;animation:fadeIn 1.2s ease}.work-card:hover{box-shadow:0 8px 32px #2563eb55;transform:scale(1.04)}.work-logo{width:64px;height:64px;object-fit:contain;border-radius:1rem;background:#fff;margin-bottom:1.2rem;box-shadow:0 2px 8px #2563eb33;display:block;transition:transform .3s}.work-card:hover .work-logo{transform:scale(1.12)}.work-card h3{font-size:1.3rem;margin-bottom:.7rem;font-weight:700;letter-spacing:1px;color:#fff}.work-card h4{font-size:1.1rem;color:#39372b;margin-bottom:.7rem;font-weight:600}.work-card p{font-size:1.1rem;margin-bottom:1rem;font-weight:400;line-height:1.6;color:#fff}.work-date{font-size:1.05rem;color:#fff;margin-top:auto;font-weight:600;letter-spacing:1px}.work-card:nth-child(1){background:#2563eb;color:#fff}.work-card:nth-child(2){background:#f59e42;color:#18181b}.work-card.work-card-center{background:#e5e7eb;color:#18181b;border-radius:2rem;box-shadow:0 4px 24px #2563eb1a;padding:3rem 2rem;width:100%;min-height:260px;font-size:1.15rem;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto}.work-card.work-card-center h3,.work-card.work-card-center h4,.work-card.work-card-center .work-date{color:#18181b;text-align:center}.work-logo-large{width:120px;height:120px;object-fit:contain;border-radius:1.5rem;background:#fff;margin:1.5rem 0;box-shadow:0 2px 8px #2563eb33;display:block}@media (max-width: 640px){.work-section{padding:3.5rem 1rem}.work-card{padding:1.4rem}.work-logo{width:48px;height:48px}.work-logo-large{width:100px;height:100px}}.projects-section{padding:5rem 2rem 4rem;background:#474754;color:#fff;max-width:1200px;margin:0 auto 2rem;border-radius:2rem;box-shadow:0 8px 32px #2563eb1f}.bento-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem}.bento-card{background:#36374b;color:#fff;border-radius:2rem;box-shadow:0 4px 24px #2563eb1a;padding:1.5rem;min-height:180px;display:flex;flex-direction:column;align-items:center;transition:box-shadow .3s,transform .3s;animation:fadeIn 1.2s ease}.bento-card:hover{box-shadow:0 4px 24px #2563eb55;transform:scale(1.04)}.bento-card h3{font-size:1.1rem;margin-bottom:.5rem;font-weight:700;text-align:center}.badges{display:flex;gap:.7rem;margin-bottom:1rem;flex-wrap:wrap}.badge{background:#2563eb;color:#fff;padding:.3rem .8rem;border-radius:.8rem;font-size:.95rem;font-weight:600}.bento-card p{font-size:1rem;margin-bottom:1rem;font-weight:400}.source-btn{background:#18181b;color:#fff;border:none;border-radius:1rem;padding:.7rem 1.5rem;margin-top:1rem;cursor:pointer;transition:background .2s,color .2s;font-weight:600;font-size:1rem}.source-btn:hover{background:#2563eb;color:#fff}.project-img{width:100%;height:260px;object-fit:cover;border-radius:2rem 2rem 0 0;background:#18181b;margin-bottom:0;transition:transform .3s}.bento-card:hover .project-img{transform:scale(1.08)}.project-info{width:100%;padding:1rem 0 0;display:flex;flex-direction:column;align-items:center}.project-info-vertical{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0}.badges-bottom{margin-top:.7rem;display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.modal-flex{display:flex;flex-direction:row;gap:2.5rem;align-items:flex-start}.modal-img-block{flex:1;display:flex;align-items:center;justify-content:center}.modal-info-block{flex:2;display:flex;flex-direction:column;gap:1.2rem;justify-content:flex-start;font-size:1.15rem}.modal-bento .modal-content{padding:1.5rem}@media (max-width: 900px){.modal-flex{flex-direction:column;gap:1.5rem}.modal-project-img{width:200px;height:200px}.modal-info-block{font-size:1rem}}@media (max-width: 480px){.modal-project-img{width:160px;height:160px}}@media (max-width: 480px){.projects-section{padding:2.5rem 1rem}.project-info h3{font-size:1rem}}.modal-goal{font-size:1.15rem;font-weight:600;color:#2563eb}.modal-desc{font-size:1.05rem;color:#fff;line-height:1.6}.modal-tools{font-size:1.05rem;color:#fff}.source-link{display:inline-block;margin-top:1rem;background:#18181b;color:#fff;padding:.7rem 1.5rem;border-radius:1rem;text-decoration:none;font-weight:600;font-size:1rem;transition:background .2s}.source-link:hover{background:#2563eb}.close-modal-btn{position:absolute;top:1rem;right:1rem;background:#2563eb;color:#fff;border:none;border-radius:50%;width:2.5rem;height:2.5rem;font-size:1.2rem;cursor:pointer;transition:background .2s}.close-modal-btn:hover{background:#18181b}.source-btn{background:#2563eb;color:#fff;border:none;border-radius:1rem;padding:.7rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:1rem;transition:background .2s}.source-btn:hover{background:#18181b;color:#4f77cc}.modal-bento{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#18181beb;display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .7s ease}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.modal-content{background:#18181b;border-radius:2rem;padding:3rem 3.5rem;box-shadow:0 8px 32px #2563eb33;min-width:340px;max-width:90vw;position:relative;display:flex;flex-direction:row;gap:2.5rem;align-items:flex-start;animation:fadeIn 1.2s ease;color:#fff}@media (max-width: 700px){.modal-content{flex-direction:column;padding:1.2rem;border-radius:1rem;width:calc(100% - 2rem);max-height:calc(100vh - 2rem);overflow-y:auto}.modal-project-img{width:160px;height:160px;margin:0 auto}.modal-info-block{font-size:1rem}.modal-bento{align-items:flex-start;padding-top:1rem}}.modal-project-img{width:240px;height:240px;object-fit:cover;border-radius:2rem;background:#18181b;transition:transform .3s}.modal-content:hover .modal-project-img{transform:scale(1.08)}.modal-info-block{flex:2;display:flex;flex-direction:column;gap:1.2rem;justify-content:flex-start;font-size:1.15rem;color:#fff}.badges{display:flex;gap:.5rem;margin-bottom:1rem}.badge{background:#2563eb;color:#fff;padding:.3rem .8rem;border-radius:1rem;font-size:.95rem;font-weight:500}.source-link{display:inline-block;margin-top:1rem;color:#2563eb;text-decoration:underline;font-weight:500}.back-btn{background:#2563eb;color:#fff;border:none;border-radius:1rem;padding:.7rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:1rem;transition:background .2s}.back-btn:hover{background:#18181b}.contact-section{padding:7rem 2rem 4rem;background:#474754;color:#fff;max-width:800px;margin:0 auto 2rem;border-radius:2rem;box-shadow:0 8px 32px #2563eb1f}.contact-section h2{font-size:2rem;margin-bottom:1.5rem;font-weight:700;letter-spacing:1px;color:#fff}.contact-links{display:flex;gap:2.5rem;justify-content:center;flex-wrap:wrap;margin-top:1.5rem}.contact-name{font-weight:700;font-size:1.15rem;color:#eae9e5}.contact-link{background:#4d4d5c;color:#fff;border-radius:1rem;padding:.7rem 1.5rem;text-decoration:none;font-weight:600;font-size:1.05rem;transition:background .2s,box-shadow .3s;display:flex;align-items:center;gap:.7rem}.contact-link:hover{background:#575768;box-shadow:0 0 16px #18181b,0 0 32px #2563eb}.contact-link:hover{background:#444c5c;box-shadow:0 0 16px #18181b,0 0 32px #2563eb}.contact-link .contact-icon{background:#fff;border-radius:50%;box-shadow:0 0 12px #2563eb,0 0 24px #18181b;padding:.3rem;width:48px;height:48px;transition:box-shadow .3s,transform .3s}.contact-link:hover .contact-icon{box-shadow:0 0 24px gold,0 0 48px #2563eb;transform:scale(1.12)}.linkedin-icon{width:28px;height:28px;margin-right:.7rem}@media (max-width: 640px){.contact-section{padding:5rem 1rem 2rem}.contact-links{gap:1.5rem}.contact-link{padding:.6rem 1.2rem;font-size:1rem}.contact-link .contact-icon{width:40px;height:40px}.linkedin-icon{width:24px;height:24px;margin-right:.5rem}}.footer{background:#18181b;color:#f2f4f7;text-align:center;padding:1.5rem 0;font-size:1rem;box-shadow:0 -2px 5px #0000001a}@media (max-width:640px){.footer{padding:1.2rem 0;font-size:.95rem}}
