@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&family=Lexend:wght@400;500;600;700&display=swap";:root{--background:#fff;--background-soft:#fafafa;--surface:#f4f4f5;--text-primary:#09090b;--text-secondary:#52525b;--text-label:#71717a;--accent:#22c55e;--border:#e4e4e7;--code-bg:#f4f4f5;--button-hover:#f1f1f2}[data-theme=dark]{--background:#050505;--background-soft:#080808;--surface:#09090b;--text-primary:#fff;--text-secondary:#a1a1aa;--text-label:#52525b;--accent:#4ade80;--border:#27272a;--code-bg:#09090b;--button-hover:#18181b}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--background);background-image:radial-gradient(circle at 10% -10%, color-mix(in srgb, var(--accent) 9%, transparent), transparent 42%), radial-gradient(circle at 90% -15%, color-mix(in srgb, var(--surface) 78%, transparent), transparent 46%), linear-gradient(to bottom, var(--background-soft), var(--background));color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Lexend,system-ui,-apple-system,sans-serif;line-height:1.6;transition:background-color .3s,color .3s}html{scroll-behavior:smooth}code,pre{font-family:JetBrains Mono,monospace}.container{max-width:60rem;margin:0 auto;padding:0 1.5rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-reveal{opacity:0;animation:.6s cubic-bezier(.16,1,.3,1) forwards slideUp}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.stagger-6{animation-delay:.6s}.stagger-7{animation-delay:.7s}.stagger-8{animation-delay:.8s}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#3f3f46}.layout{position:relative}.main-content{padding-bottom:3rem}.header{background:radial-gradient(circle at 10% -10%, color-mix(in srgb, var(--accent) 7%, transparent), transparent 42%), radial-gradient(circle at 90% -15%, color-mix(in srgb, var(--surface) 55%, transparent), transparent 46%), color-mix(in srgb, var(--background) 55%, transparent);-webkit-backdrop-filter:blur(20px);z-index:100;border-bottom:1px solid color-mix(in srgb, var(--border) 30%, transparent);padding:.75rem 0;position:sticky;top:0}.header-content{justify-content:space-between;align-items:center;gap:1rem;display:flex}.logo{flex-shrink:0;align-items:center;text-decoration:none;display:flex}.logo-image{width:108px;height:auto;display:block}.logo-image-dark,[data-theme=dark] .logo-image-light{display:none}[data-theme=dark] .logo-image-dark{display:block}.nav-pill{background:color-mix(in srgb, var(--surface) 45%, transparent);border:1px solid color-mix(in srgb, var(--border) 40%, transparent);-webkit-backdrop-filter:blur(8px);border-radius:999px;align-items:center;gap:.25rem;padding:.25rem;display:flex}.nav-pill-link{color:var(--text-label);letter-spacing:.01em;border-radius:999px;padding:.32rem .72rem;font-size:.78rem;font-weight:600;text-decoration:none;transition:color .2s,background .2s}.nav-pill-link:hover{color:var(--text-primary);background:color-mix(in srgb, var(--surface) 90%, transparent)}.nav-pill-link--active{color:var(--text-primary);background:var(--background);box-shadow:0 1px 3px #0000000f}[data-theme=dark] .nav-pill-link--active{background:var(--surface);box-shadow:0 1px 3px #0003}.nav-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.nav-icon-link{color:var(--text-label);border-radius:.4rem;padding:.3rem;transition:color .2s;display:inline-flex}.nav-icon-link:hover{color:var(--text-primary)}.nav-cta{border:1px solid var(--border);color:var(--text-secondary);letter-spacing:.02em;border-radius:999px;padding:.34rem .72rem;font-size:.74rem;font-weight:700;text-decoration:none;transition:all .2s}.nav-cta:hover{border-color:color-mix(in srgb, var(--accent) 55%, var(--border));color:var(--text-primary)}.theme-toggle-btn{color:var(--text-label);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:.45rem;justify-content:center;align-items:center;padding:.34rem;transition:all .2s;display:flex}.theme-toggle-btn:hover{background:var(--surface);border-color:var(--border);color:var(--text-primary)}.theme-toggle-btn:active{transform:scale(.96)}.hero{padding-top:4.5rem;padding-bottom:1.8rem}.hero-inner{grid-template-columns:1.2fr .8fr;align-items:center;gap:1.3rem;display:grid}.hero-copy{text-align:left}.hero-eyebrow{letter-spacing:.16em;color:var(--text-label);margin-bottom:.9rem;font-size:.7rem;font-weight:700}.hero-title{letter-spacing:-.03em;margin-bottom:1rem;font-size:clamp(2rem,5.4vw,3.8rem);font-weight:700;line-height:1.04}.hero-subtitle{color:var(--text-secondary);max-width:42rem;font-size:.98rem}.hero-actions{flex-wrap:wrap;gap:.7rem;margin-top:1.1rem;display:flex}.hero-btn{letter-spacing:.01em;border:1px solid #0000;border-radius:.7rem;justify-content:center;align-items:center;padding:.58rem .92rem;font-size:.8rem;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex}.hero-btn-primary{background:color-mix(in srgb, var(--accent) 20%, var(--surface));color:var(--accent);border-color:color-mix(in srgb, var(--accent) 52%, var(--border))}.hero-btn-primary:hover{border-color:color-mix(in srgb, var(--accent) 68%, var(--border));transform:translateY(-1px)}.hero-btn-secondary{background:var(--surface);color:var(--text-secondary);border-color:var(--border)}.hero-btn-secondary:hover{color:var(--text-primary);border-color:color-mix(in srgb, var(--accent) 48%, var(--border))}.hero-chips{flex-wrap:wrap;justify-content:flex-start;gap:.55rem;margin-top:1.35rem;display:flex}.hero-chip{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);letter-spacing:.01em;border-radius:999px;padding:.35rem .6rem;font-size:.74rem;font-weight:600}.hero-profile-card{background:color-mix(in srgb, var(--surface) 84%, transparent);border:1px solid var(--border);text-align:center;border-radius:1rem;justify-items:center;padding:1rem;display:grid}.hero-profile-image{object-fit:cover;border:1px solid color-mix(in srgb, var(--accent) 28%, var(--border));border-radius:.9rem;width:144px;height:144px;margin-bottom:.7rem}.hero-profile-name{letter-spacing:-.01em;font-size:1rem;font-weight:700}.hero-profile-role{color:var(--text-secondary);margin-top:.1rem;font-size:.84rem}.hero-profile-meta{color:var(--text-label);max-width:18rem;margin-top:.38rem;font-size:.78rem}.hero-status{border:1px solid color-mix(in srgb, var(--accent) 55%, var(--border));background:color-mix(in srgb, var(--accent) 13%, transparent);color:var(--accent);letter-spacing:.02em;border-radius:999px;align-items:center;gap:.35rem;margin-top:.7rem;padding:.24rem .58rem;font-size:.72rem;font-weight:700;display:inline-flex}.tech-section{padding:.9rem 0;scroll-margin-top:5.2rem}.tech-label{color:var(--text-label);text-transform:uppercase;letter-spacing:.14em;margin-bottom:.58rem;font-size:.69rem;font-weight:700}.tech-content{padding:.2rem 0}.code-block{margin:0;overflow-x:auto}.code-line{font-size:.82rem;line-height:1.72;display:block}.code-prompt{color:var(--accent);-webkit-user-select:none;user-select:none;margin-right:.5rem}.about-layout{grid-template-columns:1fr auto;align-items:start;gap:1.5rem;display:grid}.about-text{color:var(--text-secondary);font-size:.88rem;line-height:1.7}.about-highlights{flex-shrink:0;grid-template-columns:repeat(2,1fr);gap:.6rem;display:grid}.about-highlight{background:color-mix(in srgb, var(--surface) 85%, transparent);border:1px solid color-mix(in srgb, var(--border) 80%, transparent);text-align:center;border-radius:.7rem;gap:.05rem;min-width:5.5rem;padding:.55rem .72rem;transition:border-color .2s;display:grid}.about-highlight:hover{border-color:color-mix(in srgb, var(--accent) 45%, var(--border))}.about-highlight-value{color:var(--accent);font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:500}.about-highlight-label{color:var(--text-label);letter-spacing:.04em;text-transform:uppercase;font-size:.66rem;font-weight:600}.stack-grid{gap:.78rem;display:grid}.stack-category{border-bottom:1px dashed color-mix(in srgb, var(--border) 55%, transparent);grid-template-columns:8.5rem 1fr;align-items:baseline;gap:.8rem;padding:.4rem 0;display:grid}.stack-category:last-child{border-bottom:none}.stack-category-label{color:var(--accent);font-family:JetBrains Mono,monospace;font-size:.78rem;font-weight:500}.stack-items{flex-wrap:wrap;gap:.38rem;display:flex}.stack-chip{background:color-mix(in srgb, var(--surface) 90%, transparent);border:1px solid color-mix(in srgb, var(--border) 80%, transparent);color:var(--text-secondary);border-radius:999px;align-items:center;gap:.32rem;padding:.26rem .58rem;font-size:.74rem;font-weight:600;transition:border-color .2s,color .2s;display:inline-flex}.stack-chip:hover{border-color:color-mix(in srgb, var(--accent) 50%, var(--border));color:var(--text-primary)}.stack-chip-icon{opacity:.7;flex-shrink:0;font-size:.82rem;transition:opacity .2s}.stack-chip:hover .stack-chip-icon{opacity:1}.services-grid{grid-template-columns:repeat(2,1fr);gap:.7rem;display:grid}.service-card{background:color-mix(in srgb, var(--surface) 85%, transparent);border:1px solid color-mix(in srgb, var(--border) 80%, transparent);border-radius:.8rem;align-items:flex-start;gap:.7rem;padding:.78rem .85rem;transition:border-color .2s,transform .2s;display:flex}.service-card:hover{border-color:color-mix(in srgb, var(--accent) 45%, var(--border));transform:translateY(-1px)}.service-icon{background:color-mix(in srgb, var(--accent) 12%, transparent);border:1px solid color-mix(in srgb, var(--accent) 25%, var(--border));width:2rem;height:2rem;color:var(--accent);border-radius:.5rem;flex-shrink:0;justify-content:center;align-items:center;display:flex}.service-body{gap:.18rem;display:grid}.service-title{color:var(--text-primary);font-size:.84rem;font-weight:600}.service-desc{color:var(--text-secondary);font-size:.78rem;line-height:1.5}.project-link{color:inherit;border-bottom:1px dashed color-mix(in srgb, var(--accent) 45%, transparent);text-decoration:none}.project-link:hover{color:var(--text-primary);border-bottom-color:var(--accent)}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem;display:grid}.project-card{background:color-mix(in srgb, var(--surface) 85%, transparent);border:1px solid var(--border);border-radius:.9rem;gap:.68rem;padding:.92rem;transition:border-color .2s,transform .2s;display:grid}.project-card:hover{border-color:color-mix(in srgb, var(--accent) 45%, var(--border));transform:translateY(-1px)}.project-card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.project-heading{gap:.24rem;display:grid}.project-category{letter-spacing:.12em;color:var(--text-label);text-transform:uppercase;font-size:.64rem;font-weight:700}.project-title{color:var(--accent);font-family:JetBrains Mono,monospace;font-size:.9rem;line-height:1.3}.project-card-actions{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.project-github-btn{border:1px solid var(--border);color:var(--text-secondary);border-radius:999px;align-items:center;gap:.28rem;padding:.2rem .55rem;font-size:.72rem;font-weight:700;text-decoration:none;transition:border-color .2s,color .2s;display:inline-flex}.project-github-btn:hover{color:var(--text-primary);border-color:color-mix(in srgb, var(--accent) 50%, var(--border))}.project-details-btn{border:1px solid color-mix(in srgb, var(--accent) 55%, var(--border));background:color-mix(in srgb, var(--accent) 12%, transparent);color:var(--accent);border-radius:999px;align-items:center;gap:.28rem;padding:.2rem .55rem;font-size:.72rem;font-weight:700;text-decoration:none;transition:transform .2s,border-color .2s;display:inline-flex}.project-details-btn:hover{border-color:color-mix(in srgb, var(--accent) 72%, var(--border));transform:translateY(-1px)}.project-description{color:var(--text-secondary);font-size:.82rem;line-height:1.55}.project-stack-list{flex-wrap:wrap;gap:.42rem;display:flex}.project-stack-chip{border:1px solid color-mix(in srgb, var(--border) 80%, transparent);background:color-mix(in srgb, var(--background) 60%, transparent);color:var(--text-label);border-radius:999px;align-items:center;gap:.3rem;padding:.2rem .48rem;font-size:.69rem;font-weight:600;display:inline-flex}.project-highlights{gap:.4rem;display:grid}.project-highlight{color:var(--text-secondary);padding-left:.8rem;font-size:.74rem;line-height:1.55;position:relative}.project-highlight:before{content:"";background:color-mix(in srgb, var(--accent) 70%, transparent);border-radius:999px;width:.38rem;height:.38rem;position:absolute;top:.56rem;left:0}.project-footer{justify-content:space-between;align-items:center;gap:.6rem;display:flex}.project-repo-meta{color:var(--text-label);font-family:JetBrains Mono,monospace;font-size:.68rem}.project-secondary-link{color:var(--text-secondary);align-items:center;gap:.24rem;font-size:.72rem;font-weight:600;text-decoration:none;transition:color .2s;display:inline-flex}.project-secondary-link:hover{color:var(--accent)}.experience-summary{margin-bottom:.9rem}.experience-summary-text{color:var(--text-secondary);font-size:.84rem;line-height:1.65}.experience-summary-text strong{color:var(--text-primary);font-family:JetBrains Mono,monospace;font-weight:500}.experience-track{gap:.72rem;display:grid;position:relative}.experience-track:before{content:"";background:color-mix(in srgb, var(--border) 78%, transparent);width:1px;position:absolute;top:.35rem;bottom:.35rem;left:.42rem}.experience-card{grid-template-columns:.84rem 1fr;gap:.6rem;display:grid;position:relative}.experience-marker{border:2px solid color-mix(in srgb, var(--accent) 70%, var(--border));background:var(--background);border-radius:999px;width:.84rem;height:.84rem;margin-top:.86rem}.experience-card-body{background:color-mix(in srgb, var(--surface) 86%, transparent);border:1px solid color-mix(in srgb, var(--border) 80%, transparent);border-radius:.9rem;gap:.5rem;padding:.78rem .86rem;transition:border-color .2s,transform .2s;display:grid}.experience-card:hover{z-index:1}.experience-card:hover .experience-card-body{border-color:color-mix(in srgb, var(--accent) 45%, var(--border));transform:translateY(-1px)}.experience-header{align-items:flex-start;gap:.55rem;display:flex}.experience-logo-shell{border:1px solid color-mix(in srgb, var(--border) 75%, transparent);border-radius:.65rem;flex-shrink:0;justify-content:center;align-items:center;width:2.75rem;height:2.75rem;display:flex;overflow:hidden;box-shadow:0 1px 2px #0000000f}.experience-logo-shell--neutral{background:color-mix(in srgb, var(--background) 92%, transparent)}.experience-logo-shell--light{background:#fff;border-color:#d4d4d8cc}.experience-logo-shell--dark{background:#0f172a;border-color:#334155c7}[data-theme=dark] .experience-logo-shell--neutral{background:color-mix(in srgb, var(--surface) 88%, #fff 12%)}[data-theme=dark] .experience-logo-shell--light{background:#f8fafc}[data-theme=dark] .experience-logo-shell--dark{background:#020617}.experience-logo{object-fit:contain;border-radius:.45rem;width:100%;height:100%;padding:.22rem;display:block}.experience-meta{flex:1;gap:.14rem;min-width:0;display:grid}.experience-role{color:var(--accent);font-family:JetBrains Mono,monospace;font-size:.82rem;font-weight:500}.experience-company{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:.32rem;font-size:.82rem;display:flex}.experience-period,.experience-location{color:var(--text-label);font-size:.76rem}.experience-period strong{color:var(--text-secondary);font-weight:600}.experience-dot{opacity:.55}.experience-link{color:var(--text-secondary);text-underline-offset:2px;text-decoration:underline;transition:color .2s}.experience-link:hover{color:var(--accent)}.experience-badge{background:var(--accent);color:var(--background);text-transform:uppercase;letter-spacing:.06em;border-radius:999px;align-self:flex-start;padding:.08rem .4rem;font-size:.6rem;font-weight:700}.experience-desc{color:var(--text-secondary);font-size:.83rem;line-height:1.55}.experience-skills{flex-wrap:wrap;gap:.38rem;display:flex}.experience-skill-chip{border:1px solid color-mix(in srgb, var(--border) 80%, transparent);background:color-mix(in srgb, var(--background) 60%, transparent);color:var(--text-secondary);border-radius:999px;align-items:center;padding:.22rem .56rem;font-size:.69rem;font-weight:600;display:inline-flex}.experience-footer{justify-content:space-between;align-items:center;gap:.6rem;display:flex}.experience-order{color:var(--text-label);font-family:JetBrains Mono,monospace;font-size:.68rem}.experience-visit-link{color:var(--text-secondary);align-items:center;gap:.26rem;font-size:.73rem;font-weight:600;text-decoration:none;display:inline-flex}.experience-visit-link:hover{color:var(--text-primary)}.blogs-page{padding-top:3rem;padding-bottom:2rem}.blogs-header{gap:.5rem;margin-bottom:2rem;display:grid}.blogs-back{color:var(--text-label);align-items:center;gap:.3rem;margin-bottom:.5rem;font-size:.78rem;font-weight:600;text-decoration:none;transition:color .2s;display:inline-flex}.blogs-back:hover{color:var(--accent)}.blogs-title{letter-spacing:-.03em;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;line-height:1.1}.blogs-subtitle{color:var(--text-secondary);max-width:36rem;font-size:.9rem;line-height:1.6}.blogs-grid{gap:.85rem;display:grid}.blog-card{background:color-mix(in srgb, var(--surface) 85%, transparent);border:1px solid color-mix(in srgb, var(--border) 80%, transparent);color:inherit;cursor:pointer;border-radius:.9rem;text-decoration:none;transition:border-color .2s,transform .2s;display:grid;overflow:hidden}.blog-card:hover{border-color:color-mix(in srgb, var(--accent) 45%, var(--border));transform:translateY(-1px)}.blog-card-cover{object-fit:cover;width:100%;height:180px;display:block}.blog-card-content{gap:.6rem;padding:1rem 1.2rem 1.1rem;display:grid}.blog-card-meta{align-items:center;gap:.8rem;display:flex}.blog-card-date,.blog-card-read{color:var(--text-label);align-items:center;gap:.28rem;font-family:JetBrains Mono,monospace;font-size:.72rem;display:inline-flex}.blog-card-title{color:var(--text-primary);letter-spacing:-.01em;font-size:1rem;font-weight:700;line-height:1.35}.blog-card:hover .blog-card-title{color:var(--accent)}.blog-card-excerpt{color:var(--text-secondary);font-size:.82rem;line-height:1.6}.blog-card-footer{justify-content:space-between;align-items:center;gap:.6rem;margin-top:.2rem;display:flex}.blog-card-tags{flex-wrap:wrap;gap:.35rem;display:flex}.blog-card-tag{border:1px solid color-mix(in srgb, var(--border) 80%, transparent);background:color-mix(in srgb, var(--background) 60%, transparent);color:var(--text-label);border-radius:999px;padding:.18rem .5rem;font-size:.68rem;font-weight:600;display:inline-flex}.blog-card-link{color:var(--text-label);flex-shrink:0;align-items:center;gap:.2rem;font-size:.76rem;font-weight:600;transition:color .2s;display:inline-flex}.blog-card:hover .blog-card-link{color:var(--accent)}.blog-detail{max-width:48rem;padding-top:3rem;padding-bottom:2rem}.blog-detail-header{gap:.6rem;margin-bottom:1.5rem;display:grid}.blog-detail-tags{flex-wrap:wrap;gap:.35rem;display:flex}.blog-detail-title{letter-spacing:-.03em;font-size:clamp(1.5rem,4vw,2.2rem);font-weight:700;line-height:1.15}.blog-detail-meta{align-items:center;gap:.8rem;display:flex}.blog-detail-cover{border:1px solid color-mix(in srgb, var(--border) 60%, transparent);border-radius:.9rem;margin-bottom:2rem;overflow:hidden}.blog-detail-cover-img{object-fit:cover;width:100%;height:auto;max-height:380px;display:block}.blog-detail-body{gap:1rem;display:grid}.blog-body-h2{color:var(--text-primary);letter-spacing:-.01em;margin-top:.5rem;font-size:1.15rem;font-weight:700}.blog-body-p{color:var(--text-secondary);font-size:.88rem;line-height:1.75}.blog-body-p strong{color:var(--text-primary);font-weight:600}.blog-body-p code{background:var(--surface);border:1px solid var(--border);color:var(--accent);border-radius:.3rem;padding:.1rem .35rem;font-size:.8rem}.blog-body-code{background:var(--code-bg);border:1px solid var(--border);color:var(--text-secondary);border-radius:.7rem;padding:1rem 1.1rem;font-family:JetBrains Mono,monospace;font-size:.78rem;line-height:1.7;overflow-x:auto}.blog-body-list{gap:.4rem;padding-left:1.2rem;display:grid}.blog-body-list li{color:var(--text-secondary);font-size:.88rem;line-height:1.7}.blog-body-list li strong{color:var(--text-primary);font-weight:600}.blog-detail-footer{border-top:1px solid color-mix(in srgb, var(--border) 40%, transparent);margin-top:2rem;padding-top:1.5rem}.project-detail{padding-top:3rem;padding-bottom:2rem}.project-detail-header{gap:.8rem;margin-bottom:1.5rem;display:grid}.project-detail-meta-row{flex-wrap:wrap;align-items:center;gap:.55rem;display:flex}.project-detail-category{border:1px solid color-mix(in srgb, var(--accent) 45%, var(--border));background:color-mix(in srgb, var(--accent) 12%, transparent);color:var(--accent);letter-spacing:.04em;text-transform:uppercase;border-radius:999px;align-items:center;padding:.22rem .55rem;font-size:.68rem;font-weight:700;display:inline-flex}.project-detail-repo{color:var(--text-label);align-items:center;gap:.28rem;font-family:JetBrains Mono,monospace;font-size:.74rem;display:inline-flex}.project-detail-title{letter-spacing:-.03em;font-size:clamp(1.6rem,4vw,2.5rem);font-weight:700;line-height:1.08}.project-detail-description{max-width:48rem;color:var(--text-secondary);font-size:.94rem;line-height:1.7}.project-detail-links{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.project-detail-link-primary,.project-detail-link-secondary{border-radius:999px;align-items:center;gap:.35rem;padding:.42rem .8rem;font-size:.76rem;font-weight:700;text-decoration:none;transition:transform .2s,border-color .2s,color .2s;display:inline-flex}.project-detail-link-primary{background:color-mix(in srgb, var(--accent) 14%, transparent);border:1px solid color-mix(in srgb, var(--accent) 50%, var(--border));color:var(--accent)}.project-detail-link-secondary{border:1px solid var(--border);color:var(--text-secondary)}.project-detail-link-primary:hover,.project-detail-link-secondary:hover{transform:translateY(-1px)}.project-detail-link-secondary:hover{color:var(--text-primary);border-color:color-mix(in srgb, var(--accent) 45%, var(--border))}.project-detail-grid{grid-template-columns:minmax(0,1.45fr) minmax(18rem,.8fr);align-items:start;gap:1rem;display:grid}.project-detail-main,.project-detail-sidebar{gap:.9rem;display:grid}.project-detail-block,.project-detail-panel{background:color-mix(in srgb, var(--surface) 85%, transparent);border:1px solid color-mix(in srgb, var(--border) 80%, transparent);border-radius:.95rem;padding:1rem 1.05rem}.project-detail-block-title,.project-detail-panel-title{color:var(--text-primary);letter-spacing:-.01em;margin-bottom:.72rem;font-size:.92rem;font-weight:700}.project-detail-copy{gap:.85rem;display:grid}.project-detail-paragraph{color:var(--text-secondary);font-size:.88rem;line-height:1.78}.project-detail-highlight-list,.project-detail-tech-list{flex-wrap:wrap;gap:.48rem;display:flex}.project-detail-highlight{width:100%;color:var(--text-secondary);background:color-mix(in srgb, var(--background) 58%, transparent);border:1px solid color-mix(in srgb, var(--border) 70%, transparent);border-radius:.8rem;padding:.7rem .78rem;font-size:.8rem;line-height:1.6}.project-detail-tech-chip{border:1px solid color-mix(in srgb, var(--border) 80%, transparent);background:color-mix(in srgb, var(--background) 58%, transparent);color:var(--text-secondary);border-radius:999px;align-items:center;padding:.28rem .62rem;font-size:.72rem;font-weight:600;display:inline-flex}.site-footer{border-top:1px solid color-mix(in srgb, var(--border) 40%, transparent);background:radial-gradient(circle at 90% 110%, color-mix(in srgb, var(--accent) 6%, transparent), transparent 42%), radial-gradient(circle at 10% 115%, color-mix(in srgb, var(--surface) 50%, transparent), transparent 46%), color-mix(in srgb, var(--background) 60%, transparent);-webkit-backdrop-filter:blur(16px);margin-top:1.5rem}.footer-inner{gap:1.5rem;padding:2rem 1.5rem 1.5rem;display:grid}.footer-top{justify-content:space-between;align-items:center;gap:1rem;display:flex}.footer-brand{gap:.2rem;display:grid}.footer-name{color:var(--text-primary);letter-spacing:-.01em;font-size:.88rem;font-weight:700}.footer-tagline{color:var(--text-label);font-size:.76rem}.footer-socials{gap:.25rem;display:flex}.footer-social-link{width:2rem;height:2rem;color:var(--text-label);border:1px solid #0000;border-radius:.45rem;justify-content:center;align-items:center;transition:all .2s;display:inline-flex}.footer-social-link:hover{color:var(--text-primary);background:var(--surface);border-color:var(--border)}.footer-bottom{border-top:1px solid color-mix(in srgb, var(--border) 30%, transparent);color:var(--text-label);justify-content:center;align-items:center;gap:.4rem;padding-top:1rem;font-size:.72rem;display:flex}.footer-dot{opacity:.4}.gh-loading{align-items:center;gap:.5rem;padding:.4rem 0;display:flex}.gh-loading-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.3}50%{opacity:1}}.gh-loading-text{color:var(--text-secondary);font-size:.82rem}.gh-contrib-total{color:var(--text-secondary);margin-bottom:.72rem;font-size:.82rem}.gh-contrib-count{color:var(--text-primary);font-family:JetBrains Mono,monospace;font-weight:500}.gh-graph-wrapper{gap:.55rem;display:grid}.gh-graph-scroll{gap:.3rem;padding-bottom:.25rem;display:flex;overflow-x:auto}.gh-graph-scroll::-webkit-scrollbar{height:4px}.gh-graph-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.gh-day-labels{flex-shrink:0;grid-template-rows:repeat(7,1fr);gap:3px;padding-top:1.4rem;display:grid}.gh-day-label{color:var(--text-label);text-align:right;height:12px;padding-right:.3rem;font-family:JetBrains Mono,monospace;font-size:.62rem;line-height:12px}.gh-graph-main{flex:1;gap:3px;min-width:0;display:grid}.gh-month-row{gap:3px;height:1.1rem;display:grid}.gh-month-label{color:var(--text-label);font-family:JetBrains Mono,monospace;font-size:.62rem;line-height:1.1rem}.gh-grid{gap:3px;display:grid}.gh-week{grid-template-rows:repeat(7,1fr);gap:3px;display:grid}.gh-cell{border-radius:2px;width:12px;height:12px;transition:outline .1s}.gh-cell[data-empty]{visibility:hidden}.gh-cell:not([data-empty]):hover{outline:1.5px solid var(--text-secondary);outline-offset:.5px}.gh-level-0{background:color-mix(in srgb, var(--border) 50%, var(--surface))}.gh-level-1{background:#9be9a8}.gh-level-2{background:#40c463}.gh-level-3{background:#30a14e}.gh-level-4{background:#216e39}[data-theme=dark] .gh-level-0{background:#161b22}[data-theme=dark] .gh-level-1{background:#0e4429}[data-theme=dark] .gh-level-2{background:#006d32}[data-theme=dark] .gh-level-3{background:#26a641}[data-theme=dark] .gh-level-4{background:#39d353}.gh-legend{justify-content:flex-end;align-items:center;gap:3px;display:flex}.gh-legend .gh-cell{cursor:default}.gh-legend .gh-cell:hover{outline:none}.gh-legend-text{color:var(--text-label);padding:0 .25rem;font-family:JetBrains Mono,monospace;font-size:.62rem}.gh-profile-link{color:var(--text-secondary);border-bottom:1px dashed color-mix(in srgb, var(--accent) 40%, transparent);align-items:center;gap:.32rem;margin-top:.35rem;font-size:.78rem;font-weight:600;text-decoration:none;transition:color .2s;display:inline-flex}.gh-profile-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.gh-inline-link{color:var(--accent);border-bottom:1px dashed var(--accent);text-decoration:none}.gh-inline-link:hover{color:var(--text-primary)}@media (width<=960px){.logo-image{width:102px}.nav-pill,.nav-icon-link,.nav-cta{display:none}.hero-inner{grid-template-columns:1fr}.hero-copy{text-align:center}.hero-actions,.hero-chips{justify-content:center}.hero-profile-card{max-width:24rem;margin:0 auto}.project-grid,.project-detail-grid,.about-layout{grid-template-columns:1fr}.about-highlights{grid-template-columns:repeat(4,1fr)}.services-grid{grid-template-columns:1fr}}@media (width<=640px){.header{padding:.65rem 0}.logo-image{width:92px}.nav-actions{gap:.35rem}.hero{padding-top:3.4rem;padding-bottom:1.1rem}.hero-subtitle{font-size:.9rem}.hero-actions{flex-direction:column}.hero-btn{width:100%}.hero-profile-image{width:124px;height:124px}.tech-content{padding:.92rem}.about-highlights{grid-template-columns:repeat(2,1fr)}.stack-category{grid-template-columns:1fr;gap:.35rem}.experience-track:before{left:.35rem}.experience-card{grid-template-columns:.7rem 1fr;gap:.45rem}.experience-marker{width:.7rem;height:.7rem;margin-top:.9rem}.experience-card-body{padding:.72rem}.experience-header{flex-wrap:wrap;align-items:flex-start}.project-card-header,.project-footer{flex-direction:column;align-items:flex-start}.project-card-actions,.project-detail-links{flex-wrap:wrap}.footer-top{text-align:center;flex-direction:column}.footer-socials{justify-content:center}}
