:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #1c2026;--bg-quaternary: #2c313a;--bg-quinary: #363c44;--accent-blue: #007acc;--accent-cyan: #00bfff;--accent-orange: #e67e22;--accent-green: #27ae60;--accent-purple: #9b59b6;--accent-red: #e74c3c;--accent-yellow: #f1c40f;--text-primary: #ffffff;--text-secondary: #e0e0e0;--text-muted: #8b949e;--glow: 0 0 20px rgba(0, 191, 255, .3);--glass-bg: rgba(255, 255, 255, .1);--glass-blur: blur(15px);--blog-narrow-width: 820px}html{scroll-behavior:smooth}.glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);box-shadow:0 4px 30px #0000001a}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden}.container{max-width:1200px;margin:0 auto;padding:0 20px}nav{position:fixed;top:0;width:100%;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:var(--glass-border);z-index:1000;padding:15px 0;transition:all .3s ease}nav.scrolled{background:var(--glass-bg);box-shadow:0 2px 20px #0000004d}.nav-container{display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:700;color:var(--accent-cyan)}.nav-links{display:flex;list-style:none;gap:30px}.nav-links a{color:var(--text-secondary);text-decoration:none;font-weight:500;transition:all .3s ease;position:relative}.nav-links a:hover{color:var(--accent-cyan);text-shadow:0 0 10px rgba(0,191,255,.5)}.nav-links a:after{content:"";position:absolute;bottom:-5px;left:0;width:0;height:2px;background:var(--accent-cyan);transition:width .3s ease}.nav-links a:hover:after{width:100%}.mobile-menu{display:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;width:36px;height:36px;align-items:center;justify-content:center;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--accent-cyan);border-radius:4px;position:relative;z-index:1101}.hero{height:100vh;height:100dvh;min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.hero:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="10" height="10" patternUnits="userSpaceOnUse"><path d="M 10 0 L 0 0 0 10" fill="none" stroke="%23ffffff" stroke-width="0.1" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');opacity:.1;z-index:1}.hero:after{content:"";position:absolute;inset:0;opacity:.03;filter:grayscale(100%);z-index:0}.hero-content{position:relative;z-index:2;animation:fadeInUp 1s ease-out;display:grid;grid-template-columns:1fr 2fr;gap:60px;align-items:center}.hero-image{text-align:center}.hero h1{font-size:4rem;font-weight:700;margin-bottom:20px;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero .tagline{--hero-tagline-color: var(--text-secondary);--hero-tagline-weight: 300;--hero-tagline-max-ch: 60ch;--hero-tagline-size: clamp(1.125rem, 2.5vw + .2rem, 1.75rem);font-size:var(--hero-tagline-size);color:var(--hero-tagline-color);margin-bottom:30px;font-weight:var(--hero-tagline-weight);line-height:1.35;max-width:var(--hero-tagline-max-ch)}.hero .subtitle{font-size:1.1rem;color:var(--text-muted);margin-bottom:40px;max-width:600px}.cta-buttons{display:flex;gap:20px;margin-top:40px}@supports (-webkit-touch-callout: none){.hero .cta-buttons{margin-bottom:20px}}.btn{padding:15px 30px;font-size:1rem;font-weight:600;text-decoration:none;border-radius:50px;transition:all .3s ease;display:inline-flex;align-items:center;gap:10px;border:none;cursor:pointer}.btn-primary{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));color:var(--text-primary)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--glow)}.btn-secondary{background:transparent;color:var(--accent-cyan);border:2px solid var(--accent-cyan)}.btn-secondary:hover{background:var(--accent-cyan);color:var(--bg-primary);box-shadow:var(--glow)}.construction-btn{position:absolute;top:20px;left:50%;transform:translate(-50%);margin-top:60px;padding:15px 30px;font-size:1rem;font-weight:600;border-radius:50px;background:linear-gradient(135deg,#ff416c,#ff4b2b);color:var(--text-primary);border:none;cursor:pointer;white-space:nowrap;z-index:3;box-shadow:0 0 10px #ff4b2b80}.construction-btn:hover{transform:translate(-50%,-2px);box-shadow:0 0 15px #ff4b2bb3}.section{padding:90px 0 50px;position:relative;background:var(--bg-primary)}#about{background:var(--bg-secondary)}#projects{background:var(--bg-tertiary)}#blog{background:var(--bg-quaternary)}footer{background:var(--bg-quinary)}.section-title{text-align:center;font-size:2.5rem;font-weight:700;margin-bottom:60px;color:var(--text-primary)}.section-title:not(:first-of-type){margin-top:80px}.section-title:after{content:"";display:block;width:80px;height:3px;background:var(--accent-cyan);margin:20px auto}.about-content{display:grid;grid-template-columns:1fr;gap:60px;align-items:center}.profile-img{width:300px;height:300px;border-radius:50%;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));display:flex;align-items:center;justify-content:center;font-size:8rem;color:var(--text-primary);margin:0 auto;border:3px solid var(--accent-cyan);box-shadow:var(--glow)}.profile-img img{width:100%;height:100%;object-fit:cover;border-radius:50%;filter:brightness(90%)}.about-text h3{font-size:2rem;color:var(--accent-cyan);margin-bottom:20px}.about-text p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:20px}.tech-stack{display:flex;flex-wrap:wrap;gap:15px;margin-top:30px}.skills-section{margin-top:30px}.skills-section h4{margin-bottom:10px;color:var(--accent-cyan)}.skill-group{margin-top:15px}.tech-tag{background:var(--bg-tertiary);padding:8px 16px;border-radius:25px;font-size:.9rem;color:var(--accent-cyan);border:1px solid var(--accent-blue)}.tech-tag.languages{color:var(--accent-cyan);border-color:var(--accent-cyan)}.tech-tag.frontend{color:var(--accent-blue);border-color:var(--accent-blue)}.tech-tag.infrastructure,.tech-tag.infra{color:var(--accent-orange);border-color:var(--accent-orange)}.tech-tag.database{color:var(--accent-green);border-color:var(--accent-green)}.tech-tag.devops{color:var(--accent-purple);border-color:var(--accent-purple)}.tech-tag.backend{color:var(--accent-red);border-color:var(--accent-red)}.tech-tag.patterns{color:var(--accent-yellow);border-color:var(--accent-yellow)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:30px;margin-top:40px}.project-card{background:linear-gradient(135deg,#ffffff0d,#fff0),var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:15px;padding:30px 30px 70px;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;border:1px solid rgba(255,255,255,.1);cursor:pointer;position:relative;overflow:hidden}.center-highlight{box-shadow:var(--glow);border-color:var(--accent-cyan)}.project-card:hover{transform:translateY(-10px);border-color:var(--accent-cyan);box-shadow:0 10px 30px #00bfff4d}.project-type{color:var(--accent-cyan);font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}.project-company{font-size:.85rem;color:var(--text-muted);margin-bottom:10px}.project-card h3{font-size:1.4rem;color:var(--text-primary);margin-bottom:15px}.project-card p{color:var(--text-secondary);margin-bottom:20px}.project-tech{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.project-tech span{background:var(--bg-primary);padding:4px 10px;border-radius:12px;font-size:.8rem;color:var(--text-muted)}.project-links{display:flex;gap:15px}.project-links span{display:inline-flex;align-items:center;gap:5px;color:var(--accent-cyan);transition:color .3s ease}.project-links a{color:var(--accent-cyan);text-decoration:none;font-weight:500;transition:all .3s ease}.project-links .details-link{display:inline-flex;align-items:center;gap:5px;position:absolute;right:30px;bottom:30px}.project-links a:hover,.project-links span:hover{color:var(--text-primary);text-shadow:0 0 10px rgba(0,191,255,.5)}.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:30px;margin-top:40px}.blog-card{background:linear-gradient(135deg,#ffffff0d,#fff0),var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:15px;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;border:1px solid rgba(255,255,255,.1);position:relative}.blog-card:hover{transform:translateY(-8px);border-color:var(--accent-cyan);box-shadow:0 10px 30px #00bfff40}.blog-image{height:160px;background:linear-gradient(135deg,var(--accent-blue),var(--accent-cyan));display:flex;align-items:center;justify-content:center;font-size:2.2rem;color:var(--text-primary);overflow:hidden;position:relative;isolation:isolate;transition:filter .28s ease,transform .28s ease;will-change:filter,transform}.blog-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .28s ease;will-change:transform}.blog-card:hover .blog-image{filter:drop-shadow(0 8px 16px rgba(0,0,0,.25)) drop-shadow(0 2px 4px rgba(0,0,0,.2));transform:translateY(-2px)}.blog-image:after{content:"";position:absolute;inset:-20%;background:linear-gradient(120deg,#fff0 30%,#ffffff40 48%,#fff9,#ffffff40 52%,#fff0 70%);transform:translate(-140%) rotate(.001deg);opacity:0;pointer-events:none}.blog-card:hover .blog-image:after{animation:blog-card-shine .9s ease forwards;opacity:1}.blog-card:hover .blog-image img{transform:scale(1.03)}@keyframes blog-card-shine{0%{transform:translate(-140%) rotate(.001deg)}60%{transform:translate(0) rotate(.001deg)}to{transform:translate(140%) rotate(.001deg)}}.blog-content{padding:24px 24px 28px}.blog-card-link{display:block;color:inherit;text-decoration:none}.blog-card-link:focus{outline:none}.blog-card-link:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:3px;border-radius:14px}.blog-empty{text-align:center;color:var(--text-secondary)}.blog-date{color:var(--text-muted);font-size:.9rem;margin-bottom:8px}.blog-card h3{font-size:1.25rem;color:var(--text-primary);margin-bottom:12px}.blog-card h3 a{color:inherit;text-decoration:none}.blog-card h3 a:hover{color:var(--accent-cyan);text-shadow:0 0 10px rgba(0,191,255,.5)}.blog-card p{color:var(--text-secondary);margin-bottom:16px}.read-more{color:var(--accent-cyan);text-decoration:none;font-weight:600;transition:all .3s ease}.read-more:hover{color:var(--text-primary);text-shadow:0 0 10px rgba(0,191,255,.5)}.blog-post-actions{display:flex;justify-content:center;margin-top:20px}.blog-post-actions.left{justify-content:flex-start;max-width:var(--blog-narrow-width);width:100%;margin-left:auto;margin-right:auto}.back-btn{border-radius:10px;padding:10px 18px}.latest-posts{margin-top:40px}.latest-posts-title{text-align:center;font-size:1.6rem;margin:30px 0 10px;color:var(--text-primary)}.blog-post-header.align-left,.blog-post-title.align-left,.blog-post-date.align-left{text-align:left}.blog-post-divider{height:3px;width:100%;max-width:var(--blog-narrow-width);background:linear-gradient(90deg,var(--accent-cyan),var(--accent-blue));margin:18px auto 6px;box-shadow:var(--glow);border-radius:2px}.blog-post-divider.blog-post-divider--wide{max-width:var(--blog-narrow-width)}.code-block-wrapper{position:relative;margin:16px 0}.code-lang{position:absolute;top:-10px;right:12px;background:#161b22e6;color:var(--text-muted);font-size:.75rem;padding:2px 8px;border:1px solid #30363d;border-radius:6px;letter-spacing:.02em;text-transform:uppercase}.code-block{margin-top:12px}.blog-post{max-width:1200px;margin:0 auto;background:linear-gradient(135deg,#ffffff0d,#fff0),var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:28px}.blog-post.blog-post--narrow{max-width:var(--blog-narrow-width);width:100%}@media (max-width: 900px){.blog-post.blog-post--narrow,.blog-post-divider,.blog-post-actions.left{max-width:100%}}.blog-post-header{margin-bottom:12px;text-align:center}.blog-post-title{font-size:2rem;font-weight:700;margin-bottom:6px;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.blog-post-date{color:var(--text-muted);font-size:.95rem}.blog-post-content{margin-top:18px}.blog-post-content .blog-list{margin:0 0 1.25rem 1.25rem;padding:0;list-style:none}.blog-post-content .blog-list li{position:relative;margin:0 0 .5rem;padding-left:1.25rem;line-height:1.6}.blog-post-content .blog-list li:before{content:"•";position:absolute;left:0;top:0;transform:translateY(2px);font-weight:700;color:var(--accent-cyan)}.blog-post-content h2.blog-subtitle,.blog-post-content h3.blog-subtitle,.blog-post-content h4.blog-subtitle{margin:1.5rem 0 .75rem;line-height:1.3}.blog-post-content p{color:var(--text-secondary);margin:14px 0;font-size:1.05rem}.code-block{background:#0d1117;color:#c9d1d9;padding:14px;border-radius:8px;overflow-x:auto;border:1px solid #30363d;margin:16px 0}footer{background:var(--bg-primary);padding:60px 0 30px;text-align:center;border-top:1px solid var(--bg-tertiary)}.footer-content h3{font-size:2rem;color:var(--accent-cyan);margin-bottom:20px}.footer-content p{color:var(--text-secondary);margin-bottom:30px;max-width:600px;margin-left:auto;margin-right:auto}.social-links{display:flex;justify-content:center;gap:30px;margin-bottom:40px}.social-links a{color:var(--text-muted);font-size:1.5rem;transition:all .3s ease}.social-links a:hover{color:var(--accent-cyan);text-shadow:0 0 10px rgba(0,191,255,.5)}.footer-bottom{border-top:1px solid var(--bg-tertiary);padding-top:20px;color:var(--text-muted)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%{transform:translateY(100vh) rotate(0);opacity:0}10%{opacity:.5}90%{opacity:.5}to{transform:translateY(-100vh) rotate(360deg);opacity:0}}.fade-in{opacity:0;transform:translateY(30px);animation:fadeInUp .8s ease-out forwards}@media (max-width: 768px){.hero,.section{padding-top:100px}.nav-links{position:fixed;top:0;right:0;height:100vh;width:250px;background:#161b22f2;box-shadow:-2px 0 5px #00000080;flex-direction:column;padding-top:80px;padding-left:40px;transform:translate(100%);transition:transform .3s ease;display:flex;gap:20px;z-index:1100}.nav-links li{margin-left:10px}.nav-links.open{transform:translate(0)}.mobile-menu{display:flex}.hero h1{font-size:2.5rem}.hero .tagline{--hero-tagline-max-ch: 42ch;--hero-tagline-size: clamp(1rem, 3.2vw + .2rem, 1.35rem)}.cta-buttons{flex-direction:row;align-items:center;justify-content:center}.hero-content{grid-template-columns:1fr;text-align:center;gap:20px}.about-content{grid-template-columns:1fr;text-align:center}.profile-img{width:200px;height:200px;font-size:5rem}.profile-img img{width:100%;height:100%;object-fit:cover;border-radius:50%}.projects-grid,.blog-grid{grid-template-columns:1fr}.social-links{gap:20px}}.scroll-animate{opacity:0;transform:translateY(50px);transition:all .8s ease-out}.scroll-animate.visible{opacity:1;transform:translateY(0)}.timeline{position:relative;padding:60px 0;overflow-x:auto;overflow-y:visible}.timeline:before{content:"";position:absolute;left:0;right:0;top:50%;height:3px;background:linear-gradient(to right,var(--accent-cyan),var(--accent-blue));transform:translateY(-50%);box-shadow:var(--glow)}.timeline-container{display:flex;justify-content:space-between;align-items:center;position:relative;min-width:800px}.timeline-item{position:relative;text-align:center;flex:1;height:120px;opacity:0;animation:fadeInUp .8s ease-out forwards}.timeline-item:nth-child(1){animation-delay:.2s}.timeline-item:nth-child(2){animation-delay:.4s}.timeline-item:nth-child(3){animation-delay:.6s}.timeline-item:nth-child(4){animation-delay:.8s}.timeline-item:nth-child(5){animation-delay:1s}.timeline-dot{width:16px;height:16px;background:var(--accent-cyan);border-radius:50%;border:3px solid var(--bg-primary);position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:10;box-shadow:var(--glow);animation:pulse 2s infinite}.timeline-header{text-align:left;color:var(--accent-cyan);margin-bottom:40px;padding-left:20px}.company{position:absolute;top:-80px;left:50%;transform:translate(-50%);width:140px;font-size:1rem;color:var(--text-primary);font-weight:500;transition:color .3s ease;line-height:1.3}.timeline-item:hover .company{color:var(--accent-cyan)}.date{position:absolute;top:calc(50% + 30px);left:50%;transform:translate(-50%);font-size:.9rem;font-weight:600;color:var(--accent-cyan);white-space:nowrap}@keyframes pulse{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.2)}}@media (max-width: 768px){.timeline{overflow-x:scroll;padding:80px 20px 40px}.timeline-container{min-width:600px}.date{font-size:.8rem}.company{font-size:.9rem}}@media (max-width: 480px){.timeline-container{min-width:500px}.date{font-size:.75rem}.company{font-size:.8rem}}.scroll-top-btn{position:fixed;bottom:40px;right:40px;width:50px;height:50px;border-radius:50%;background:transparent;border:2px solid var(--text-muted);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1000;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s,visibility .3s,border-color .3s,box-shadow .3s,color .3s}.scroll-top-btn.visible{opacity:1;visibility:visible;pointer-events:auto}.scroll-top-btn:hover{border-color:var(--accent-cyan);box-shadow:var(--glow);color:var(--accent-cyan)}.not-found{height:100vh;height:100dvh;min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);text-align:center}.not-found:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="10" height="10" patternUnits="userSpaceOnUse"><path d="M 10 0 L 0 0 0 10" fill="none" stroke="%23ffffff" stroke-width="0.1" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');opacity:.1;z-index:1}.not-found-content{position:relative;z-index:2;animation:fadeInUp 1s ease-out}.not-found h1{font-size:8rem;font-weight:700;margin-bottom:20px;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.not-found p{font-size:1.5rem;color:var(--text-secondary);margin-bottom:40px}@media (max-width: 768px){.not-found h1{font-size:6rem}.not-found p{font-size:1.2rem}}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
  Theme: GitHub Dark
  Description: Dark theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-dark
  Current colors taken from GitHub's CSS
*/.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}
