:root{--bg:#ffffff;--bg-alt:#fbfbfd;--surface:#ffffff;--footer-bg:#0a0e27;--text:#15171a;--text-soft:#4a5060;--text-muted:#8a8f9a;--hairline:rgba(20, 23, 28, 0.07);--hairline-strong:rgba(20, 23, 28, 0.14);--primary:#0051E1;--primary-dark:#003a99;--accent-green:#00C853;--shadow-xs:0 1px 2px rgba(15, 20, 30, 0.04);--shadow-sm:0 1px 3px rgba(15, 20, 30, 0.05), 0 1px 2px rgba(15, 20, 30, 0.03);--shadow-md:0 4px 12px rgba(15, 20, 30, 0.06), 0 1px 3px rgba(15, 20, 30, 0.04);--shadow-lg:0 24px 60px rgba(15, 20, 30, 0.09), 0 4px 12px rgba(15, 20, 30, 0.05);--ease:cubic-bezier(0.22, 0.61, 0.36, 1);--max-width:1200px;--measure:1080px;--font-display:'Orbitron', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;--font-body:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;--font-mono:'Share Tech Mono', 'SFMono-Regular', Consolas, Menlo, monospace}*,*::before,*::after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-body);font-size:17px;line-height:1.75;color:var(--text);background-color:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6{margin:0 0 .4em;font-weight:700;font-family:var(--font-body);letter-spacing:-.025em;color:var(--text);line-height:1.2}h1{font-size:clamp(2.25rem,5.5vw,3.5rem);font-weight:800}h2{font-size:clamp(1.75rem,3.5vw,2.4rem);margin-top:0}h3{font-size:1.3rem}h4{font-size:.78rem;margin-top:1.75em;color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;font-weight:600}p{margin:0 0 1.25em}a{color:var(--primary);text-decoration:none;transition:color .3s var(--ease)}a:hover{color:var(--primary-dark);text-decoration:underline;text-underline-offset:3px}img{max-width:100%;height:auto}section{padding:7rem 2rem}.section-container{max-width:var(--max-width);margin:0 auto;padding:7rem 2rem}.services-section h2::before,.experience-section>h2::before,.about-content h2::before,.list-header h1::before{content:attr(data-eyebrow);display:block;font-family:var(--font-mono);font-size:.72rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--primary);margin-bottom:1rem}header{background:rgba(255,255,255,.85);backdrop-filter:saturate(180%)blur(14px);-webkit-backdrop-filter:saturate(180%)blur(14px);border-bottom:1px solid var(--hairline);padding:1.1rem 2rem;position:sticky;top:0;z-index:100}.header-container{display:flex;justify-content:space-between;align-items:center;max-width:var(--max-width);margin:0 auto;gap:1rem}.header-container .logo a{display:inline-flex;align-items:center;font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.01em;color:var(--text)}.header-container .logo a:hover{text-decoration:none;color:var(--text)}.logo-icon{background:var(--text);color:#fff;padding:5px 9px;margin-right:10px;border-radius:6px;font-weight:700;font-size:.82rem;letter-spacing:.02em}.main-menu{list-style:none;display:flex;gap:2rem;margin:0;padding:0}.main-menu a{color:var(--text-soft);font-weight:500;font-size:.95rem;padding:4px 0;position:relative}.main-menu a:hover,.main-menu .active a{color:var(--text);text-decoration:none}.main-menu .active a{color:var(--primary)}.main-menu .active a::after{content:'';position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--primary);border-radius:2px}footer{background:var(--footer-bg);color:#c7ccda;padding:5rem 2rem 2rem;margin-top:3rem}.footer-container{display:flex;flex-wrap:wrap;gap:3rem;max-width:var(--max-width);margin:0 auto}.footer-left{flex:1.4;min-width:260px}.footer-left .logo{font-family:var(--font-display);font-weight:700;font-size:1.05rem;margin-bottom:.75rem}.footer-left .logo a{color:#fff}.footer-left p{color:#8892b0;max-width:360px;line-height:1.7}.footer-right{flex:1;min-width:180px}.footer-right h4{margin:0 0 1rem;color:#fff;text-transform:uppercase;font-size:.72rem;letter-spacing:.16em}.footer-right ul{list-style:none;margin:0;padding:0}.footer-right li{color:#8892b0;margin-bottom:.6rem;font-size:.95rem}.footer-right a{color:#c7ccda}.footer-right a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}.footer-contact{min-width:180px}.footer-contact h4{margin:0 0 1rem;color:#fff;text-transform:uppercase;font-size:.72rem;letter-spacing:.16em}.qr-box{display:inline-block;padding:8px;background:#fff;border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.3)}.qr-box img{display:block;width:116px;height:116px;border-radius:4px}footer hr{border:0;border-top:1px solid rgba(255,255,255,8%);margin:3rem auto 1.5rem;max-width:var(--max-width)}.footer-bottom{max-width:var(--max-width);margin:0 auto}.footer-bottom-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-bottom small{color:#6b7280;font-size:.85rem}.footer-links{display:flex;flex-wrap:wrap;gap:1.25rem}.footer-links a{color:#c7ccda;font-size:.85rem}.footer-links a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}.hero-section{display:flex;align-items:center;gap:4rem;max-width:var(--max-width);margin:0 auto;padding:6rem 2rem 5rem}.hero-content{flex:1;min-width:0}.hero-content h1{margin-bottom:1rem;font-family:var(--font-display);font-weight:900;letter-spacing:-.01em;font-size:clamp(2.25rem,5vw,3.4rem)}.subtitle{font-family:var(--font-mono);color:var(--primary);font-size:.85rem;text-transform:uppercase;letter-spacing:.18em;margin-bottom:1.5rem}.hero-content p{color:var(--text-soft);max-width:540px;font-size:1.08rem;line-height:1.75}.hero-image{flex-shrink:0}.profile-avatar{width:200px;height:200px;object-fit:cover;border-radius:50%;box-shadow:var(--shadow-lg);border:6px solid var(--bg)}.btn{display:inline-block;padding:.95rem 1.9rem;border-radius:8px;font-weight:600;font-family:var(--font-body);font-size:.95rem;letter-spacing:-.01em;transition:transform .3s var(--ease),box-shadow .3s var(--ease),background-color .3s var(--ease)}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 14px rgba(0,81,225,.28)}.btn-primary:hover{background:var(--primary-dark);color:#fff;text-decoration:none;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,81,225,.36)}.services-section{background:var(--bg-alt);border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}.services-section .section-container{text-align:center}.services-section>.section-container>p{max-width:620px;margin:0 auto 3.5rem;color:var(--text-soft);font-size:1.05rem}.service-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;text-align:left}.card{background:var(--surface);border:1px solid var(--hairline);border-radius:16px;padding:2rem;box-shadow:var(--shadow-xs);transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}.card-header{display:flex;align-items:center;gap:.85rem;margin-bottom:.9rem}.card .icon{font-size:1.4rem;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--bg-alt);border-radius:12px}.card h3{margin:0;color:var(--text);font-size:1.15rem}.card p{margin:0;color:var(--text-soft);font-size:.95rem;line-height:1.65}.experience-section{max-width:var(--max-width);margin:0 auto}.experience-section>h2{text-align:center}.experience-section>p{text-align:center;max-width:680px;margin:0 auto 3.5rem;color:var(--text-soft);font-size:1.05rem}.experience-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:4rem}.experience-column h3{margin:0 0 1.25rem;padding-bottom:.6rem;border-bottom:1px solid var(--hairline-strong);font-size:1.1rem}.tag-group{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tech-tag{display:inline-block;padding:.3rem .75rem;background:0 0;color:var(--text-soft);border:1px solid var(--hairline-strong);border-radius:999px;font-family:var(--font-mono);font-size:.76rem;transition:border-color .25s var(--ease),color .25s var(--ease)}.tech-tag:hover{border-color:var(--primary);color:var(--primary)}.project-list{list-style:none;margin:0;padding:0}.project-list li{padding:.9rem 0 .9rem 1.1rem;border-bottom:1px solid var(--hairline);color:var(--text-soft);font-size:.95rem;position:relative}.project-list li::before{content:'';position:absolute;left:0;top:1.35rem;width:6px;height:6px;border-radius:50%;background:var(--accent-green)}.project-list li:last-child{border-bottom:none}.project-list li strong{color:var(--text);font-weight:600}.about-section{background:var(--bg-alt);border-top:1px solid var(--hairline)}.about-section .section-container{display:flex;align-items:center;gap:4rem}.about-content{flex:1;min-width:0}.about-content h2{margin-bottom:.4rem}.about-content h3{color:var(--text-soft);font-weight:500;margin-bottom:1.75rem;font-size:1.15rem}.about-content p{color:var(--text-soft)}.about-image{flex-basis:38%;flex-shrink:0}.about-image img{border-radius:16px;box-shadow:var(--shadow-lg)}.list-page{padding:6rem 2rem}.list-container{max-width:var(--max-width);margin:0 auto}.list-header{margin-bottom:4rem}.list-header h1{font-size:clamp(2.25rem,5vw,3rem);margin:0}.list-desc{color:var(--text-soft);margin-top:.6rem;max-width:620px;font-size:1.05rem}.post-list{list-style:none;margin:0;padding:0}.post-card{display:grid;grid-template-columns:120px 1fr;gap:2.5rem;padding:2.25rem;margin-bottom:1.25rem;background:var(--surface);border:1px solid var(--hairline);border-radius:16px;box-shadow:var(--shadow-xs);transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease)}.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:transparent}.post-card-meta{display:flex;flex-direction:column;gap:.3rem;padding-right:1rem;border-right:1px solid var(--hairline)}.post-card-meta time{font-size:1.65rem;font-weight:700;color:var(--text);line-height:1;letter-spacing:-.03em}.post-card-year{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em}.post-card-body{display:flex;flex-direction:column;gap:.65rem;min-width:0}.post-card-body h2{margin:0;font-size:1.4rem;line-height:1.3;letter-spacing:-.02em}.post-card-body h2 a{color:var(--text)}.post-card-body h2 a:hover{color:var(--primary);text-decoration:none}.post-card-summary{margin:0;color:var(--text-soft);font-size:.98rem;line-height:1.65}.post-card-link{font-family:var(--font-mono);font-size:.76rem;font-weight:400;color:var(--primary);text-transform:uppercase;letter-spacing:.14em;margin-top:.4rem}.post-card-link:hover{color:var(--primary-dark);text-decoration:none}.post-card-link .arrow{display:inline-block;transition:transform .3s var(--ease)}.post-card-link:hover .arrow{transform:translateX(4px)}.pagination ul{list-style:none;display:flex;flex-wrap:wrap;padding:0;justify-content:center;gap:.5rem;margin-top:3.5rem}.pagination li a,.pagination li span{display:block;padding:.55rem 1rem;border:1px solid var(--hairline-strong);color:var(--text-soft);text-decoration:none;border-radius:8px;font-family:var(--font-mono);font-size:.82rem;transition:border-color .25s var(--ease),color .25s var(--ease)}.pagination li a:hover{border-color:var(--primary);color:var(--primary)}.pagination li.active a{background:var(--text);color:#fff;border-color:var(--text)}.pagination li.disabled span{opacity:.35}.single-page .section-container{max-width:var(--max-width)}.single-page h1{font-size:clamp(1.9rem,4vw,2.6rem)}.single-page time,.single-page .tags{color:var(--text-muted);font-size:.9rem;font-family:var(--font-mono)}.single-page .tags a{margin-left:.5rem}.single-page .content{margin-top:2.5rem}.single-page .content p,.single-page .content li{font-size:1.06rem;line-height:1.8;color:var(--text)}.single-page .content h2{margin-top:2em}.single-page .content h3{margin-top:1.75em}.single-page .content blockquote{border-left:3px solid var(--primary);margin:1.5em 0;padding:.5em 0 .5em 1.25em;color:var(--text-soft);font-style:italic}.highlight{margin:1.75em 0;border-radius:12px;overflow:auto;background:#0d1117;border:1px solid var(--hairline);box-shadow:var(--shadow-sm)}.highlight pre{padding:1.4em;margin:0;font-size:.88em;line-height:1.65;color:#e0e6ed;font-family:var(--font-mono)}:not(pre)>code{background:var(--bg-alt);padding:.15em .4em;border-radius:4px;font-size:.88em;color:var(--primary)}.single-page .content table{width:100%;border-collapse:collapse;margin:1.75em 0;font-size:.95em;line-height:1.5;border:1px solid var(--hairline-strong);border-radius:8px;overflow:hidden}.single-page .content thead{background:var(--bg-alt)}.single-page .content th,.single-page .content td{padding:.75em 1em;text-align:left;border-bottom:1px solid var(--hairline)}.single-page .content th{font-weight:600;color:var(--text);font-size:.82em;text-transform:uppercase;letter-spacing:.06em}.single-page .content tbody tr:last-child td{border-bottom:none}.single-page .content tbody tr:hover{background:var(--bg-alt)}.single-page .content table code,.single-page .content table kbd{font-family:var(--font-mono)}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:4px}::selection{background:rgba(0,81,225,.16)}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}@media(max-width:960px){section,.section-container{padding:5rem 1.5rem}.hero-section{padding:4rem 1.5rem;gap:2.5rem}.experience-grid{gap:2.5rem}.about-section .section-container{gap:2.5rem}}@media(max-width:640px){body{font-size:16px}header{padding:.9rem 1.25rem}.header-container{flex-direction:column;align-items:flex-start;gap:.6rem}.main-menu{flex-wrap:wrap;gap:1.1rem}.main-menu a{font-size:.9rem}section,.section-container{padding:4rem 1.25rem}.hero-section{flex-direction:column-reverse;text-align:center;gap:2rem;padding:3rem 1.25rem 2rem}.hero-content p{margin-left:auto;margin-right:auto}.subtitle{letter-spacing:.14em}.btn{display:block;width:100%;text-align:center}.profile-avatar{width:132px;height:132px;border-width:4px}.about-section .section-container{flex-direction:column}.about-image{width:100%}.experience-grid{grid-template-columns:1fr;gap:2.5rem}.post-card{grid-template-columns:1fr;gap:1rem;padding:1.5rem}.post-card-meta{flex-direction:row;align-items:baseline;gap:.6rem;border-right:none;border-bottom:1px solid var(--hairline);padding:0 0 1rem}.post-card-meta time{font-size:1.35rem}.footer-container{gap:2rem}.footer-bottom-content{flex-direction:column;align-items:flex-start;gap:.75rem}.footer-links{gap:1rem}}.logo-strip{max-width:var(--max-width);margin:0 auto;padding:2.5rem 2rem 1rem;text-align:center}.logo-strip-label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin:0 0 1.5rem}.logo-list{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:2.5rem 3rem;margin:0;padding:0}.logo-item{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.01em;color:var(--text-muted);opacity:.75;transition:opacity .3s var(--ease),color .3s var(--ease)}.logo-item:hover{opacity:1;color:var(--text)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.work-section .section-container{padding-top:4.5rem;padding-bottom:4.5rem}.section-lead{max-width:620px;margin:0 auto 2.5rem;color:var(--text-soft);font-size:1.02rem;text-align:center}.work-section .section-container>h2{text-align:center}.company-groups{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;align-items:start}.company-group{border:1px solid var(--hairline);border-radius:10px;padding:1.1rem 1.25rem;background:var(--surface);transition:border-color .25s var(--ease)}.company-group:hover{border-color:var(--hairline-strong)}.company-name{margin:0 0 .65rem;font-size:1.02rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:.5rem}.company-name::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--primary);flex-shrink:0}.company-projects{display:grid;gap:.6rem}.project-entity{margin:0;font-weight:600;font-size:.9rem;color:var(--text)}.project-desc{margin:0;color:var(--text-soft);font-size:.86rem;line-height:1.5}.project-desc a{color:var(--primary)}.project-desc a:hover{color:var(--primary-dark)}@media(max-width:720px){.company-groups{grid-template-columns:1fr}.work-section .section-container{padding-top:3.5rem;padding-bottom:3.5rem}}.process-section{background:var(--bg-alt);border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}.process-section .section-container{text-align:center}.process-list{list-style:none;margin:3rem 0 0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;text-align:left;counter-reset:step}.process-step{display:flex;gap:1.25rem;align-items:flex-start}.process-badge{flex-shrink:0;width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid var(--hairline-strong);border-radius:50%;font-family:var(--font-mono);font-size:.9rem;color:var(--primary);background:var(--surface)}.process-step h3{margin:.2rem 0 .4rem;font-size:1.15rem}.process-step p{margin:0;color:var(--text-soft);font-size:.95rem}@media(max-width:720px){.process-list{grid-template-columns:1fr;gap:1.75rem}}.faq-section{padding:7rem 2rem}.faq-container{max-width:820px;margin:0 auto}.faq-list{margin-top:3rem;border-top:1px solid var(--hairline)}.faq-item{border-bottom:1px solid var(--hairline)}.faq-question{list-style:none;cursor:pointer;padding:1.4rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:1.1rem;font-weight:600;color:var(--text)}.faq-question::-webkit-details-marker{display:none}.faq-question::after{content:'+';font-family:var(--font-mono);font-weight:400;font-size:1.4rem;color:var(--primary);transition:transform .3s var(--ease)}.faq-item[open] .faq-question::after{transform:rotate(45deg)}.faq-answer{margin:0;padding:0 0 1.4rem;color:var(--text-soft);line-height:1.7}.faq-question:focus-visible{outline:2px solid var(--primary);outline-offset:4px;border-radius:4px}.cta-band{position:relative;background:var(--footer-bg);color:#fff;padding:7rem 2rem;text-align:center;overflow:hidden}.cta-band .gfx-node-graph{position:absolute;inset:0;width:100%;height:100%;color:#0051e1;opacity:.18;pointer-events:none}.cta-inner{position:relative;max-width:640px;margin:0 auto}.cta-inner h2{color:#fff;font-size:clamp(1.8rem,3.5vw,2.6rem)}.cta-inner p{color:#c7ccda;font-size:1.1rem;margin-bottom:2rem}.btn-large{padding:1.05rem 2.2rem;font-size:1.02rem}.cta-band .btn-primary{background:#fff;color:var(--footer-bg);box-shadow:0 4px 20px rgba(0,0,0,.3)}.cta-band .btn-primary:hover{background:var(--accent-green);color:var(--footer-bg);transform:translateY(-2px)}.hero-section{position:relative;overflow:hidden}.hero-section .gfx-node-graph{position:absolute;inset:0;width:100%;height:100%;color:var(--primary);opacity:.06;pointer-events:none}.hero-section>.hero-content,.hero-section>.hero-image{position:relative;z-index:1}.hero-eyebrow{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--primary);margin:0 0 1rem}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}.btn-ghost{background:0 0;color:var(--text);border:1px solid var(--hairline-strong)}.btn-ghost:hover{border-color:var(--text);color:var(--text);text-decoration:none;transform:translateY(-2px)}.hero-photo-frame{position:relative;width:220px;height:220px;display:flex;align-items:center;justify-content:center}.hero-photo-frame .profile-avatar{width:180px;height:180px;object-fit:cover;border-radius:50%;border:4px solid var(--bg);box-shadow:var(--shadow-lg);position:relative;z-index:1}.hero-photo-frame .gfx-orbit-ring{position:absolute;inset:-10px;width:calc(100% + 20px);height:calc(100% + 20px);color:var(--primary);animation:orbit-spin 40s linear infinite}@keyframes orbit-spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.hero-photo-frame .gfx-orbit-ring{animation:none}}.card .icon{width:40px;height:40px;padding:8px;box-sizing:content-box;color:var(--primary)}.card .icon svg{width:100%;height:100%;display:block}.about-skills{margin-top:2rem}.compact-skills{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;margin:.75rem 0 0;padding:0;font-family:var(--font-mono);font-size:.88rem;color:var(--text-soft)}.compact-skills li{position:relative;padding-left:1rem}.compact-skills li::before{content:'';position:absolute;left:0;top:.55em;width:5px;height:5px;border-radius:50%;background:var(--accent-green)}.about-links{margin-top:1.75rem}.about-links a{font-family:var(--font-mono);font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:var(--primary)}.skip-link{position:absolute;left:1rem;top:-3rem;z-index:200;background:var(--text);color:#fff;padding:.6rem 1rem;border-radius:6px;font-size:.9rem;transition:top .2s var(--ease)}.skip-link:focus{top:1rem;color:#fff;text-decoration:none}[data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}[data-reveal].is-visible{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none}}@media(max-width:720px){.case-card-row{grid-template-columns:1fr;gap:1.25rem;padding:1.5rem}.case-thumb img{height:150px}}