@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@300;400;500;600&display=swap";.header{position:fixed;top:0;left:0;right:0;z-index:var(--z-mobile-nav);background-color:#0a0a0ae6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:all var(--transition-normal);isolation:isolate;width:100%;max-width:100vw}.header--scrolled{background-color:#0a0a0af2;border-bottom-color:var(--color-border);box-shadow:var(--shadow-md)}.header__content{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) 0;min-height:70px;width:100%;max-width:100%;box-sizing:border-box}.header__logo{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:600;font-size:1.25rem;color:var(--color-text-primary);text-decoration:none;transition:color var(--transition-fast)}.header__logo:hover{color:var(--color-accent)}.header__logo-text{font-family:var(--font-mono);color:var(--color-accent);font-weight:700;font-size:1.5rem}.header__name{font-weight:600}.header__nav{display:flex;align-items:center;gap:var(--spacing-xl)}.header__nav-link{position:relative;font-weight:500;color:var(--color-text-secondary);text-decoration:none;padding:var(--spacing-sm) 0;transition:color var(--transition-fast)}.header__nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background-color:var(--color-accent);transition:width var(--transition-normal)}.header__nav-link:hover,.header__nav-link--active{color:var(--color-text-primary)}.header__nav-link:hover:after,.header__nav-link--active:after{width:100%}.header__mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:var(--spacing-sm);z-index:calc(var(--z-mobile-nav) + 1);position:relative;flex-shrink:0}.hamburger{display:flex;flex-direction:column;gap:4px;width:24px;height:18px;position:relative}.hamburger span{display:block;height:2px;background-color:var(--color-text-primary);transition:all var(--transition-normal);transform-origin:center;border-radius:1px}.hamburger--active span{background-color:var(--color-accent)}.hamburger--active span:nth-child(1){transform:rotate(45deg) translate(7px,7px)}.hamburger--active span:nth-child(2){opacity:0}.hamburger--active span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}@media (max-width: 768px){.header{padding:0 var(--spacing-md);z-index:calc(var(--z-mobile-nav) + 10)}.header__mobile-toggle{display:block;position:relative;z-index:calc(var(--z-mobile-nav) + 20);background:#0a0a0af2;border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid transparent;transition:all var(--transition-fast)}.header__mobile-toggle:hover{border-color:var(--color-border);background:#1a1a1af2}.header__nav--desktop{display:none}.header__nav--mobile{position:fixed;top:0;right:0;width:280px;height:100vh;background-color:var(--color-bg-secondary);border-left:1px solid var(--color-border);display:flex;flex-direction:column;justify-content:center;gap:var(--spacing-lg);z-index:var(--z-mobile-nav);box-shadow:-5px 0 15px #0000004d;padding-top:80px}.header__nav--mobile .header__nav-link{font-size:1.125rem;padding:var(--spacing-md);text-align:center;width:100%}.header__nav--mobile .header__nav-link:after{left:50%;transform:translate(-50%)}.header__content{padding:var(--spacing-md) 0}}@media (max-width: 1024px) and (min-width: 769px){.header__nav{gap:var(--spacing-lg)}}.footer{border-top:1px solid var(--color-border);background-color:var(--color-bg-secondary);padding:var(--spacing-xl) 0;margin-top:auto}.footer__content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-lg)}.footer__info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.footer__text{font-size:.875rem;color:var(--color-text-secondary);margin:0}.footer__accent{color:var(--color-accent);font-weight:600}.footer__copyright{font-size:.75rem;color:var(--color-text-muted);margin:0}.footer__links{display:flex;gap:var(--spacing-lg);align-items:center}.footer__link{font-size:.875rem;font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast);position:relative}.footer__link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background-color:var(--color-accent);transition:width var(--transition-normal)}.footer__link:hover{color:var(--color-accent)}.footer__link:hover:after{width:100%}@media (max-width: 768px){.footer__content{flex-direction:column;text-align:center;gap:var(--spacing-md)}.footer__links{gap:var(--spacing-md)}}@media (max-width: 480px){.footer__links{flex-direction:column;gap:var(--spacing-sm)}}.animated-background{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:var(--z-background);overflow:hidden}.falling-item{position:absolute;left:var(--x-position);top:-50px;font-family:var(--font-mono);font-size:var(--font-size);color:var(--color-text-secondary);opacity:var(--opacity);white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;animation:fall linear var(--fall-duration) var(--delay) infinite;transform:translate(-50%)}.falling-item:nth-child(odd){animation-name:fall-with-sway-left}.falling-item:nth-child(2n){animation-name:fall-with-sway-right}.falling-item:nth-child(3n){animation-name:fall-straight}@keyframes fall-straight{0%{transform:translateY(-50px) translate(-50%);opacity:0}10%{opacity:var(--opacity)}90%{opacity:var(--opacity)}to{transform:translateY(calc(100vh + 50px)) translate(-50%);opacity:0}}@keyframes fall-with-sway-left{0%{transform:translateY(-50px) translate(-50%);opacity:0}10%{opacity:var(--opacity)}25%{transform:translateY(25vh) translate(-60%)}50%{transform:translateY(50vh) translate(-40%)}75%{transform:translateY(75vh) translate(-60%)}90%{opacity:var(--opacity)}to{transform:translateY(calc(100vh + 50px)) translate(-50%);opacity:0}}@keyframes fall-with-sway-right{0%{transform:translateY(-50px) translate(-50%);opacity:0}10%{opacity:var(--opacity)}25%{transform:translateY(25vh) translate(-40%)}50%{transform:translateY(50vh) translate(-60%)}75%{transform:translateY(75vh) translate(-40%)}90%{opacity:var(--opacity)}to{transform:translateY(calc(100vh + 50px)) translate(-50%);opacity:0}}@media (max-width: 768px){.falling-item{font-size:calc(var(--font-size) * .8)}}@media (max-width: 480px){.falling-item{font-size:calc(var(--font-size) * .6)}.animated-background{-webkit-backdrop-filter:blur(.5px);backdrop-filter:blur(.5px)}}@media (prefers-reduced-motion: reduce){.falling-item{animation-duration:20s!important;opacity:calc(var(--opacity) * .5)!important}}@media (max-width: 480px) and (max-height: 800px){.animated-background{display:none}}.layout{min-height:100vh;display:flex;flex-direction:column;position:relative}.main-content{flex:1;display:flex;flex-direction:column;position:relative;z-index:1;-webkit-backdrop-filter:blur(.5px);backdrop-filter:blur(.5px)}.home{padding-top:70px}.hero{min-height:calc(100vh - 70px);display:flex;align-items:center;position:relative;overflow:hidden}.hero__content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-3xl);align-items:center;width:100%}.hero__greeting{margin-bottom:var(--spacing-md)}.hero__greeting-sign,.hero__greeting-text{color:var(--color-accent);font-size:1.125rem;font-weight:500}.hero__title{font-size:clamp(2.5rem,6vw,4rem);font-weight:700;line-height:1.1;margin-bottom:var(--spacing-sm)}.hero__name{color:var(--color-accent);position:relative}.hero__subtitle{font-size:clamp(1.25rem,3vw,1.75rem);font-weight:400;color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.hero__description{font-size:1.125rem;color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--spacing-xl);max-width:500px}.hero__actions{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);font-weight:600;font-size:1rem;border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-normal);border:2px solid transparent;cursor:pointer;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.btn:hover:before{left:100%}.btn--primary{background-color:var(--color-accent);color:var(--color-text-primary)}.btn--primary:hover{background-color:var(--color-accent-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn--secondary{background-color:transparent;color:var(--color-text-primary);border-color:var(--color-border-light)}.btn--secondary:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-2px)}.hero__visual{display:flex;justify-content:center;align-items:center;margin-top:var(--spacing-xl)}.terminal{background-color:var(--color-bg-secondary);border-radius:var(--radius-lg);overflow:hidden;width:100%;max-width:450px;box-shadow:var(--shadow-lg);border:1px solid var(--color-border)}.terminal__header{background-color:var(--color-bg-tertiary);padding:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-md);border-bottom:1px solid var(--color-border)}.terminal__buttons{display:flex;gap:var(--spacing-sm)}.terminal__button{width:12px;height:12px;border-radius:50%;display:block}.terminal__button--close{background-color:#ff5f57}.terminal__button--minimize{background-color:#ffbd2e}.terminal__button--maximize{background-color:#28ca42}.terminal__title{font-family:var(--font-mono);font-size:.875rem;color:var(--color-text-secondary);text-align:center;flex:1}.terminal__body{padding:var(--spacing-lg);font-family:var(--font-mono);font-size:.875rem;line-height:1.6}.terminal__line{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.terminal__prompt{color:var(--color-accent);font-weight:600}.terminal__command{color:var(--color-text-primary)}.terminal__output{color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);margin-left:var(--spacing-lg)}.terminal__output-colored{color:var(--color-text-green);margin-bottom:var(--spacing-sm);margin-left:var(--spacing-lg)}.terminal__cursor{color:var(--color-accent);animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.skills-preview{padding:var(--spacing-3xl) 0;background-color:var(--color-bg-secondary)}.skills-preview__content{text-align:center;max-width:800px;margin:0 auto}.skills-preview__title{font-size:2rem;margin-bottom:var(--spacing-xl);color:var(--color-text-primary)}.skills-preview__tags{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-md)}.skill-tag{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-lg);font-family:var(--font-mono);font-size:.875rem;font-weight:500;border:1px solid var(--color-border);transition:all var(--transition-normal)}.skill-tag:hover{border-color:var(--color-accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}@media (max-width: 768px){.hero__content{grid-template-columns:1fr;gap:var(--spacing-2xl);text-align:center}.hero__visual{margin-top:var(--spacing-2xl);margin-bottom:var(--spacing-3xl)}.hero__actions{justify-content:center;margin-bottom:var(--spacing-xl)}.skills-preview{padding-top:var(--spacing-4xl)}.btn{padding:var(--spacing-md) var(--spacing-lg)}.terminal{max-width:350px}.skills-preview__tags{gap:var(--spacing-sm)}.skill-tag{font-size:.75rem;padding:var(--spacing-xs) var(--spacing-md)}}@media (max-width: 480px){.hero__actions{flex-direction:column;align-items:center}.btn{width:100%;max-width:280px;justify-content:center}.terminal{max-width:320px}.hero__visual{margin-bottom:var(--spacing-4xl)}}.page-header{text-align:center;padding:var(--spacing-3xl) 0 var(--spacing-2xl)}.page-header__title{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;margin-bottom:var(--spacing-md);background:linear-gradient(135deg,var(--color-text-primary) 0%,var(--color-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-header__subtitle{font-size:clamp(1rem,3vw,1.25rem);color:var(--color-text-secondary);max-width:auto;line-height:1.6}@media (max-width: 768px){.page-header{margin-bottom:var(--spacing-2xl)}.page-header__title{margin-bottom:var(--spacing-sm)}}.timeline-page{padding-top:70px;min-height:100vh;background:linear-gradient(135deg,var(--color-bg-primary) 0%,var(--color-bg-secondary) 100%);overflow-x:hidden;width:100%}.timeline-container{position:relative;max-width:1000px;margin:0 auto;padding:var(--spacing-2xl) 0;overflow:visible;width:100%}.timeline-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent 0%,var(--color-accent) 10%,var(--color-accent) 90%,transparent 100%);transform:translate(-50%);z-index:1}.timeline-item{position:relative;margin-bottom:var(--spacing-3xl);display:flex;align-items:center;z-index:2}.timeline-item--left{justify-content:flex-end;padding-right:calc(50% + var(--spacing-xl))}.timeline-item--right{justify-content:flex-start;padding-left:calc(50% + var(--spacing-xl))}.timeline-content{position:relative;width:100%;max-width:450px}.timeline-node{position:absolute;top:50%;transform:translateY(-50%);width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--color-text-primary);box-shadow:0 0 20px #ff44444d;border:3px solid var(--color-bg-primary);z-index:3}.timeline-item--left .timeline-node{right:calc(-50% - var(--spacing-xl) - 30px)}.timeline-item--right .timeline-node{left:calc(-50% - var(--spacing-xl) - 30px)}.timeline-year{writing-mode:vertical-lr;text-orientation:mixed;font-size:.7rem;letter-spacing:1px}.timeline-card{background:#1a1a1acc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden}.timeline-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-accent),transparent);opacity:0;transition:opacity var(--transition-normal)}.timeline-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--color-accent)}.timeline-card:hover:before{opacity:1}.timeline-card.expanded{border-color:var(--color-accent)}.timeline-card.expanded:before{opacity:1}.timeline-card-header{margin-bottom:var(--spacing-md)}.timeline-card-meta{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);flex-wrap:wrap}.timeline-category{font-family:var(--font-mono);font-size:.75rem;font-weight:600;padding:var(--spacing-xs) var(--spacing-sm);background:#ff44441a;border-radius:var(--radius-sm);border:1px solid currentColor}.timeline-subtitle-text{font-size:.875rem;color:var(--color-text-muted);font-style:italic}.timeline-card-title{font-size:1.5rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--color-text-primary);line-height:1.3}.timeline-card-description{color:var(--color-text-secondary);line-height:1.6;margin:0}.timeline-card-details{overflow:hidden;border-top:1px solid var(--color-border);margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.timeline-details-content{padding:var(--spacing-sm) 0}.timeline-details-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.timeline-details-title:before{content:"▶";color:var(--color-accent);font-size:.75rem}.timeline-details-list{list-style:none;padding:0;margin:0}.timeline-details-list li{position:relative;padding-left:var(--spacing-lg);margin-bottom:var(--spacing-sm);color:var(--color-text-secondary);line-height:1.5}.timeline-details-list li:before{content:"•";position:absolute;left:0;color:var(--color-accent);font-weight:700}.timeline-expand-indicator{position:absolute;bottom:var(--spacing-md);right:var(--spacing-md);color:var(--color-text-muted);font-size:1.2rem;transition:color var(--transition-fast)}.timeline-card:hover .timeline-expand-indicator{color:var(--color-accent)}.expand-arrow{display:inline-block}.timeline-footer{text-align:center;padding:var(--spacing-3xl) 0}.timeline-footer-text{font-size:1.25rem;color:var(--color-text-secondary);font-family:var(--font-mono)}@media (max-width: 768px){.timeline-page{overflow-x:hidden;width:100vw;max-width:100%}.timeline-container{padding:var(--spacing-xl) var(--spacing-md);max-width:none;width:100%}.timeline-line{left:30px}.timeline-item--left,.timeline-item--right{justify-content:flex-start;padding-left:90px;padding-right:var(--spacing-md);width:100%;max-width:calc(100vw - var(--spacing-lg))}.timeline-item--left .timeline-node,.timeline-item--right .timeline-node{left:5px;right:auto;top:0}.timeline-content{max-width:none;position:relative;width:100%;max-width:calc(100vw - 120px)}.timeline-card{padding:var(--spacing-md);margin-left:0;margin-top:0;width:100%;max-width:100%;box-sizing:border-box}.timeline-card-title{font-size:1.25rem}.timeline-year{writing-mode:horizontal-tb;text-orientation:mixed}.timeline-node{width:50px;height:50px;font-size:.7rem;position:absolute;top:0;z-index:10}}@media (max-width: 480px){.timeline-page{padding:70px 0 0}.timeline-container{padding:var(--spacing-xl) var(--spacing-sm)}.timeline-header{padding:var(--spacing-2xl) 0 var(--spacing-xl)}.timeline-item{margin-bottom:var(--spacing-2xl);width:100%;max-width:calc(100vw - var(--spacing-md))}.timeline-card-meta{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.timeline-item--left,.timeline-item--right{padding-left:75px;padding-right:var(--spacing-sm);width:100%}.timeline-content{max-width:calc(100vw - 95px)}.timeline-node{width:45px;height:45px;font-size:.6rem;top:0}.timeline-item--left .timeline-node,.timeline-item--right .timeline-node{left:5px}.timeline-line{left:27px}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}.timeline-card.expanded+.timeline-node{animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 20px #ff44444d}50%{box-shadow:0 0 30px #f449}to{box-shadow:0 0 20px #ff44444d}}.project-card{display:flex;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-2xl);transition:all var(--transition-normal);min-height:300px;position:relative}.project-card--expanded .project-card__image-section{flex:0 0 0%;min-width:0;opacity:0;overflow:hidden}.project-card--expanded .project-card__content{flex:1}.project-card:hover{border-color:var(--color-border-light);box-shadow:var(--shadow-lg)}.project-card__image-section{flex:0 0 40%;position:relative;background:var(--color-bg-tertiary);min-height:300px;transition:all var(--transition-normal);opacity:1}.project-card__image-container{position:relative;width:100%;height:100%;overflow:hidden}.project-card__image{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform var(--transition-slow);cursor:pointer}.project-card:hover .project-card__image{transform:scale(1.03)}.project-card__nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:#000000b3;border:none;color:var(--color-text-primary);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);font-size:1.25rem;font-weight:700;z-index:2;opacity:0}.project-card__image-container:hover .project-card__nav-btn{opacity:1}.project-card__nav-btn:hover{background:#000000e6;transform:translateY(-50%) scale(1.1)}.project-card__nav-btn--prev{left:var(--spacing-sm)}.project-card__nav-btn--next{right:var(--spacing-sm)}.project-card__image-indicators{position:absolute;bottom:var(--spacing-sm);left:50%;transform:translate(-50%);display:flex;gap:var(--spacing-xs);z-index:2}.project-card__indicator{width:6px;height:6px;border-radius:50%;border:none;background:#ffffff80;cursor:pointer;transition:all var(--transition-fast)}.project-card__indicator.active{background:var(--color-text-primary);transform:scale(1.3)}.project-card__indicator:hover{background:#fffc}.project-card__content{flex:1;padding:var(--spacing-lg);display:flex;flex-direction:column;position:relative;padding-bottom:var(--spacing-3xl)}.project-card__header{flex-shrink:0;margin-bottom:var(--spacing-md)}.project-card__meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);flex-wrap:wrap}.project-card__category{font-family:var(--font-mono);font-size:.7rem;font-weight:600;color:var(--color-accent);background:#ff44441a;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em}.project-card__year{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-secondary)}.project-card__status{font-size:.8rem;font-weight:500;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);background:#0000004d}.project-card__title{font-size:1.35rem;font-weight:600;color:var(--color-text-primary);margin:0;line-height:1.3}.project-card__body{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md)}.project-card__description{color:var(--color-text-secondary);line-height:1.6;margin:0;font-size:.95rem}.project-card__expanded-content{margin-top:var(--spacing-md);overflow:hidden}.project-card__long-description{color:var(--color-text-secondary);line-height:1.6;margin:0 0 var(--spacing-lg) 0;font-size:.95rem;font-style:italic}.project-card__highlights{background:#0003;padding:var(--spacing-md);border-radius:var(--radius-md);border-left:3px solid var(--color-accent);margin-bottom:var(--spacing-md)}.project-card__highlights-title{font-size:.8rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0;text-transform:uppercase;letter-spacing:.05em}.project-card__highlights-list{margin:0;padding:0;list-style:none}.project-card__highlight{color:var(--color-text-secondary);font-size:.8rem;margin-bottom:var(--spacing-xs);position:relative;padding-left:var(--spacing-md)}.project-card__highlight:before{content:"→";position:absolute;left:0;color:var(--color-accent);font-weight:700}.project-card__technologies{margin-top:auto}.project-card__tech-title{font-size:.8rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0;text-transform:uppercase;letter-spacing:.05em}.project-card__tech-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.project-card__tech-tag{background:var(--color-bg-tertiary);color:var(--color-text-secondary);font-size:.7rem;font-family:var(--font-mono);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);border:1px solid var(--color-border);transition:all var(--transition-fast)}.project-card__tech-tag:hover{color:var(--color-text-primary);border-color:var(--color-border-light)}.project-card__actions{display:flex;gap:var(--spacing-sm);flex-shrink:0;margin-top:var(--spacing-md)}.project-card__btn{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);text-decoration:none;font-weight:500;font-size:.8rem;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;border:none;min-width:100px;justify-content:center}.project-card__btn--primary{background:var(--color-accent);color:#fff}.project-card__btn--primary:hover{background:var(--color-accent-hover);transform:translateY(-2px)}.project-card__btn--secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.project-card__btn--secondary:hover{color:var(--color-text-primary);border-color:var(--color-border-light);transform:translateY(-2px)}.project-card__expand-btn{position:absolute;bottom:var(--spacing-md);left:50%;transform:translate(-50%);background:transparent;border:none;color:var(--color-text-primary);font-size:.85rem;font-weight:500;cursor:pointer;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);transition:all var(--transition-fast);font-family:var(--font-primary)}.project-card__expand-btn:hover{background:var(--color-text-primary);color:var(--color-bg-primary);transform:translate(-50%) translateY(-2px)}@media (max-width: 1024px){.project-card{flex-direction:column;min-height:auto}.project-card__image-section{flex:none;height:220px}.project-card__content{padding:var(--spacing-md);padding-bottom:var(--spacing-3xl)}.project-card__title{font-size:1.2rem}.project-card__actions{margin-bottom:var(--spacing-lg)}.project-card__expand-btn{bottom:var(--spacing-md)}.project-card--expanded .project-card__image-section{display:none}}@media (max-width: 640px){.project-card__content{padding:var(--spacing-sm);padding-bottom:var(--spacing-3xl);gap:var(--spacing-sm)}.project-card__meta{gap:var(--spacing-xs)}.project-card__actions{flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.project-card__btn{text-align:center;width:100%}.project-card__highlights{padding:var(--spacing-sm)}.project-card__expand-btn{font-size:.9rem;padding:var(--spacing-md) var(--spacing-lg);min-height:44px;border-radius:var(--radius-lg);bottom:var(--spacing-md)}.project-card--expanded .project-card__image-section{display:none}}@media (max-width: 480px){.project-card__image-section{height:180px}.project-card__title{font-size:1.1rem}.project-card__content{padding-bottom:var(--spacing-4xl)}.project-card__actions{margin-bottom:var(--spacing-xl)}.project-card__expand-btn{font-size:.9rem;padding:var(--spacing-md) var(--spacing-lg);min-height:44px;bottom:var(--spacing-md)}.project-card--expanded .project-card__image-section{display:none}}.image-modal-overlay{position:fixed;inset:0;background:#000000e6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--spacing-lg)}.image-modal-content{position:relative;width:90vw;max-width:1000px;max-height:90vh;background:var(--color-bg-secondary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xl);border:1px solid var(--color-border);display:flex;flex-direction:column}.image-modal-close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:32px;height:32px;border:none;background:#000000b3;color:var(--color-text-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1001;font-size:1.2rem;transition:all var(--transition-fast)}.image-modal-close:hover{background:#000000e6;transform:scale(1.1)}.image-modal-image-container{position:relative;display:flex;align-items:center;justify-content:center;flex:1;min-height:300px;max-height:calc(90vh - 120px);background:var(--color-bg-tertiary)}.image-modal-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;object-position:center}.image-modal-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border:none;background:#000000b3;color:var(--color-text-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.5rem;font-weight:700;transition:all var(--transition-fast);z-index:1001}.image-modal-nav:hover{background:#000000e6;transform:translateY(-50%) scale(1.1)}.image-modal-nav--prev{left:var(--spacing-md)}.image-modal-nav--next{right:var(--spacing-md)}.image-modal-indicators{position:absolute;bottom:var(--spacing-md);left:50%;transform:translate(-50%);display:flex;gap:var(--spacing-sm);z-index:1001}.image-modal-indicator{width:8px;height:8px;border-radius:50%;border:none;background:#ffffff80;cursor:pointer;transition:all var(--transition-fast)}.image-modal-indicator.active{background:var(--color-accent);transform:scale(1.4)}.image-modal-indicator:hover{background:#fffc}.image-modal-info{padding:var(--spacing-md);background:var(--color-bg-secondary);border-top:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;min-height:60px}.image-modal-title{font-size:1.1rem;font-weight:600;color:var(--color-text-primary);margin:0}.image-modal-counter{font-family:var(--font-mono);font-size:.9rem;color:var(--color-text-secondary);margin:0}@media (max-width: 768px){.image-modal-overlay{padding:var(--spacing-md)}.image-modal-content{width:95vw;max-width:none;max-height:95vh}.image-modal-image-container{min-height:250px;max-height:calc(95vh - 100px)}.image-modal-nav{width:40px;height:40px;font-size:1.2rem}.image-modal-nav--prev{left:var(--spacing-sm)}.image-modal-nav--next{right:var(--spacing-sm)}.image-modal-info{padding:var(--spacing-sm);flex-direction:column;gap:var(--spacing-xs);text-align:center;min-height:50px}.image-modal-title{font-size:1rem}.image-modal-counter{font-size:.8rem}}@media (max-width: 480px){.image-modal-close{width:28px;height:28px;font-size:1rem}.image-modal-nav{width:36px;height:36px;font-size:1.1rem}.image-modal-indicators{bottom:var(--spacing-sm)}.image-modal-image-container{max-height:calc(95vh - 80px)}.image-modal-info{min-height:40px}}.projects-page{min-height:100vh;padding:var(--spacing-3xl) 0;background:var(--color-bg-primary)}.projects-header{text-align:center;padding:var(--spacing-3xl) 0 var(--spacing-2xl)}.projects-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;margin-bottom:var(--spacing-md);background:linear-gradient(135deg,var(--color-text-primary) 0%,var(--color-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.projects-title .text-accent{color:var(--color-accent)}.projects-title .font-mono{font-family:var(--font-mono)}.projects-subtitle{font-size:1.125rem;color:var(--color-text-secondary);max-width:600px;margin:0 auto;line-height:1.6}.projects-section{margin-bottom:var(--spacing-3xl)}.projects-section-title{font-size:2rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-2xl) 0;display:flex;align-items:center;gap:var(--spacing-sm)}.projects-section-title .text-accent{color:var(--color-accent)}.projects-section-title .font-mono{font-family:var(--font-mono)}.projects-grid{display:flex;flex-direction:column;gap:0}.projects-cta{margin-top:var(--spacing-3xl);padding:var(--spacing-3xl) 0;border-top:1px solid var(--color-border)}.projects-cta-content{text-align:center;max-width:600px;margin:0 auto}.projects-cta-title{font-size:2rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-lg) 0}.projects-cta-text{font-size:1.125rem;color:var(--color-text-secondary);margin:0 0 var(--spacing-2xl) 0;line-height:1.6}.projects-cta-actions{display:flex;gap:var(--spacing-lg);justify-content:center;flex-wrap:wrap}.projects-cta-btn{padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);text-decoration:none;font-weight:600;font-size:1rem;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;border:none;min-width:160px;justify-content:center}.projects-cta-btn--primary{background:var(--color-accent);color:#fff}.projects-cta-btn--primary:hover{background:var(--color-accent-hover);transform:translateY(-3px);box-shadow:var(--shadow-md)}.projects-cta-btn--secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.projects-cta-btn--secondary:hover{color:var(--color-text-primary);border-color:var(--color-border-light);transform:translateY(-3px);box-shadow:var(--shadow-sm)}@media (max-width: 768px){.projects-page{padding:var(--spacing-2xl) 0}.projects-header,.projects-section{margin-bottom:var(--spacing-2xl)}.projects-section-title{font-size:1.5rem;margin-bottom:var(--spacing-xl)}.projects-cta{margin-top:var(--spacing-2xl);padding:var(--spacing-2xl) 0}.projects-cta-title{font-size:1.5rem}.projects-cta-text{font-size:1rem}.projects-cta-actions{flex-direction:column;align-items:center;gap:var(--spacing-md)}.projects-cta-btn{width:100%;max-width:280px}}@media (max-width: 480px){.projects-subtitle{font-size:1rem}.projects-section-title{font-size:1.25rem}}.contact-page{padding-top:70px;min-height:calc(100vh - 70px);padding-bottom:var(--spacing-3xl)}.contact-header{text-align:center;padding:var(--spacing-3xl) 0 var(--spacing-2xl)}.contact-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;margin-bottom:var(--spacing-md);background:linear-gradient(135deg,var(--color-text-primary) 0%,var(--color-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.contact-subtitle{font-size:1.25rem;color:var(--color-text-secondary);max-width:600px;margin:0 auto;line-height:1.6}.contact-content{max-width:900px;margin:0 auto}.contact-intro{margin-bottom:var(--spacing-3xl)}.terminal-block{background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden;box-shadow:var(--shadow-lg)}.terminal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}.terminal-buttons{display:flex;gap:var(--spacing-xs)}.terminal-button{width:12px;height:12px;border-radius:50%}.terminal-button--close{background:#ff5f56}.terminal-button--minimize{background:#ffbd2e}.terminal-button--maximize{background:#27ca3f}.terminal-title{font-family:var(--font-mono);font-size:.875rem;color:var(--color-text-secondary)}.terminal-content{padding:var(--spacing-lg)}.terminal-line{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.terminal-prompt{color:var(--color-accent);font-weight:600}.terminal-command{color:var(--color-text-green);font-family:var(--font-mono)}.terminal-text{color:var(--color-text-primary)}.terminal-output{margin-left:var(--spacing-lg);color:var(--color-text-secondary);line-height:1.7}.terminal-output p{margin-bottom:var(--spacing-md)}.terminal-output p:last-child{margin-bottom:0}.contact-methods{margin-bottom:var(--spacing-3xl)}.contact-methods-title{font-size:1.75rem;font-weight:600;margin-bottom:var(--spacing-xl);text-align:center}.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.contact-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);transition:var(--transition-normal);cursor:default}.contact-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-md)}.contact-card-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.contact-icon{font-size:1.5rem}.contact-label{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0}.contact-value{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);line-height:1.5;font-size:1rem}.contact-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.contact-button{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);border:none;font-weight:500;font-size:.875rem;cursor:pointer;transition:var(--transition-fast);font-family:var(--font-primary)}.contact-button--primary{background:var(--color-accent);color:#fff}.contact-button--primary:hover{background:var(--color-accent-hover);transform:translateY(-1px)}.contact-button--secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.contact-button--secondary:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-border-light);transform:translateY(-1px)}.contact-footer{text-align:center;padding:var(--spacing-xl);background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.contact-footer .terminal-line{justify-content:center;margin-bottom:0}@media (max-width: 768px){.contact-page{padding-bottom:var(--spacing-xl)}.contact-title{font-size:clamp(2rem,8vw,2.5rem)}.contact-subtitle{font-size:1.125rem;padding:0 var(--spacing-md)}.contact-grid{grid-template-columns:1fr;gap:var(--spacing-lg);margin:0 var(--spacing-md)}.contact-card{padding:var(--spacing-lg)}.terminal-content{padding:var(--spacing-md)}.terminal-output{margin-left:var(--spacing-md)}.contact-actions{flex-direction:column}.contact-button{width:100%;text-align:center}}@media (max-width: 480px){.contact-header,.contact-methods{margin-bottom:var(--spacing-xl)}.terminal-header{padding:var(--spacing-xs) var(--spacing-md)}.terminal-title{font-size:.75rem}.contact-card-header{gap:var(--spacing-sm)}.contact-icon{font-size:1.25rem}.contact-label{font-size:1.125rem}}:root{--color-bg-primary: #0a0a0a;--color-bg-secondary: #1a1a1a;--color-bg-tertiary: #2a2a2a;--color-text-primary: #ffffff;--color-text-secondary: #a0a0a0;--color-text-muted: #666666;--color-text-green: #00ff00;--color-accent: #ff4444;--color-accent-hover: #ff6666;--color-accent-dark: #cc3333;--color-border: #333333;--color-border-light: #444444;--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", Consolas, "Monaco", monospace;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-4xl: 5rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .4);--z-background: 1;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal: 1040;--z-popover: 1050;--z-tooltip: 1060;--z-mobile-nav: 99999}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-primary);background-color:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;margin-bottom:var(--spacing-md);color:var(--color-text-primary)}h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:700}h2{font-size:clamp(1.5rem,4vw,2.5rem)}h3{font-size:clamp(1.25rem,3vw,1.75rem)}h4{font-size:clamp(1.1rem,2.5vw,1.25rem)}p{margin-bottom:var(--spacing-md);color:var(--color-text-secondary)}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}.text-accent{color:var(--color-accent)!important}code{font-family:var(--font-mono);background-color:var(--color-bg-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.875em}pre{font-family:var(--font-mono);background-color:var(--color-bg-secondary);padding:var(--spacing-md);border-radius:var(--radius-md);overflow-x:auto;border:1px solid var(--color-border)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md);width:100%;box-sizing:border-box}.section{padding:var(--spacing-3xl) 0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-mono)}.invisible-text{color:transparent;-webkit-user-select:none;user-select:none}.invisible-selectable-text{color:transparent;-webkit-user-select:text;user-select:text}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}*:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}::selection{background-color:var(--color-accent);color:var(--color-text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.animate-fade-in{animation:fadeIn .6s ease-out}.animate-slide-in-left{animation:slideInLeft .6s ease-out}.animate-slide-in-right{animation:slideInRight .6s ease-out}@media (max-width: 768px){.container{padding:0 var(--spacing-sm);max-width:100vw;overflow-x:hidden}.section{padding:var(--spacing-2xl) 0}}
