.btn{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-family:var(--font-sans);font-size:var(--text-sm);border-radius:var(--radius-md);transition:all var(--transition-base);cursor:pointer;white-space:nowrap;border:none;font-weight:500;text-decoration:none;display:inline-flex}.btn-primary{background:var(--accent);color:var(--bg-primary)}.btn-primary:hover{background:var(--accent-dim);box-shadow:var(--shadow-glow);color:var(--bg-primary);transform:translateY(-1px)}.btn-secondary{color:var(--accent);border:1px solid var(--accent);background:0 0}.btn-secondary:hover{background:var(--accent-glow);box-shadow:var(--shadow-glow);color:var(--accent);transform:translateY(-1px)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--bg-tertiary);border-color:var(--border-hover);color:var(--text-primary)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base)}.btn-icon{font-size:1.1em;display:flex}.lang-switch{background:var(--bg-tertiary);border-radius:var(--radius-full);border:1px solid var(--border);align-items:center;padding:2px;display:flex}.lang-switch__btn{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);font-weight:500;font-family:var(--font-sans);background:0 0;border:none}.lang-switch__btn:hover{color:var(--text-primary)}.lang-switch__btn--active{background:var(--accent);color:var(--bg-primary)}.lang-switch__btn--active:hover{color:var(--bg-primary)}.header{z-index:1000;height:var(--header-height);transition:all var(--transition-base);background:0 0;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.header--scrolled{-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);background:#0d0d12d9}.header__inner{width:100%;max-width:var(--max-width);padding:0 var(--space-6);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.header__logo{font-size:var(--text-base);color:var(--text-primary);white-space:nowrap;font-weight:600;text-decoration:none}.header__logo span{color:var(--accent)}.header__nav{align-items:center;gap:var(--space-8);display:flex}.header__links{align-items:center;gap:var(--space-6);display:flex}.header__link{font-size:var(--text-sm);color:var(--text-secondary);transition:color var(--transition-fast);font-weight:400;text-decoration:none;position:relative}.header__link:after{content:"";background:var(--accent);width:0;height:2px;transition:width var(--transition-base);border-radius:1px;position:absolute;bottom:-4px;left:0}.header__link:hover{color:var(--text-primary)}.header__link:hover:after{width:100%}.header__actions{align-items:center;gap:var(--space-4);display:flex}.header__mobile-toggle{padding:var(--space-2);cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;display:none}.header__mobile-toggle span{background:var(--text-primary);width:22px;height:2px;transition:all var(--transition-base);border-radius:2px;display:block}.header__mobile-toggle--open span:first-child{transform:rotate(45deg)translate(5px,5px)}.header__mobile-toggle--open span:nth-child(2){opacity:0}.header__mobile-toggle--open span:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}.header__mobile-nav{top:var(--header-height);-webkit-backdrop-filter:blur(20px);justify-content:center;align-items:center;gap:var(--space-8);z-index:999;background:#0d0d12f2;flex-direction:column;display:none;position:fixed;bottom:0;left:0;right:0}.header__mobile-nav--open{display:flex}.header__mobile-nav .header__link{font-size:var(--text-xl)}@media (width<=768px){.header__links,.header__actions .btn{display:none}.header__mobile-toggle{display:flex}.header__actions{gap:var(--space-3)}}.footer{padding:var(--space-12) 0;border-top:1px solid var(--border);background:var(--bg-secondary)}.footer__inner{justify-content:space-between;align-items:center;gap:var(--space-6);flex-wrap:wrap;display:flex}.footer__text{font-size:var(--text-sm);color:var(--text-muted)}.footer__text span{color:var(--accent)}.footer__links{align-items:center;gap:var(--space-5);display:flex}.footer__link{color:var(--text-muted);transition:all var(--transition-fast);align-items:center;font-size:1.25rem;display:flex}.footer__link:hover{color:var(--accent);transform:translateY(-2px)}@media (width<=640px){.footer__inner{text-align:center;flex-direction:column}}.particles-container{z-index:0;width:100%;height:100%;position:absolute;top:0;left:0}.hero{min-height:100vh;padding-top:var(--header-height);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.hero__content{z-index:1;text-align:center;max-width:800px;padding:var(--space-8);animation:.8s forwards fadeInUp;position:relative}.hero__badge{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--accent-glow);border-radius:var(--radius-full);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent);margin-bottom:var(--space-8);letter-spacing:.05em;border:1px solid #00e5a033;display:inline-flex}.hero__badge-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}.hero__title{font-size:var(--text-5xl);margin-bottom:var(--space-6);color:var(--text-primary);font-weight:700;line-height:1.1}.hero__title-gradient{background:linear-gradient(135deg, var(--accent) 0%, #00b4d8 50%, var(--accent) 100%);-webkit-text-fill-color:transparent;background-size:200%;-webkit-background-clip:text;background-clip:text;animation:4s infinite gradientShift}.hero__typewriter{font-family:var(--font-mono);font-size:var(--text-xl);color:var(--accent);margin-bottom:var(--space-4);min-height:1.8em;display:block}.hero__typewriter-cursor{background:var(--accent);vertical-align:text-bottom;width:2px;height:1.1em;margin-left:2px;animation:1s step-end infinite blink;display:inline-block}.hero__subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-10);max-width:640px;margin-left:auto;margin-right:auto;line-height:1.7}.hero__cta{justify-content:center;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.hero__scroll{bottom:var(--space-8);z-index:1;align-items:center;gap:var(--space-2);color:var(--text-muted);font-size:var(--text-xs);cursor:pointer;flex-direction:column;text-decoration:none;animation:3s ease-in-out infinite float;display:flex;position:absolute;left:50%;transform:translate(-50%)}.hero__scroll-line{background:linear-gradient(to bottom, var(--text-muted), transparent);width:1px;height:32px}@media (width<=640px){.hero__content{padding:var(--space-4)}.hero__cta{flex-direction:column;width:100%}.hero__cta .btn{justify-content:center;width:100%}.hero__scroll{display:none}}.section-heading{text-align:center;margin-bottom:var(--space-16)}.section-heading__label{align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent);margin-bottom:var(--space-4);letter-spacing:.05em;display:inline-flex}.section-heading__label:before{content:"//";opacity:.5}.section-heading__title{font-size:var(--text-3xl);color:var(--text-primary);margin-bottom:var(--space-4);font-weight:700}.section-heading__subtitle{font-size:var(--text-lg);color:var(--text-secondary);max-width:600px;margin:0 auto;line-height:1.7}.tag{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-full);background:var(--accent-glow);color:var(--accent);transition:all var(--transition-fast);white-space:nowrap;border:1px solid #00e5a033;align-items:center;font-weight:500;display:inline-flex}.tag:hover{background:var(--accent-glow-strong);border-color:#00e5a066}.tag-neutral{background:var(--bg-tertiary);color:var(--text-secondary);border-color:var(--border)}.tag-neutral:hover{background:var(--border);color:var(--text-primary)}.project-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition-base);cursor:pointer;flex-direction:column;display:flex;overflow:hidden}.project-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg), var(--shadow-glow);transform:translateY(-4px)}.project-card__image{background:var(--bg-tertiary);justify-content:center;align-items:center;width:100%;height:200px;display:flex;position:relative;overflow:hidden}.project-card__img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-base)}.project-card:hover .project-card__img{transform:scale(1.05)}.project-card__image-placeholder{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-muted);align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.project-card__image-icon{color:var(--accent);opacity:.5;font-size:2rem}.project-card__body{padding:var(--space-6);flex-direction:column;flex:1;display:flex}.project-card__title{font-size:var(--text-lg);color:var(--text-primary);margin-bottom:var(--space-3);font-weight:600}.project-card__description{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;line-height:1.6;display:-webkit-box;overflow:hidden}.project-card__tags{gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.project-card__footer{justify-content:flex-end;align-items:center;display:flex}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(8px);padding:var(--space-6);background:#000000b3;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:800px;max-height:85vh;animation:.3s fadeInUp;overflow-y:auto}.modal::-webkit-scrollbar{width:6px}.modal::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}.modal__header{padding:var(--space-8);border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;display:flex}.modal__title{font-size:var(--text-2xl);color:var(--text-primary);font-weight:700}.modal__close{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);padding:var(--space-2);cursor:pointer;transition:all var(--transition-fast);font-size:1.25rem;display:flex}.modal__close:hover{background:var(--border);color:var(--text-primary)}.modal__tags{gap:var(--space-2);padding:var(--space-6) var(--space-8) 0;flex-wrap:wrap;display:flex}.modal__body{padding:var(--space-8)}.modal__section{margin-bottom:var(--space-8)}.modal__section:last-child{margin-bottom:0}.modal__section-title{font-size:var(--text-base);color:var(--accent);margin-bottom:var(--space-3);font-weight:600;font-family:var(--font-mono)}.modal__section-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.8}.modal__code{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.modal__code-header{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);background:var(--bg-tertiary);display:flex}.modal__code-dot{border-radius:50%;width:8px;height:8px}.modal__code-dot--red{background:#ff5f57}.modal__code-dot--yellow{background:#ffbd2e}.modal__code-dot--green{background:#28c840}.modal__code pre{margin:0;overflow-x:auto;padding:var(--space-4)!important;background:var(--bg-primary)!important;font-size:var(--text-xs)!important;line-height:1.6!important}.modal__actions{gap:var(--space-3);padding:0 var(--space-8) var(--space-8);display:flex}@media (width<=640px){.modal-overlay{padding:var(--space-3);align-items:flex-end}.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:90vh}.modal__header,.modal__body,.modal__actions,.modal__tags{padding-left:var(--space-5);padding-right:var(--space-5)}}.modal__image-container{border-radius:var(--radius-md);border:1px solid var(--border);cursor:zoom-in;width:100%;transition:border-color var(--transition-base);overflow:hidden}.modal__image-container:hover{border-color:var(--border-hover)}.modal__image{width:100%;height:auto;display:block}.modal__image-zoomed-overlay{z-index:3000;-webkit-backdrop-filter:blur(4px);cursor:zoom-out;padding:var(--space-8);background:#000000e6;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal__image-zoomed{object-fit:contain;border-radius:var(--radius-md);max-width:100%;max-height:100%;box-shadow:var(--shadow-lg);animation:.3s cubic-bezier(.16,1,.3,1) scaleIn}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.projects{padding:var(--space-24) 0}.projects__filters{justify-content:center;align-items:center;gap:var(--space-3);margin-bottom:var(--space-12);flex-wrap:wrap;display:flex}.projects__filter-btn{padding:var(--space-2) var(--space-5);font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast)}.projects__filter-btn:hover{border-color:var(--border-hover);color:var(--text-primary)}.projects__filter-btn--active{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.projects__filter-btn--active:hover{background:var(--accent-dim);color:var(--bg-primary)}.projects__grid{gap:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=1024px){.projects__grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.projects__grid{grid-template-columns:1fr}}.about{padding:var(--space-24) 0}.about__grid{gap:var(--space-12);grid-template-columns:1fr 1fr;align-items:start;display:grid}.about__bio{font-size:var(--text-base);color:var(--text-secondary);white-space:pre-line;line-height:1.8}.about__skills{gap:var(--space-6);flex-direction:column;display:flex}.about__skills-title{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent);letter-spacing:.05em;margin-bottom:var(--space-2)}.skill-category{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}.skill-category:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.skill-category__title{font-size:var(--text-base);color:var(--text-primary);margin-bottom:var(--space-3);font-weight:600}.skill-category__tags{gap:var(--space-2);flex-wrap:wrap;display:flex}@media (width<=768px){.about__grid{gap:var(--space-10);grid-template-columns:1fr}}.contact-section{padding:var(--space-24) 0;background:var(--bg-secondary)}.contact-terminal{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:700px;box-shadow:var(--shadow-lg);margin:0 auto;overflow:hidden}.contact-terminal__bar{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--bg-tertiary);border-bottom:1px solid var(--border);display:flex}.contact-terminal__dot{border-radius:50%;width:10px;height:10px}.contact-terminal__dot--red{background:#ff5f57}.contact-terminal__dot--yellow{background:#ffbd2e}.contact-terminal__dot--green{background:#28c840}.contact-terminal__title{text-align:center;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);flex:1}.contact-terminal__body{padding:var(--space-6);font-family:var(--font-mono);font-size:var(--text-sm);min-height:320px}.contact-terminal__line{margin-bottom:var(--space-3);color:var(--text-muted);line-height:1.6}.contact-terminal__line--accent,.contact-terminal__prompt{color:var(--accent)}.contact-terminal__input-row{align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.contact-terminal__label{color:var(--accent);white-space:nowrap}.contact-terminal__input{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);caret-color:var(--accent);background:0 0;border:none;outline:none;flex:1}.contact-terminal__input::placeholder{color:var(--text-muted)}.contact-terminal__textarea-row{margin-bottom:var(--space-4)}.contact-terminal__textarea-row .contact-terminal__label{margin-bottom:var(--space-2);display:block}.contact-terminal__textarea{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;min-height:80px;padding:var(--space-3);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);caret-color:var(--accent);resize:vertical;transition:border-color var(--transition-fast);background:#1c1c2780;outline:none}.contact-terminal__textarea:focus{border-color:var(--accent)}.contact-terminal__textarea::placeholder{color:var(--text-muted)}.contact-terminal__submit{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);background:var(--accent);color:var(--bg-primary);font-family:var(--font-mono);font-size:var(--text-sm);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:600;display:inline-flex}.contact-terminal__submit:hover{background:var(--accent-dim);box-shadow:var(--shadow-glow)}.contact-terminal__submit:disabled{opacity:.5;cursor:not-allowed}.contact-terminal__result{margin-top:var(--space-4);padding:var(--space-3);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-sm);animation:.3s fadeIn}.contact-terminal__result--success{color:var(--accent);background:#00e5a014;border:1px solid #00e5a033}.contact-terminal__result--error{color:var(--error);background:#ff4d6a14;border:1px solid #ff4d6a33}.app{flex-direction:column;min-height:100vh;display:flex}.app__loading{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.app__loading-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}:root{--bg-primary:#0d0d12;--bg-secondary:#14141b;--bg-tertiary:#1c1c27;--bg-glass:#14141bb3;--text-primary:#e8e8ed;--text-secondary:#9898a6;--text-muted:#5c5c6e;--accent:#00e5a0;--accent-dim:#00b87d;--accent-glow:#00e5a01f;--accent-glow-strong:#00e5a040;--border:#2a2a38;--border-hover:#3a3a4f;--success:#00e5a0;--error:#ff4d6a;--warning:#ffb84d;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Consolas", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--text-4xl:2.5rem;--text-5xl:3.5rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--max-width:1200px;--header-height:72px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 2px 8px #0003;--shadow-md:0 4px 16px #0000004d;--shadow-lg:0 8px 32px #0006;--shadow-glow:0 0 20px #00e5a026;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:var(--header-height);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background-color:var(--bg-primary);line-height:1.6;overflow-x:hidden}a{color:var(--accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-dim)}img{max-width:100%;height:auto;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}ul,ol{list-style:none}code,pre{font-family:var(--font-mono)}::selection{background:var(--accent);color:var(--bg-primary)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.container{width:100%;max-width:var(--max-width);padding:0 var(--space-6);margin:0 auto}.section{padding:var(--space-24) 0}.section-alt{padding:var(--space-24) 0;background:var(--bg-secondary)}.glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.reveal{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(30px)}.reveal.revealed{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@media (width<=1024px){:root{--text-5xl:2.5rem;--text-4xl:2rem;--text-3xl:1.75rem}}@media (width<=640px){:root{--text-5xl:2rem;--text-4xl:1.75rem;--text-3xl:1.5rem;--space-24:4rem;--space-20:3.5rem;--space-16:3rem}.container{padding:0 var(--space-4)}}
