@import "https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=IBM+Plex+Mono:wght@300;400;500;600&display=swap";:root{color:#1e293b;--text-main:#1f2937;--text-muted:#64748b;--title-color:#0b1220;--accent:#3478d6;--border:#d9e0ea;--card:#fff;--hero-bg:#0c1428;--soft-bg:#f7f9fc;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f7f9fc;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-weight:400;line-height:1.6}*{box-sizing:border-box}body{background:var(--soft-bg);min-width:320px;color:var(--text-main);margin:0}a{color:inherit}h1,h2,h3,p,ul{margin:0}ul{padding-left:1.2rem}#root,.app-shell{width:100%}.section{border-top:1px solid #0f172a0d;width:100%;padding:5rem 0}.section__inner{width:60%;margin:0 auto}.section h2{color:var(--title-color);letter-spacing:-.02em;margin-top:0;margin-bottom:1.2rem;font-family:DM Serif Display,Georgia,serif;font-size:clamp(2rem,3vw,3rem);font-weight:400;line-height:1.12;display:inline-block;position:relative}.section h2:after{content:"";background:var(--accent);border-radius:999px;width:4.5rem;height:.2rem;position:absolute;bottom:-.65rem;left:0}@keyframes section-in{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media (width<=900px){.section{padding:3.2rem 0}.section__inner{width:72%}}@media (width<=768px){.section{padding:2.6rem 0}.section__inner{width:calc(100% - 2.5rem)}.section h2{margin-bottom:.7rem}}@media (width<=480px){.section{padding:2rem 0}.section__inner{width:calc(100% - 1.5rem)}}.hero{color:#e6edf8;background:radial-gradient(circle at 18% 22%,oklch(37.2% .181 267.935),#0000 38%),radial-gradient(circle at 84% 78%,oklch(37.2% .181 267.935),#0000 36%),linear-gradient(130deg,oklch(37.9% .146 265.522) 0% 38%,oklch(37.9% .146 265.522) 100%);border-top:0;align-items:center;min-height:100vh;display:flex;position:relative}.fade-in-up{opacity:0;animation:1s cubic-bezier(.2,.8,.2,1) forwards fade-in-up}@keyframes fade-in-up{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.hero__title{letter-spacing:-.03em;color:#f8fbffe6;font-family:DM Serif Display,Georgia,serif;font-size:clamp(2.7rem,7vw,5rem);line-height:1.05}.hero .hero__subtitle{letter-spacing:.08em;margin-top:.7rem;font-family:JetBrains Mono,Fira Code,Courier New,monospace;font-size:clamp(2rem,2.2vw,2.45rem);font-weight:600;color:#8ebcff!important}.hero__summary{color:#e6edf8cc;max-width:56rem;margin-top:1.35rem;line-height:1.75}.hero__experitnce_counter{color:#dce9ff;flex-wrap:wrap;align-items:flex-end;gap:.65rem 1rem;margin-top:1.15rem;font-size:clamp(1.1rem,1.6vw,1.35rem);display:flex}.hero__experitnce_counter_caption{letter-spacing:.03em;color:#dce9ffe6;font-weight:500}.flip-counter{flex-wrap:wrap;gap:.8rem;display:inline-flex}.flip-group{align-items:flex-end;gap:.45rem;display:inline-flex}.flip-group__digits{gap:.16rem;display:inline-flex}.flip-group__label{text-transform:uppercase;letter-spacing:.16em;color:#c8dbf7d9;font-size:.78rem;transform:translateY(-.2rem)}.flip-digit{--flip-width:1.45em;--flip-height:1.88em;width:var(--flip-width);height:var(--flip-height);perspective:700px;font-family:JetBrains Mono,Fira Code,Courier New,monospace;font-size:1.28em;font-weight:700;line-height:var(--flip-height);letter-spacing:-.03em;text-shadow:0 1px #00000059;display:inline-block;position:relative}.flip-digit:after{content:"";z-index:7;pointer-events:none;border-top:1px solid #090f1bd9;position:absolute;top:calc(50% - 1px);left:.1rem;right:.1rem}.flip-digit__half,.flip-digit__flip{color:#f7fbff;backface-visibility:hidden;background:linear-gradient(#24344f 0%,#17283f 100%);justify-content:center;width:100%;height:50%;display:flex;position:absolute;left:0;overflow:hidden;box-shadow:inset 0 0 0 1px #cddff81f,0 6px 12px #0208124d}.flip-digit__half span,.flip-digit__flip span{text-align:center;width:100%;line-height:var(--flip-height);display:inline-block}.flip-digit__half--top{border-radius:.28rem .28rem .05rem .05rem;align-items:flex-start;top:0}.flip-digit__half--bottom{background:linear-gradient(#121f32 0%,#0d1828 100%);border-radius:.05rem .05rem .28rem .28rem;align-items:flex-end;top:50%}.flip-digit__flip--top{transform-origin:bottom;z-index:8;border-radius:.28rem .28rem .05rem .05rem;align-items:flex-start;animation:.38s ease-in forwards flip-top;top:0}.flip-digit__flip--bottom{transform-origin:top;z-index:6;background:linear-gradient(#16253a 0%,#0f1c2f 100%);border-radius:.05rem .05rem .28rem .28rem;align-items:flex-end;animation:.38s ease-out .38s forwards flip-bottom;top:50%;transform:rotateX(90deg)}@keyframes flip-top{0%{filter:brightness();transform:rotateX(0)}to{filter:brightness(.65);transform:rotateX(-90deg)}}@keyframes flip-bottom{0%{filter:brightness(.5);transform:rotateX(90deg)}to{filter:brightness();transform:rotateX(0)}}.hero__contacts{perspective:1000px;flex-wrap:wrap;gap:.7rem;margin-top:2.5rem;display:flex}.contact-card{perspective:1000px;z-index:1;background-color:#0000;flex:100px;max-width:135px;height:52px;text-decoration:none;position:relative}.contact-card:hover{z-index:100}.contact-card__inner{text-align:center;width:100%;height:100%;transform-style:preserve-3d;transition:transform .5s cubic-bezier(.34,1.56,.64,1);position:relative}.contact-card:hover .contact-card__inner{transform:rotateY(180deg)scale(2)}.contact-card__front,.contact-card__back{backface-visibility:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#e6edf80a;border:1px solid #8ebcff33;border-radius:12px;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;box-shadow:0 8px 24px #0003}.contact-card__front{color:#8ebcff;font-size:1.4rem}.contact-card__back{color:#fff;word-break:break-all;background:#0a1426fa;border:1px solid #8ebcff80;padding:.4rem;font-family:IBM Plex Mono,monospace;font-size:.6rem;transform:rotateY(180deg);box-shadow:0 10px 30px #0009}.contact-card--email .contact-card__back{font-size:.52rem}.contact-card--download .contact-card__front{color:#f8fbff;background:linear-gradient(135deg,#2b63b326,#3a84ea26);border-color:#8ebcff66}.contact-card--download .contact-card__back{color:#f8fbff;background:linear-gradient(135deg,#2b63b3,#3a84ea)}.hero__scroll-indicator{color:#8ebcff80;cursor:pointer;z-index:10;font-size:1.8rem;transition:color .3s,opacity .3s;position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%)}.hero__scroll-indicator.fade-in-up{animation:1s cubic-bezier(.2,.8,.2,1) forwards fade-in-up,2s 1s infinite hero-bounce}.hero__scroll-indicator:hover{color:#8ebcff;opacity:1}@keyframes hero-bounce{0%,20%,50%,80%,to{transform:translate(-50%)translateY(0)}40%{transform:translate(-50%)translateY(-10px)}60%{transform:translate(-50%)translateY(-5px)}}@media (width<=1024px){.hero__summary{font-size:.98rem}}@media (width<=768px){.hero__experitnce_counter{gap:.6rem}.flip-counter{row-gap:.6rem}.flip-group__label{font-size:.68rem}.flip-digit{font-size:1.1em}.hero__contacts{gap:.8rem}}@media (width<=480px){.hero__experitnce_counter{align-items:flex-start}.hero__experitnce_counter_caption{width:100%}.flip-counter{gap:.5rem;width:100%}.flip-group{gap:.3rem}.flip-digit{font-size:1em}.hero__contacts{flex-wrap:wrap;justify-content:center}.contact-card{flex:0 0 calc(50% - .45rem);min-width:90px;height:50px}}.skills{background:#fff}.skills .section__inner{animation:.7s both section-in}.skills__list{grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:1.5rem;display:grid}.skills h2{color:#0b1220}.skills__group{border:1px solid var(--border);background:#f9fbfe;border-radius:.75rem;padding:1rem 1.1rem;transition:transform .25s,border-color .25s,box-shadow .25s;box-shadow:0 8px 22px #0b12200d}.skills__group:hover{border-color:#abc9ef;transform:translateY(-3px);box-shadow:0 16px 26px #0b122014}.skills__group h3{color:#12305d;margin-bottom:.4rem;font-size:1rem}.skills__group li{color:#334155;margin-bottom:.3rem}@media (width<=768px){.skills__list{grid-template-columns:1fr;gap:1rem}.skills__group{padding:.7rem .85rem}}@media (width<=480px){.skills__group h3{font-size:1rem}}.project-card{border:1px solid var(--border);background:var(--card);border-radius:1rem;flex-direction:column;gap:1.5rem;padding:1.5rem;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s,border-color .3s;display:flex;overflow:hidden;box-shadow:0 8px 32px #0f172a0a}.project-card:hover{border-color:#8ebcff;transform:translateY(-5px);box-shadow:0 20px 40px #0f172a1a}.project-card__title{letter-spacing:-.01em;color:#0b1220;font-family:DM Serif Display,Georgia,serif;font-size:1.8rem;line-height:1.2}.project-card__meta{color:#2b63b3;text-transform:uppercase;letter-spacing:.08em;margin-top:.5rem;font-size:.85rem;font-weight:600}.project-card__description{color:#334155;white-space:pre-line;margin-top:.8rem;line-height:1.6}.project-card__tech{margin-top:1.2rem}.project-card__tech-list{flex-wrap:wrap;gap:.5rem;display:flex}.project-card__tech-tile{color:#2b63b3;background:#2b63b30d;border:1px solid #2b63b326;border-radius:6px;padding:.3rem .75rem;font-family:IBM Plex Mono,monospace;font-size:.78rem;font-weight:500;transition:all .2s}.project-card__tech-tile:hover{background:#2b63b31f;border-color:#2b63b3;transform:translateY(-2px);box-shadow:0 4px 8px #2b63b31a}.project-card__gallery-wrapper{width:100%;margin-top:.5rem;position:relative}.project-card__gallery{background:#f1f5f9;border-radius:.8rem;width:100%;display:flex;overflow-x:hidden}.project-card__image-container{background:#fff;flex:0 0 100%;justify-content:center;align-items:center;width:100%;height:385px;display:flex}.project-card__image{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:100%;transition:transform .4s}.project-card__dots{justify-content:center;gap:.6rem;margin-top:1rem;display:flex}.project-card__dot{cursor:pointer;background:#2b63b333;border-radius:50%;width:8px;height:8px;transition:all .3s}.project-card__dot:hover{background:#2b63b380}.project-card__dot.active{background:#2b63b3;border-radius:4px;width:20px;transform:scale(1.25)}.project-card__links{flex-wrap:wrap;justify-content:center;gap:.85rem;margin-top:auto;display:flex}.project-card__link{color:#fff;background:#2b63b3;border:1px solid #2b63b3;border-radius:.6rem;align-items:center;gap:.6rem;padding:.65rem 1.2rem;font-size:.95rem;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex}.project-card__link:hover{background:#1e4b8a;border-color:#1e4b8a;transform:translateY(-2px);box-shadow:0 6px 15px #2b63b34d}.project-card__link--doc{color:#2b63b3;background:0 0;border:1px solid #2b63b366}.project-card__link--doc:hover{background:#2b63b30d;border-color:#2b63b3}@media (width<=768px){.project-card{padding:1.25rem}.project-card__image-container{height:275px}.project-card__title{font-size:1.5rem}}@media (width<=480px){.project-card__image-container{height:200px}.project-card__link{justify-content:center;width:100%}}.projects{background:#f7f9fc}.projects .section__inner{animation:.7s both section-in}.projects h2{color:#0b1220}.projects__list{grid-template-columns:1fr;gap:1.5rem;margin-top:1.5rem;display:grid}.experiences{background:#fff}.experiences .section__inner{animation:.7s both section-in}.experiences h2{color:#0b1220}.experiences .project-card{border-color:var(--border);background:#f9fbfe;padding-left:1.8rem;position:relative}.experiences .project-card__title{color:#0b1220}.experiences .project-card__meta{color:#2b63b3}.experiences .project-card__tech,.experiences .project-card p{color:#475569}.experiences .project-card:before{content:"";background:linear-gradient(#2b63b3,#2b63b333);border-radius:999px;width:.4rem;height:calc(100% - 2.4rem);position:absolute;top:1.2rem;left:.85rem}.experiences__list{gap:1rem;margin-top:1rem;display:grid}@media (width>=1280px){.experiences__list{grid-template-columns:repeat(2,minmax(0,1fr))}}.educations{background:#f7f9fc}.educations .section__inner{animation:.7s both section-in}.educations h2{color:#0b1220}.educations__list{gap:.8rem;margin-top:1rem;display:grid}.education-card{border-left:4px solid #2b63b3;border:1px solid var(--border);background:#fff;border-radius:.75rem;padding:1.1rem 1.2rem;transition:transform .25s,box-shadow .25s;box-shadow:0 8px 22px #0b12200d}.education-card:hover{transform:translateY(-3px);box-shadow:0 14px 28px #0b12201a}.education-card h3{color:#12305d}.education-card p{margin-top:.35rem}@media (width<=768px){.education-card{padding:.85rem}}@media (width<=480px){.education-card h3{font-size:1rem}}.certificates{padding:4rem 0}.certificates .section__inner{max-width:1140px;margin:0 auto;padding:0 1.5rem}.certificates .section__inner h2{color:#0b1220;text-align:left;margin-bottom:2rem;font-family:DM Serif Display,Georgia,serif;font-size:clamp(2rem,4vw,3.2rem)}.certificates__carousel{justify-content:center;align-items:center;display:flex;position:relative}.certificates__frame{aspect-ratio:3/2;transform-origin:50%;border-radius:1rem;width:100%;max-width:100%;transition:transform .2s;position:relative;overflow:hidden;box-shadow:0 20px 45px #2b63b32e}.certificates__frame:hover{transform:scale(1.03)}.certificates__viewer{border:none;width:100%;height:100%}.certificates__meta{flex-direction:column;align-items:center;gap:1rem;margin-top:1.5rem;display:flex}.certificates__label{color:#2b63b3;font-size:1.1rem;font-weight:600}.certificates__dots{gap:.5rem;display:flex}.certificates__dot{cursor:pointer;background:#2b63b340;border:none;border-radius:50%;width:12px;height:12px;transition:all .3s}.certificates__dot.is-active{background:#2b63b3;transform:scale(1.2)}@media (width<=768px){.certificates .section__inner{padding:0 1rem}.certificates__frame{aspect-ratio:4/3}}.languages{background:#fff}.languages .section__inner{animation:.7s both section-in}.languages h2{color:#0b1220}.languages__list{flex-wrap:wrap;gap:1.25rem;margin-top:1.5rem;display:flex}.languages__list li{border:1px solid var(--border);text-align:center;background:#f9fbfe;border-radius:.75rem;flex:auto;width:auto;max-width:fit-content;padding:.85rem 1.25rem;list-style:none;transition:transform .2s,box-shadow .2s}.languages__list li:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0b122014}@media (width<=768px){.languages__list{gap:.75rem}.languages__list li{flex:100%;width:100%;max-width:100%}}.footer{color:#d7e2f3;background:radial-gradient(circle at 14% 20%,#3478d63d,#0000 34%),radial-gradient(circle at 88% 84%,#3478d621,#0000 34%),linear-gradient(135deg,#0a1122,#111f3f);width:100%;padding:4rem 0 3rem}.footer__inner{width:60%;margin:0 auto;animation:.7s both section-in}.footer__copyright{color:#b5c5dc}.footer__contacts{gap:.4rem;margin-top:1rem;display:grid}.footer__contacts p{align-items:center;gap:.5rem;display:flex}.footer__contacts a{color:#8ebcff;text-decoration:none}.to-top{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2b63b3,#3a84ea);border:1px solid #e6edf859;border-radius:50%;width:2.4rem;height:2.4rem;margin-top:1rem;transition:transform .2s}.to-top:hover{transform:translateY(-3px)}@media (width<=900px){.footer{padding:1.75rem 0}.footer__inner{width:72%}}@media (width<=768px){.footer__inner{width:calc(100% - 2.5rem)}.footer__contacts p{align-items:flex-start}}@media (width<=480px){.footer__inner{width:calc(100% - 1.5rem)}.to-top{width:2.1rem;height:2.1rem}}
