@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800&display=swap";body{margin:0;padding:0;min-height:100vh;font-family:Montserrat,sans-serif}#root{min-height:100vh;width:100%}:root{--sidebar-width: 240px}[data-theme=dark]{--bg: #0f0f0f;--surface: #161616;--surface-hover: #1e1e1e;--border: #252525;--text: #e8e8e8;--text-muted: #777;--text-faint: #444;--accent: #6366f1;--accent-hover: #818cf8;--card-bg: #141414;--card-border: #222;--overlay: rgba(0, 0, 0, .6)}[data-theme=light]{--bg: #f7f7f7;--surface: #ffffff;--surface-hover: #f0f0f0;--border: #e2e2e2;--text: #111111;--text-muted: #888;--text-faint: #ccc;--accent: #4f46e5;--accent-hover: #6366f1;--card-bg: #ffffff;--card-border: #e8e8e8;--overlay: rgba(0, 0, 0, .5)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:Montserrat,sans-serif;background-color:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:Montserrat,sans-serif;font-weight:700;letter-spacing:-.02em}a{color:inherit;text-decoration:none}button{font-family:Montserrat,sans-serif;cursor:pointer}img{display:block;max-width:100%}.app-layout{display:flex;min-height:100vh}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.section-header{margin-bottom:3rem}.section-title{font-size:1.75rem;font-weight:700;color:var(--text);margin-bottom:.75rem;letter-spacing:-.03em}.title-line{width:40px;height:3px;background:var(--accent);border-radius:2px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent);color:#fff}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.main-content{margin-left:0;padding-top:60px}.section-header{margin-bottom:2rem}.section-title{font-size:1.5rem}}@media(max-width:480px){.section-title{font-size:1.35rem}}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--surface);border-right:1px solid var(--border);z-index:100;display:flex;flex-direction:column;transition:background-color .3s ease,border-color .3s ease}.sidebar-inner{display:flex;flex-direction:column;height:100%;padding:2.5rem 1.75rem}.sidebar-identity{margin-bottom:3rem}.sidebar-name-btn{background:none;border:none;color:var(--text);font-family:Montserrat,sans-serif;font-size:.9rem;font-weight:700;letter-spacing:-.02em;cursor:pointer;padding:0;text-align:left;line-height:1.3;transition:color .2s}.sidebar-name-btn:hover{color:var(--accent)}.sidebar-role{display:block;font-size:.7rem;font-weight:500;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;margin-top:.35rem}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem;flex:1}.nav-link{background:none;border:none;color:var(--text-muted);font-family:Montserrat,sans-serif;font-size:.85rem;font-weight:500;letter-spacing:.01em;cursor:pointer;padding:.65rem .75rem;min-height:44px;border-radius:6px;text-align:left;transition:background .2s ease,color .2s ease;display:flex;align-items:center;width:100%}.nav-link:hover{color:var(--text);background:var(--surface-hover)}.sidebar-footer{padding-top:1.5rem;border-top:1px solid var(--border)}.theme-toggle{display:flex;align-items:center;gap:.6rem;background:none;border:none;color:var(--text-muted);font-family:Montserrat,sans-serif;font-size:.8rem;font-weight:500;cursor:pointer;padding:.5rem .75rem;border-radius:6px;transition:background .2s ease,color .2s ease;width:100%;text-align:left}.theme-toggle:hover{color:var(--text);background:var(--surface-hover)}.mobile-topbar{display:none;position:fixed;top:0;left:0;right:0;height:60px;background:var(--surface);border-bottom:1px solid var(--border);z-index:200;align-items:center;justify-content:space-between;padding:0 1.25rem}.mobile-topbar .sidebar-name{font-size:.9rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.mobile-toggle{background:none;border:none;color:var(--text);cursor:pointer;padding:.5rem;min-width:44px;min-height:44px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .2s}.mobile-toggle:hover{background:var(--surface-hover)}.sidebar-backdrop{display:none;position:fixed;inset:0;background:var(--overlay);z-index:99}@media(max-width:768px){.mobile-topbar{display:flex}.sidebar{transform:translate(-100%);transition:transform .3s ease,background-color .3s ease,border-color .3s ease;top:60px;height:calc(100vh - 60px);width:260px}.sidebar.mobile-open{transform:translate(0)}.sidebar-backdrop{display:block;top:60px}}.hero{min-height:100vh;display:flex;align-items:center;padding:4rem 4rem 4rem 5rem;border-bottom:1px solid var(--border)}.hero-content{max-width:600px;animation:fadeInUp .6s ease both}.hero-tag{font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:1.25rem}.hero-title{font-size:clamp(3rem,6vw,5.5rem);font-weight:800;line-height:1;letter-spacing:-.04em;color:var(--text);margin-bottom:1.75rem}.hero-description{font-size:1rem;font-weight:400;line-height:1.75;color:var(--text-muted);max-width:480px;margin-bottom:2.5rem}.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}.cta-primary{background:var(--accent);color:#fff;border:none;padding:.75rem 1.75rem;font-family:Montserrat,sans-serif;font-size:.85rem;font-weight:600;letter-spacing:.02em;border-radius:6px;cursor:pointer;transition:background .2s ease,transform .2s ease}.cta-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.cta-secondary{background:transparent;color:var(--text-muted);border:1px solid var(--border);padding:.75rem 1.75rem;font-family:Montserrat,sans-serif;font-size:.85rem;font-weight:600;letter-spacing:.02em;border-radius:6px;cursor:pointer;transition:border-color .2s ease,color .2s ease,transform .2s ease;text-decoration:none;display:inline-flex;align-items:center}.cta-secondary:hover{border-color:var(--text-muted);color:var(--text);transform:translateY(-1px)}@media(max-width:768px){.hero{padding:4rem 1.5rem 3.5rem;min-height:calc(100vh - 60px);align-items:center}.hero-title{font-size:clamp(2.5rem,12vw,3.5rem)}.hero-description{font-size:.9rem;margin-bottom:2rem}}@media(max-width:480px){.hero{padding:4rem 1.25rem 3rem}.hero-cta{flex-direction:column}.cta-primary,.cta-secondary{width:100%;justify-content:center;padding:.875rem 1.5rem;min-height:48px}}.experience{padding:5rem 4rem 5rem 5rem;border-bottom:1px solid var(--border)}.experience-container{max-width:700px}.experience-list{display:flex;flex-direction:column;gap:1.5rem}.experience-item{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:1.75rem;transition:border-color .2s}.experience-item:hover{border-color:var(--text-faint)}.exp-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.exp-role{font-size:1rem;font-weight:700;color:var(--text);letter-spacing:-.02em;margin-bottom:.2rem}.exp-company{font-size:.82rem;font-weight:600;color:var(--accent)}.exp-period{font-size:.75rem;font-weight:500;color:var(--text-muted);white-space:nowrap;padding-top:.15rem;flex-shrink:0}.exp-bullets{list-style:none;display:flex;flex-direction:column;gap:.6rem}.exp-bullets li{font-size:.83rem;line-height:1.65;color:var(--text-muted);padding-left:1rem;position:relative}.exp-bullets li:before{content:"–";position:absolute;left:0;color:var(--accent);font-weight:600}@media(max-width:768px){.experience{padding:3rem 1.25rem}.experience-item{padding:1.25rem}.exp-header{flex-direction:column;gap:.35rem;margin-bottom:1rem}.exp-period{white-space:normal}}.projects{padding:5rem 4rem 5rem 5rem;border-bottom:1px solid var(--border)}.projects-container{max-width:1000px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:3rem}.project-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;overflow:hidden;transition:border-color .2s ease,transform .2s ease;animation:fadeInUp .5s ease both}.project-card:hover{border-color:var(--accent);transform:translateY(-3px)}.project-thumbnail{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--surface)}.project-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-card:hover .project-thumbnail img{transform:scale(1.03)}.project-overlay{position:absolute;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.project-card:hover .project-overlay{opacity:1}.project-links{display:flex;gap:1rem}.project-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);transition:background .2s,color .2s;text-decoration:none}.project-link:hover{background:var(--accent);border-color:var(--accent);color:#fff}.project-content{padding:1.25rem}.project-title{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:.5rem;letter-spacing:-.01em}.project-description{font-size:.82rem;line-height:1.65;color:var(--text-muted);margin-bottom:1rem}.project-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.project-tech{display:flex;gap:.5rem;flex-wrap:wrap}.tech-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center}.tech-icon img{width:100%;height:100%;object-fit:contain}.project-actions-mobile{display:none;gap:.5rem}.project-actions-mobile a{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;color:var(--text-muted);border:1px solid var(--border);transition:color .2s,border-color .2s}.project-actions-mobile a:hover{color:var(--accent);border-color:var(--accent)}.view-more-container{display:flex}.view-more-btn{display:inline-flex;align-items:center;gap:.5rem;background:none;border:1px solid var(--border);color:var(--text-muted);font-family:Montserrat,sans-serif;font-size:.82rem;font-weight:600;padding:.65rem 1.25rem;border-radius:6px;cursor:pointer;transition:border-color .2s,color .2s}.view-more-btn:hover{border-color:var(--accent);color:var(--accent)}@media(max-width:768px){.projects{padding:3rem 1.25rem}.projects-grid{grid-template-columns:1fr;gap:1rem}.project-actions-mobile{display:flex}.project-overlay{display:none}.view-more-btn{width:100%;justify-content:center;min-height:48px}}.skills{padding:5rem 4rem 5rem 5rem;border-bottom:1px solid var(--border)}.skills-container{max-width:1000px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:2rem}.skill-category{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:1.5rem;transition:border-color .2s}.skill-category:hover{border-color:var(--text-faint)}.category-title{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1.25rem}.skills-list{display:flex;flex-direction:column;gap:.65rem}.skill-item{display:flex;align-items:center;gap:.75rem}.skill-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center}.skill-icon img{width:100%;height:100%;object-fit:contain}.skill-name{font-size:.83rem;font-weight:500;color:var(--text)}@media(max-width:768px){.skills{padding:3rem 1.5rem}.skills-grid{grid-template-columns:repeat(2,1fr);gap:1rem}}@media(max-width:480px){.skills-grid{grid-template-columns:1fr}}.contact{padding:5rem 4rem 5rem 5rem}.contact-container{max-width:700px}.contact-content{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:start;margin-bottom:4rem}.contact-heading{font-size:1.4rem;font-weight:700;color:var(--text);margin-bottom:.75rem;letter-spacing:-.02em}.contact-description{font-size:.88rem;line-height:1.7;color:var(--text-muted);margin-bottom:1.25rem;max-width:360px}.contact-email{font-size:.85rem;font-weight:600;color:var(--accent);text-decoration:none;transition:color .2s}.contact-email:hover{color:var(--accent-hover)}.social-links{display:flex;flex-direction:column;gap:.5rem}.social-link{display:flex;align-items:center;gap:.6rem;color:var(--text-muted);font-size:.83rem;font-weight:500;text-decoration:none;padding:.4rem .6rem;border-radius:6px;transition:color .2s,background .2s}.social-link:hover{color:var(--text);background:var(--surface-hover)}.footer{padding-top:2rem;border-top:1px solid var(--border);color:var(--text-muted);font-size:.78rem}@media(max-width:768px){.contact{padding:3rem 1.5rem}.contact-content{grid-template-columns:1fr;gap:2rem}.social-links{flex-direction:row;flex-wrap:wrap}}.projects-page{padding:5rem 4rem 5rem 5rem;min-height:100vh}.projects-page-container{max-width:1000px}.projects-page .projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.projects-page .project-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;overflow:hidden;transition:border-color .2s ease,transform .2s ease;animation:fadeInUp .5s ease both}.projects-page .project-card:hover{border-color:var(--accent);transform:translateY(-3px)}.projects-page .project-thumbnail{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--surface)}.projects-page .project-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.projects-page .project-card:hover .project-thumbnail img{transform:scale(1.03)}.projects-page .project-overlay{position:absolute;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.projects-page .project-card:hover .project-overlay{opacity:1}.projects-page .project-links{display:flex;gap:1rem}.projects-page .project-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);transition:background .2s,color .2s;text-decoration:none}.projects-page .project-link:hover{background:var(--accent);border-color:var(--accent);color:#fff}.projects-page .project-content{padding:1.25rem}.projects-page .project-title{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:.5rem;letter-spacing:-.01em}.projects-page .project-description{font-size:.82rem;line-height:1.65;color:var(--text-muted);margin-bottom:1rem}.projects-page .project-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.projects-page .project-tech{display:flex;gap:.5rem;flex-wrap:wrap}.projects-page .tech-icon{width:22px;height:22px;display:flex;align-items:center}.projects-page .tech-icon img{width:100%;height:100%;object-fit:contain}.projects-page .project-actions-mobile{display:none;gap:.5rem}.projects-page .project-actions-mobile a{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;color:var(--text-muted);border:1px solid var(--border);transition:color .2s,border-color .2s}.projects-page .project-actions-mobile a:hover{color:var(--accent);border-color:var(--accent)}@media(max-width:768px){.projects-page{padding:3rem 1.25rem}.projects-page .projects-grid{grid-template-columns:1fr;gap:1rem}.projects-page .project-actions-mobile{display:flex}.projects-page .project-overlay{display:none}}
