.language-switcher{background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:.3rem;font-size:.9rem;padding:.5rem 0;color:var(--color-black);transition:opacity .3s ease;white-space:nowrap}.language-switcher:hover{opacity:.6}.current-lang{font-weight:500;color:var(--color-black)}.lang-separator{color:var(--color-gray-medium);font-weight:300}.other-lang{color:var(--color-gray-medium);font-weight:400}@media(max-width:768px){.language-switcher{font-size:.85rem}}@media(max-width:480px){.language-switcher{font-size:.8rem;gap:.2rem}}:root{--color-black: #000000;--color-white: #ffffff;--color-gray-light: #f5f5f5;--color-gray-medium: #999999;--color-gray-dark: #333333;--transition-speed: .3s;--navbar-height: 80px}.navbar{position:fixed;top:0;left:0;right:0;height:var(--navbar-height);background-color:var(--color-white);border-bottom:1px solid var(--color-black);display:flex;justify-content:space-between;align-items:center;padding:0 5%;z-index:1000;transition:all var(--transition-speed) ease}.navbar-logo{text-decoration:none;color:var(--color-black);display:flex;flex-direction:column;gap:2px;transition:opacity var(--transition-speed) ease}.navbar-logo:hover{opacity:.7}.logo-text{font-size:1.2rem;font-weight:600;letter-spacing:-.02em;line-height:1.2}.logo-subtitle{font-size:.75rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;color:var(--color-gray-medium)}.navbar-right{display:flex;align-items:center;gap:2rem}.navbar-menu{display:flex;gap:3rem;list-style:none;margin:0;padding:0;align-items:center}.nav-link{position:relative;text-decoration:none;color:var(--color-black);font-size:.95rem;font-weight:400;letter-spacing:.02em;transition:color var(--transition-speed) ease;padding:.5rem 0;white-space:nowrap}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background-color:var(--color-black);transition:width var(--transition-speed) ease}.nav-link:hover:after{width:100%}.nav-link.active{font-weight:500}.nav-link.active:after{width:100%}@media(max-width:768px){.navbar{padding:0 4%}.navbar-right{gap:1.5rem}.navbar-menu{gap:2rem}.logo-text{font-size:1.1rem}.nav-link{font-size:.9rem}}@media(max-width:480px){.navbar{padding:0 5%;height:70px}.navbar-right{gap:1rem}.navbar-menu{gap:1.5rem}.logo-text{font-size:1rem}.logo-subtitle{font-size:.7rem}.nav-link{font-size:.85rem}}.navbar.scrolled{box-shadow:0 2px 10px #0000000d;background-color:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.footer{border-top:1px solid #000000;padding:2rem 0;margin-top:auto;background-color:#fff}.footer-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.footer-copyright{color:#666;font-size:.875rem}.footer-copyright p{margin:0}.footer-social{display:flex;gap:1.5rem;align-items:center}.footer-social-link{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;text-decoration:none;color:#000;border:1px solid #000000;background-color:#fff;font-size:.875rem;font-weight:500;transition:all .3s ease;cursor:pointer}.footer-social-link:hover{background-color:#000;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.footer-social-link:active{transform:translateY(0)}.footer-social-icon{width:20px;height:20px;flex-shrink:0}.footer-social-text{font-size:.875rem;line-height:1}.footer-social-link:nth-child(1):hover{background-color:#24292e;border-color:#24292e;color:#fff}.footer-social-link:nth-child(2):hover{background-color:#0077b5;border-color:#0077b5;color:#fff}.footer-social-link:nth-child(3):hover{background-color:#000;border-color:#000;color:#fff}@media(max-width:1024px){.footer-content{padding:0 1.5rem}.footer-social{gap:1.25rem}}@media(max-width:768px){.footer{padding:1.5rem 0}.footer-content{flex-direction:column;gap:1.5rem;text-align:center}.footer-social{justify-content:center}.footer-social-icon{width:18px;height:18px}}@media(max-width:480px){.footer{padding:1.5rem 0}.footer-content{padding:0 1rem}.footer-social{flex-direction:column;gap:1rem;width:100%}.footer-social-link{width:100%;justify-content:center;padding:.75rem 1rem}.footer-social-icon{width:16px;height:16px}.footer-social-text,.footer-copyright{font-size:.8125rem}}.home{width:100%;min-height:calc(100vh - 80px)}.hero{height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:0 5%;position:relative}.hero-content{max-width:1200px;width:100%}.hero-title{font-size:clamp(3rem,10vw,8rem);font-weight:600;line-height:1.4;letter-spacing:-.03em;margin-bottom:2rem;display:flex;flex-direction:column}.title-line{display:block;overflow:hidden}.hero-description{font-size:clamp(1rem,2vw,1.25rem);color:#666;max-width:600px;letter-spacing:.01em;line-height:1.6}@media(max-width:768px){.hero{height:calc(100vh - 70px)}.hero-title{margin-bottom:1.5rem}}@media(max-width:480px){.hero-content{text-align:left}}.about{width:100%;min-height:calc(100vh - 80px)}.about-hero{padding:5rem 5%;min-height:calc(100vh - 80px)}.about-container{max-width:1200px;margin:0 auto}.about-title{font-size:clamp(3rem,8vw,5rem);font-weight:600;letter-spacing:-.03em;margin-bottom:4rem;line-height:1.1}.about-content{display:flex;gap:4rem;align-items:center;margin-bottom:5rem;flex-wrap:wrap}.about-text{flex:1;min-width:300px;display:flex;flex-direction:column;gap:1.5rem}.about-intro{font-size:clamp(1.25rem,2.5vw,1.75rem);line-height:1.6;letter-spacing:-.01em;font-weight:500}.about-description{font-size:clamp(1rem,2vw,1.125rem);line-height:1.8;color:#666}.about-pic{flex:0 0 auto;display:flex;justify-content:center;align-items:center}.profile-pic{width:clamp(280px,35vw,380px);height:clamp(280px,35vw,380px);border-radius:50%;object-fit:cover;box-shadow:0 10px 40px #0000001a;transition:transform .3s ease}.skills-section{border-top:1px solid #e0e0e0;padding-top:4rem;margin-top:3rem}.section-title{font-size:clamp(1.5rem,3vw,2rem);font-weight:600;margin-bottom:2.5rem;letter-spacing:-.02em}.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3rem 2rem}.skill-category{display:flex;flex-direction:column;gap:1rem}.category-title{font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;color:#000}.skill-list{list-style:none;display:flex;flex-direction:column;gap:.75rem;padding:0;margin:0}.skill-list li{font-size:.95rem;color:#666;padding-left:1.5rem;position:relative;line-height:1.4}.skill-list li:before{content:"—";position:absolute;left:0;color:#000}@media(max-width:1024px){.about-main{gap:3rem}.skills-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem 2rem}}@media(max-width:968px){.about-main{flex-direction:column;align-items:center;text-align:center}.about-text{align-items:center;max-width:100%}.about-pic{order:-1}}@media(max-width:768px){.about-hero{padding:3rem 5%}.about-title{margin-bottom:3rem}.about-main{gap:2.5rem;margin-bottom:4rem}.skills-section{padding-top:3rem}.skills-grid{grid-template-columns:repeat(2,1fr);gap:2rem 1.5rem}.profile-pic{width:280px;height:280px}}@media(max-width:640px){.about-hero{padding:2.5rem 5%}.skills-grid{grid-template-columns:1fr;gap:2rem}.profile-pic{width:250px;height:250px}}@media(max-width:480px){.about-hero{padding:2rem 5%;min-height:auto}.about-title{margin-bottom:2rem;font-size:clamp(2.5rem,10vw,3rem)}.about-main{gap:2rem;margin-bottom:3rem}.about-intro{font-size:1.125rem}.about-description{font-size:.95rem}.skills-section{padding-top:2.5rem;margin-top:2rem}.section-title{margin-bottom:2rem}.skills-grid{gap:1.5rem}.profile-pic{width:220px;height:220px}}@media(max-width:360px){.about-hero{padding:1.5rem 5%}.profile-pic{width:200px;height:200px}.about-intro{font-size:1rem}.about-description{font-size:.9rem}}.projects{width:100%;min-height:calc(100vh - 80px)}.projects-hero{padding:5rem 5%;min-height:calc(100vh - 80px)}.projects-container{max-width:1200px;margin:0 auto}.projects-title{font-size:clamp(3rem,8vw,5rem);font-weight:600;letter-spacing:-.03em;margin-bottom:4rem;line-height:1}.projects-grid{display:flex;flex-direction:column;gap:4rem}.project-card{border-top:1px solid #000000;padding-top:2rem;display:flex;flex-direction:column;gap:1.5rem;transition:opacity .3s ease;cursor:pointer}.project-card:hover{opacity:.7}.project-title{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:600;letter-spacing:-.02em;line-height:1.2}.project-description{font-size:clamp(1rem,2vw,1.125rem);line-height:1.7;color:#666;max-width:700px}@media(max-width:768px){.projects-hero{padding:3rem 5%}.projects-title{margin-bottom:3rem}.projects-grid{gap:3rem}.project-header{flex-direction:column;gap:.5rem;align-items:flex-start}}@media(max-width:480px){.projects-hero{padding:2rem 5%}.project-card{padding-top:1.5rem}.projects-grid{gap:2.5rem}}.project-card{border-top:1px solid #000000;padding-top:2rem;padding-bottom:2rem;transition:opacity .3s ease}.project-content-wrapper{display:flex;gap:3rem;align-items:flex-start}.project-text-section{flex:1;display:flex;flex-direction:column;gap:1.5rem}.project-header{display:flex;justify-content:space-between;align-items:baseline;gap:2rem}.project-title{font-size:clamp(1.5rem,3vw,2rem);font-weight:600;letter-spacing:-.02em;line-height:1.2}.project-year{font-size:1rem;color:#666;font-weight:400;white-space:nowrap}.project-description{font-size:clamp(.95rem,1.5vw,1.05rem);line-height:1.7;color:#666}.project-tags{display:flex;flex-wrap:wrap;gap:.75rem}.project-tag{font-size:.875rem;color:#000;padding:.5rem 1rem;border:1px solid #000000;display:inline-block;letter-spacing:.02em;transition:all .3s ease}.project-card:hover .project-tag{background-color:#000;color:#fff}.project-links{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}.project-link-button{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;text-decoration:none;border:1px solid #000000;background-color:#fff;color:#000;transition:all .3s ease;cursor:pointer;letter-spacing:.02em}.project-link-button:hover{background-color:#000;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.project-link-button:active{transform:translateY(0)}.link-icon{font-size:1rem;line-height:1}.link-text{line-height:1}.project-link-button.github:hover{background-color:#24292e;border-color:#24292e;color:#fff}.project-link-button.demo:hover{background-color:#06c;border-color:#06c;color:#fff}.project-link-button.video:hover{background-color:red;border-color:red;color:#fff}.project-carousel-section{flex:0 0 320px;display:flex;flex-direction:column;gap:.75rem}.carousel-container{position:relative;width:100%;min-height:240px;max-height:400px;overflow:hidden;background-color:#f5f5f5;border:1px solid #e0e0e0;display:flex;align-items:center;justify-content:center}.carousel-image{object-fit:contain;max-width:100%;max-height:100%;width:auto;height:auto;transition:opacity .3s ease}.carousel-video{width:100%;height:100%;min-height:240px;border:none}.carousel-button{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;background-color:#ffffffe6;border:1px solid #000000;border-radius:50%;font-size:1.25rem;color:#000;cursor:pointer;transition:all .3s ease;opacity:.7;z-index:10;display:flex;align-items:center;justify-content:center}.carousel-button-prev{left:1rem}.carousel-button-next{right:1rem}.carousel-button:active{transform:translateY(-50%) scale(.95)}.carousel-indicators{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 0}.indicator-dot{width:8px;height:8px;border-radius:50%;border:1px solid #000000;background-color:transparent;cursor:pointer;transition:all .3s ease;padding:0}.indicator-dot.active{background-color:#000;width:10px;height:10px}.indicator-dot.indicator-video{border-color:red}.indicator-dot.indicator-video.active{background-color:red}.indicator-dot:hover{background-color:#666}.image-counter{font-size:.875rem;color:#666;margin-left:.5rem}@media(max-width:1024px){.project-carousel-section{flex:0 0 280px}.project-content-wrapper{gap:2rem}}@media(max-width:768px){.project-content-wrapper{flex-direction:column;gap:2rem}.project-carousel-section{flex:none;width:100%}.carousel-container{min-height:300px;max-height:500px}.carousel-button{width:36px;height:36px;font-size:1.125rem}.project-header{flex-direction:column;gap:.5rem;align-items:flex-start}}@media(max-width:480px){.project-card{padding-top:1.5rem;padding-bottom:1.5rem}.project-content-wrapper{gap:1.5rem}.project-links{flex-direction:column}.project-link-button{width:100%;justify-content:center}.carousel-container{min-height:250px;max-height:400px}.carousel-button{width:32px;height:32px;font-size:1rem}.carousel-button-prev{left:.5rem}.carousel-button-next{right:.5rem}.indicator-dot{width:6px;height:6px}.indicator-dot.active{width:8px;height:8px}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}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;background-color:#fff;color:#000;line-height:1.6}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;margin-top:80px;width:100%}@media(max-width:480px){.main-content{margin-top:70px}}::selection{background-color:#000;color:#fff}
