:root,[data-theme=light]{--bg-primary:#f8f9fc;--bg-secondary:#fff;--bg-card:#fff;--bg-nav:#ffffffd9;--text-primary:#1a1a2e;--text-secondary:#4a4a6a;--text-muted:#8888a0;--border-color:#e2e4ea;--accent:#6c5ce7;--accent-light:#6c5ce71f;--accent-hover:#5a4bd1;--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 4px 20px #00000014;--shadow-lg:0 8px 40px #0000001f;--shadow-card:0 4px 24px #00000012;--success:#00b894;--error:#e74c3c;--warning:#fdcb6e;--code-bg:#f0f0f5;--gradient-hero:linear-gradient(135deg, #667eea 0%, #764ba2 100%);--skeleton-base:#e8e8ee;--skeleton-shine:#f5f5fa}[data-theme=dark]{--bg-primary:#0f0f1a;--bg-secondary:#1a1a2e;--bg-card:#1e1e35;--bg-nav:#0f0f1aeb;--text-primary:#e8e8f0;--text-secondary:#a0a0bc;--text-muted:#6a6a88;--border-color:#2a2a45;--accent:#a29bfe;--accent-light:#a29bfe26;--accent-hover:#b8b2ff;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--shadow-card:0 4px 24px #00000059;--success:#55efc4;--error:#ff7675;--warning:#ffeaa7;--code-bg:#12121f;--gradient-hero:linear-gradient(135deg, #4a3f8a 0%, #2d1b69 100%);--skeleton-base:#2a2a45;--skeleton-shine:#36365a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{color:var(--text-primary);background-color:var(--bg-primary);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.6;transition:background-color .3s,color .3s}#root{flex-direction:column;min-height:100vh;display:flex}h1,h2,h3,h4{color:var(--text-primary);font-weight:700;line-height:1.2}a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.section{max-width:1200px;margin:0 auto;padding:5rem 1.25rem}@media (width>=768px){.section{padding:6rem 2rem}}.section__header{text-align:center;margin-bottom:3rem}.section__title{margin-bottom:.5rem;font-size:2rem}@media (width>=768px){.section__title{font-size:2.5rem}}.section__title-accent{color:var(--accent);font-family:Fira Code,monospace;font-size:.85em}.section__subtitle{color:var(--text-secondary);max-width:500px;margin:0 auto;font-size:1.1rem}.navbar{z-index:1000;background:var(--bg-nav);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid #0000;transition:border-color .3s,box-shadow .3s;position:fixed;top:0;left:0;right:0}.navbar--scrolled{border-bottom-color:var(--border-color);box-shadow:var(--shadow-sm)}.navbar__inner{justify-content:space-between;align-items:center;max-width:1200px;height:64px;margin:0 auto;padding:0 1.25rem;display:flex}.navbar__logo{color:var(--text-primary);align-items:center;gap:.4rem;font-size:1.25rem;font-weight:700;text-decoration:none;display:flex}.navbar__logo-icon{color:var(--accent);font-size:1.4rem}.navbar__links{gap:.25rem;display:none}@media (width>=768px){.navbar__links{display:flex}}.navbar__link{color:var(--text-secondary);border-radius:8px;padding:.5rem .85rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s}.navbar__link:hover{color:var(--accent);background:var(--accent-light)}.navbar__theme-btn{background:var(--accent-light);border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;transition:all .2s;display:flex}.navbar__theme-btn:hover{background:var(--accent);transform:rotate(15deg)}.navbar__hamburger{flex-direction:column;gap:5px;padding:8px;display:flex}@media (width>=768px){.navbar__hamburger{display:none}}.navbar__hamburger-line{background:var(--text-primary);border-radius:2px;width:22px;height:2px;transition:all .3s}.navbar__hamburger-line.open:first-child{transform:rotate(45deg)translate(5px,5px)}.navbar__hamburger-line.open:nth-child(2){opacity:0}.navbar__hamburger-line.open:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}.navbar__mobile-menu{background:var(--bg-secondary);border-top:1px solid var(--border-color);overflow:hidden}.navbar__mobile-link{color:var(--text-secondary);border-bottom:1px solid var(--border-color);padding:.85rem 1.5rem;font-weight:500;text-decoration:none;display:block}.navbar__mobile-link:hover{color:var(--accent);background:var(--accent-light)}.navbar__theme-btn--mobile{background:var(--accent-light);width:calc(100% - 3rem);color:var(--text-primary);border-radius:10px;margin:1rem 1.5rem;padding:.75rem;font-size:1rem}.hero{text-align:center;background:var(--gradient-hero);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:6rem 1.25rem 3rem;display:flex;position:relative;overflow:hidden}.hero__particles{pointer-events:none;position:absolute;inset:0}.hero__particle{background:#fff3;border-radius:50%;position:absolute}.hero__content{z-index:1;max-width:700px;position:relative}.hero__greeting{color:#ffffffd9;margin-bottom:.5rem;font-size:1.1rem}.hero__name{color:#fff;letter-spacing:-1px;margin-bottom:.75rem;font-size:3rem;font-weight:800}@media (width>=768px){.hero__name{font-size:4.5rem}}.hero__title-wrapper{margin-bottom:1.25rem}.hero__title{color:#ffffffe6;border:1px solid #ffffff4d;border-radius:30px;padding:.4rem 1.2rem;font-size:1rem;display:inline-block}@media (width>=768px){.hero__title{font-size:1.15rem}}.hero__subtitle{color:#ffffffbf;max-width:500px;margin-bottom:2rem;margin-left:auto;margin-right:auto;font-size:1.05rem}.hero__actions{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.hero__btn{border-radius:12px;padding:.8rem 2rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .3s}.hero__btn--primary{color:#6c5ce7;background:#fff;box-shadow:0 4px 15px #0003}.hero__btn--primary:hover{color:#5a4bd1;transform:translateY(-2px);box-shadow:0 6px 25px #0000004d}.hero__btn--outline{color:#fff;border:2px solid #ffffff80}.hero__btn--outline:hover{color:#fff;background:#ffffff26;border-color:#fff}.hero__scroll-indicator{color:#ffffff80;position:absolute;bottom:2rem}.projects__grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (width>=540px){.projects__grid{grid-template-columns:repeat(2,1fr)}}@media (width>=900px){.projects__grid{grid-template-columns:repeat(3,1fr)}}.project-card-wrapper{perspective:1000px}.project-card{height:360px;transform-style:preserve-3d;cursor:pointer;border-radius:16px;transition:transform .7s cubic-bezier(.4,0,.2,1);position:relative}.project-card--flipped{transform:rotateY(180deg)}.project-card__face{backface-visibility:hidden;border-radius:16px;position:absolute;inset:0;overflow:hidden}.project-card__front{background:var(--bg-card);box-shadow:var(--shadow-card);flex-direction:column;display:flex}.project-card__image-wrapper{height:55%;position:relative;overflow:hidden}.project-card__image-wrapper img{object-fit:cover;width:100%;height:100%;transition:transform .5s}.project-card:hover .project-card__image-wrapper img{transform:scale(1.05)}.project-card__image-overlay{background:linear-gradient(#0000 50%,#0006 100%);position:absolute;inset:0}.project-card__content{flex-direction:column;flex:1;justify-content:center;padding:1rem 1.25rem;display:flex}.project-card__title{margin-bottom:.5rem;font-size:1.1rem;font-weight:700}.project-card__tags{flex-wrap:wrap;gap:.35rem;display:flex}.project-card__tag{background:var(--accent-light);color:var(--accent);letter-spacing:.02em;border-radius:6px;padding:.2rem .55rem;font-size:.72rem;font-weight:600}.project-card__hint{color:var(--text-muted);border-top:1px solid var(--border-color);align-items:center;gap:.3rem;padding:.6rem 1.25rem;font-size:.75rem;display:flex}.project-card__back{background:var(--accent);justify-content:center;align-items:center;padding:1.5rem;display:flex;transform:rotateY(180deg)}.project-card__back-content{text-align:center;color:#fff}.project-card__back-title{color:#fff;margin-bottom:.75rem;font-size:1.2rem}.project-card__description{color:#ffffffe6;margin-bottom:1rem;font-size:.92rem;line-height:1.6}.project-card__back-tags{flex-wrap:wrap;justify-content:center;gap:.35rem;margin-bottom:1.25rem;display:flex}.project-card__back .project-card__tag{color:#fff;background:#fff3}.project-card__link{background:#fff3;border-radius:10px;align-items:center;gap:.4rem;padding:.55rem 1.5rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-flex;color:#fff!important}.project-card__link:hover{background:#ffffff59;color:#fff!important}.timeline__track{padding:2rem 0;position:relative}.timeline__track:before{content:"";background:linear-gradient(to bottom, var(--accent), var(--border-color));border-radius:1px;width:2px;position:absolute;top:0;bottom:0;left:20px}@media (width>=768px){.timeline__track:before{left:50%;transform:translate(-50%)}}.timeline__item{margin-bottom:2.5rem;padding-left:50px;position:relative}@media (width>=768px){.timeline__item{width:50%;padding-left:0;padding-right:2.5rem}.timeline__item--right{margin-left:50%;padding-left:2.5rem;padding-right:0}}.timeline__dot{background:var(--bg-primary);border:2px solid var(--accent);z-index:1;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;display:flex;position:absolute;top:0;left:14px}@media (width>=768px){.timeline__item--left .timeline__dot{left:auto;right:-7px}.timeline__item--right .timeline__dot{left:-7px}}.timeline__dot-inner{background:var(--accent);border-radius:50%;width:6px;height:6px}.timeline__card{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:14px;padding:1.5rem;transition:border-color .3s,box-shadow .3s}.timeline__card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.timeline__year{background:var(--accent-light);color:var(--accent);border-radius:6px;margin-bottom:.75rem;padding:.2rem .75rem;font-size:.8rem;font-weight:700;display:inline-block}.timeline__title{margin-bottom:.25rem;font-size:1.15rem}.timeline__company{color:var(--accent);margin-bottom:.6rem;font-size:.95rem;font-weight:600}.timeline__description{color:var(--text-secondary);margin-bottom:.85rem;font-size:.9rem;line-height:1.6}.timeline__techs{flex-wrap:wrap;gap:.35rem;display:flex}.timeline__tech{background:var(--accent-light);color:var(--accent);border-radius:6px;padding:.2rem .55rem;font-size:.72rem;font-weight:600}.blog__grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (width>=540px){.blog__grid{grid-template-columns:repeat(2,1fr)}}@media (width>=900px){.blog__grid{grid-template-columns:repeat(3,1fr)}}.blog__card{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;border-radius:14px;padding:1.5rem;transition:border-color .3s,box-shadow .3s}.blog__card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.blog__card-tags{flex-wrap:wrap;gap:.35rem;margin-bottom:.75rem;display:flex}.blog__tag{background:var(--accent-light);color:var(--accent);text-transform:uppercase;letter-spacing:.04em;border-radius:6px;padding:.2rem .55rem;font-size:.7rem;font-weight:600}.blog__card-title{margin-bottom:.5rem;font-size:1.1rem;line-height:1.35}.blog__card-summary{color:var(--text-secondary);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:.85rem;font-size:.88rem;line-height:1.55;display:-webkit-box;overflow:hidden}.blog__card-meta{color:var(--text-muted);justify-content:space-between;font-size:.8rem;display:flex}.blog__detail{max-width:760px;margin:0 auto}.blog__back-btn{background:var(--accent-light);color:var(--accent);border-radius:10px;align-items:center;gap:.4rem;margin-bottom:1.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:background .2s;display:inline-flex}.blog__back-btn:hover{background:var(--accent);color:#fff}.blog__article-header{margin-bottom:2rem}.blog__article-title{margin-bottom:.5rem;font-size:2rem}@media (width>=768px){.blog__article-title{font-size:2.5rem}}.blog__article-meta{color:var(--text-muted);gap:1rem;font-size:.9rem;display:flex}.markdown-body{color:var(--text-secondary);font-size:1rem;line-height:1.75}.markdown-body h2{border-bottom:1px solid var(--border-color);margin:2rem 0 .75rem;padding-bottom:.3rem;font-size:1.5rem}.markdown-body h3{margin:1.5rem 0 .5rem;font-size:1.2rem}.markdown-body p{margin-bottom:1rem}.markdown-body ul,.markdown-body ol{margin-bottom:1rem;padding-left:1.75rem}.markdown-body li{margin-bottom:.35rem}.markdown-body strong{color:var(--text-primary)}.markdown-body blockquote{border-left:3px solid var(--accent);background:var(--accent-light);color:var(--text-secondary);border-radius:0 8px 8px 0;margin-bottom:1rem;padding:.75rem 1rem}.markdown-body code{background:var(--code-bg);color:var(--accent);border-radius:4px;padding:.15rem .4rem;font-family:Fira Code,monospace;font-size:.88em}.markdown-body pre{background:var(--code-bg);border:1px solid var(--border-color);border-radius:10px;margin-bottom:1rem;padding:1rem;overflow-x:auto}.markdown-body pre code{color:var(--text-primary);background:0 0;padding:0}.markdown-body table{border-collapse:collapse;width:100%;margin-bottom:1rem}.markdown-body th,.markdown-body td{border:1px solid var(--border-color);text-align:left;padding:.6rem .85rem}.markdown-body th{background:var(--accent-light);font-weight:600}.markdown-body hr{border:none;border-top:1px solid var(--border-color);margin:1.5rem 0}.blog__error{text-align:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;padding:3rem 1rem}.blog__error-icon{color:var(--error);margin-bottom:1rem}.blog__error h3{margin-bottom:.5rem}.blog__error p{color:var(--text-secondary);margin-bottom:1.25rem}.blog__retry-btn{background:var(--accent);color:#fff;border-radius:10px;padding:.6rem 2rem;font-size:.95rem;font-weight:600;transition:background .2s}.blog__retry-btn:hover{background:var(--accent-hover)}.skeleton__card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;padding:1.5rem;overflow:hidden}.skeleton__line{background:linear-gradient(90deg, var(--skeleton-base) 25%, var(--skeleton-shine) 50%, var(--skeleton-base) 75%);background-size:200% 100%;border-radius:6px;margin-bottom:.75rem;animation:1.5s ease-in-out infinite skeleton-shimmer}.skeleton__line--tag{width:30%;height:22px}.skeleton__line--title{width:85%;height:24px}.skeleton__line--text{width:100%;height:16px}.skeleton__line--short{width:65%}.skeleton__line--meta{width:45%;height:14px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.contact__wrapper{max-width:600px;margin:0 auto}.contact__form{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (width>=540px){.contact__form{grid-template-columns:1fr 1fr}.contact__field--full,.contact__submit{grid-column:1/-1}}.contact__field{flex-direction:column;display:flex}.contact__label{color:var(--text-primary);margin-bottom:.4rem;font-size:.88rem;font-weight:600}.contact__input,.contact__textarea{border:2px solid var(--border-color);color:var(--text-primary);background:var(--bg-card);resize:vertical;border-radius:10px;padding:.75rem 1rem;font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.contact__input:focus,.contact__textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.contact__field--error .contact__input,.contact__field--error .contact__textarea{border-color:var(--error)}.contact__error{color:var(--error);align-items:center;gap:.25rem;margin-top:.35rem;font-size:.8rem;display:flex}.contact__form-error{color:var(--error);background:#e74c3c1a;border:1px solid #e74c3c4d;border-radius:10px;grid-column:1/-1;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500;display:flex}.contact__submit{background:var(--accent);color:#fff;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;margin-top:.5rem;padding:.85rem 2rem;font-size:1rem;font-weight:700;transition:background .2s,transform .2s;display:flex}.contact__submit:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.contact__submit:disabled{opacity:.7;cursor:not-allowed}.contact__spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.contact__success{text-align:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;padding:3rem 1rem}.contact__success-icon{background:var(--success);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 1.25rem;font-size:2rem;display:flex}.contact__success h3{margin-bottom:.5rem;font-size:1.4rem}.contact__success p{color:var(--text-secondary);margin-bottom:1.5rem}.contact__reset-btn{background:var(--accent);color:#fff;border-radius:10px;padding:.6rem 2rem;font-weight:600;transition:background .2s}.contact__reset-btn:hover{background:var(--accent-hover)}.footer{border-top:1px solid var(--border-color);background:var(--bg-secondary);padding:2rem 1.25rem}.footer__inner{text-align:center;flex-direction:column;align-items:center;gap:1rem;max-width:1200px;margin:0 auto;display:flex}@media (width>=768px){.footer__inner{flex-direction:row;justify-content:space-between}}.footer__text{color:var(--text-muted);font-size:.88rem}.footer__links{gap:1.25rem;display:flex}.footer__link{color:var(--text-secondary);font-size:.88rem;font-weight:500;text-decoration:none;transition:color .2s}.footer__link:hover{color:var(--accent)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.project-card{transition:none}html{scroll-behavior:auto}}
