:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;--bg-dark: #1b1b1b;--bg-light: #f5f5f5;--text-dark: #f9f9f9;--text-light: #213547;--accent: #2563eb;--highlight: #d4af37}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;background:var(--bg-light);color:var(--text-light)}.app-layout{display:flex;min-height:100vh;width:100%;font-family:inherit;background:var(--bg-light)}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;background:var(--bg-dark);color:var(--text-dark);padding:1rem;z-index:1001;box-shadow:0 2px 10px #0000004d}.mobile-header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.mobile-profile{display:flex;align-items:center;gap:.8rem}.mobile-pfp{width:40px;height:40px;border-radius:50%;object-fit:cover}.mobile-name{font-size:1.1rem;font-weight:600}.hamburger{background:none;border:none;color:var(--text-dark);font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background .3s ease}.hamburger:hover{background:#ffffff1a}.mobile-menu{display:none;position:fixed;inset:0;background:#000000e6;z-index:1002;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.mobile-menu.open{display:block}.mobile-menu-content{position:absolute;top:0;right:0;width:280px;height:100%;background:var(--bg-dark);color:var(--text-dark);padding:2rem 1rem;transform:translate(100%);transition:transform .3s ease;overflow-y:auto}.mobile-menu.open .mobile-menu-content{transform:translate(0)}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.mobile-close{background:none;border:none;color:var(--text-dark);font-size:1.5rem;cursor:pointer;padding:.5rem}.mobile-menu-profile{text-align:center;margin-bottom:2rem}.mobile-menu-pfp{width:100px;height:100px;border-radius:50%;object-fit:cover;margin-bottom:1rem;box-shadow:0 4px 16px #0006}.mobile-menu-name{font-size:1.3rem;font-weight:600}.mobile-menu-email{font-size:.9rem;color:#aaa;margin-top:.3rem}.mobile-nav-links{display:flex;flex-direction:column;gap:1rem}.mobile-nav-link{text-decoration:none;color:var(--text-dark);font-weight:600;font-size:1.1rem;padding:.8rem 1rem;border-radius:8px;transition:all .3s ease;text-align:center}.mobile-nav-link:hover,.mobile-nav-link.active{background:#ffffff1a;color:var(--highlight)}.sidebar{flex-shrink:0;width:260px;background:var(--bg-dark);color:var(--text-dark);display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;box-shadow:4px 0 20px #00000040;position:sticky;top:0;height:100vh;border-right:1px solid rgba(255,255,255,.1)}.sidebar .profile{text-align:center;margin-bottom:2rem}.sidebar .pfp{width:120px;height:120px;border-radius:50%;object-fit:cover;margin-bottom:1rem;box-shadow:0 6px 20px #00000059;transition:transform .3s ease,box-shadow .3s ease}.sidebar .pfp:hover{transform:scale(1.08);box-shadow:0 12px 32px #00000080}.sidebar .name{font-size:1.4rem;font-weight:600;margin:.5rem 0 .25rem}.sidebar .profile p{font-size:.85rem;color:#aaa}.nav-links-vertical{display:flex;flex-direction:column;gap:1rem;width:100%}.nav-link{display:block;padding:.75rem 1rem;border-radius:.5rem;font-size:1rem;font-weight:500;text-decoration:none;color:var(--text-dark);transition:background .3s ease,transform .2s ease}.nav-link:hover{background:#ffffff14;transform:translate(4px)}.nav-link.active{background:#ffffff26;font-weight:600;color:var(--highlight)}.content{flex:1;display:flex;flex-direction:column;justify-content:space-between;padding:3rem 2rem;overflow-y:auto;position:relative;background:linear-gradient(120deg,var(--bg-dark) 0%,var(--bg-dark) 20%,#3a3525 40%,#b89d2a 70%,#d4af37 100%);background-size:200% 100%;background-position:0% 50%;animation:contentSlide 4s ease forwards}@keyframes contentSlide{0%{background-position:0% 50%}to{background-position:100% 50%}}.home-section{position:relative;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:2rem;overflow:hidden}.home-text{max-width:700px}.home-text h2{font-size:2.5rem;margin-bottom:1rem}.tech-stack{display:flex;justify-content:center;gap:1.2rem;flex-wrap:wrap}.intro{font-size:1.1rem;margin-bottom:1rem}.tech-stack img{height:40px;margin:.5rem .8rem .5rem 0;transition:transform .3s ease}.tech-stack img:hover{transform:scale(1.15)}.timeline{list-style:none;padding:0;margin:1.5rem 0;display:flex;flex-direction:column;gap:1.5rem;border-left:none}.timeline-box{background:#000000b3;padding:2rem;margin:2rem 0;border-radius:16px;box-shadow:0 6px 24px #0006;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:transform .3s ease,box-shadow .3s ease}.timeline-box:hover{transform:translateY(-6px);box-shadow:0 10px 32px #d4af3759}.timeline-box h3{font-size:1.6rem;margin-bottom:1.5rem;color:var(--highlight);text-align:center}.timeline li{background:#000000b3;padding:1.2rem 1.5rem;border-radius:12px;box-shadow:0 4px 16px #0000004d;transition:transform .3s ease,box-shadow .3s ease,background .3s ease;opacity:0;transform:translateY(30px);animation:timelineFadeUp .8s ease forwards}.timeline li:hover{transform:translateY(-4px);background:#000c;box-shadow:0 6px 20px #d4af3759}.timeline li ul{margin-top:.5rem;margin-left:1rem;padding-left:1rem;list-style-type:disc;color:#fffc;font-size:.95rem;line-height:1.5}.timeline li ul li{margin-bottom:.4rem;transition:color .3s ease}.timeline li ul li:hover{color:var(--highlight)}@keyframes timelineFadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.timeline li:nth-child(1){animation-delay:.2s}.timeline li:nth-child(2){animation-delay:.4s}.timeline li:nth-child(3){animation-delay:.6s}.timeline li:nth-child(4){animation-delay:.8s}.timeline h4{font-size:1.2rem;margin-bottom:.4rem;color:var(--highlight)}.timeline p{font-size:1rem;color:var(--text-dark)}.projects-section{padding:2rem 0;text-align:center}.projects-section h3{font-size:2rem;margin-bottom:2rem;color:var(--highlight)}.projects-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(330px,1fr))}.project-card{background:#000000b3;border-radius:16px;padding:1.5rem;box-shadow:0 6px 24px #0006;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:transform .3s ease,box-shadow .3s ease,background .3s ease;display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer}.project-card:hover{transform:translateY(-6px);box-shadow:0 10px 32px #d4af3759;background:#000c}.project-card h4{margin-top:1rem;margin-bottom:.8rem;color:var(--highlight)}.project-card p{color:#ffffffd9;font-size:.95rem;line-height:1.4}.project-image{width:100%;height:160px;overflow:hidden;border-radius:12px}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-card:hover .project-image img{transform:scale(1.05)}.project-popup{position:fixed;top:0;right:0;width:40%;max-width:90%;height:100%;background:#000000f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:2rem;box-shadow:-8px 0 24px #00000080;display:flex;flex-direction:column;align-items:center;text-align:center;transform:translate(100%);animation:slideIn .4s forwards;z-index:1000;overflow-y:auto}.project-popup p{color:#ffffffe6;font-size:1rem;line-height:1.6;margin:1rem 0;text-align:left;width:100%;max-width:700px;text-align:center}.project-popup h2{color:var(--highlight);margin-bottom:1rem}.popup-box{background:#ffffff0d;border-radius:12px;padding:1.2rem;margin:1.2rem 0;box-shadow:0 6px 20px #0000004d;display:flex;flex-direction:column;align-items:center;gap:1rem;transition:transform .3s ease,box-shadow .3s ease}.popup-box:hover{transform:translateY(-4px);box-shadow:0 10px 28px #d4af374d}.popup-box img{max-width:100%;border-radius:8px;box-shadow:0 3px 12px #00000040}.popup-text{color:#ffffffe6;font-size:1rem;line-height:1.5;text-align:left;width:100%}.popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;justify-content:flex-end;z-index:999}@keyframes slideIn{to{transform:translate(0)}}.close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;font-size:2rem;color:var(--highlight);cursor:pointer}.project-popup img{width:100%;border-radius:12px;margin:1rem 0}.project-popup a{display:inline-block;margin:.5rem .8rem;padding:.6rem 1.2rem;border-radius:8px;background:var(--highlight);color:#000;font-weight:600;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease}.project-popup a:hover{transform:translateY(-2px);box-shadow:0 4px 12px #d4af3780}.contact-bar{position:fixed;bottom:1rem;left:50%;transform:translate(-20%);background:var(--bg-dark);color:var(--text-dark);display:flex;justify-content:center;gap:2rem;padding:.75rem 1.5rem;border-radius:50px;box-shadow:0 10px 32px #0000004d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100;transition:background .3s ease,color .3s ease}.contact-bar a{color:var(--text-dark);font-weight:600;transition:color .3s ease,transform .3s ease}.contact-bar a:hover{color:var(--highlight);transform:translateY(-3px)}.spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.loader{border:4px solid rgba(255,255,255,.3);border-top:4px solid #3498db;border-radius:50%;width:32px;height:32px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.image-wrapper.grid{width:100%;height:160px;overflow:hidden;border-radius:12px}.image-wrapper.grid img{width:100%;height:100%;object-fit:cover;display:block}.image-wrapper.popup{width:100%;border-radius:12px;overflow:hidden}.image-wrapper.popup img{width:100%;height:auto;object-fit:contain;display:block}.media-wrapper.grid,.media-wrapper.popup{border-radius:12px;overflow:hidden}.media-wrapper.grid{width:100%;height:160px}.media-wrapper.grid video,.media-wrapper.grid img{width:100%;height:100%;object-fit:cover;display:block}.media-wrapper.popup video,.media-wrapper.popup img{width:100%;height:auto;object-fit:contain;display:block}@media (max-width: 768px){.sidebar{display:none}.mobile-header{display:block}.app-layout{flex-direction:column}.content{padding:5rem 1rem 2rem;margin-top:0}.home-text h2{font-size:2rem}.timeline-box{padding:1.5rem;margin:1rem 0}.timeline-box h3{font-size:1.4rem}.tech-stack img{height:35px;margin:.3rem}.projects-grid{grid-template-columns:1fr;gap:1rem}.contact-bar{left:50%;transform:translate(-50%);gap:1rem;padding:.6rem 1rem;font-size:.9rem}.project-popup{width:100%;padding:1.5rem}}@media (max-width: 480px){.content{padding:5rem .5rem 2rem}.home-text h2{font-size:1.8rem}.intro{font-size:1rem}.timeline-box{padding:1rem}.contact-bar{gap:.5rem;padding:.5rem .8rem;font-size:.8rem}}
