@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}.absolute{position:absolute}.contents{display:contents}.flex{display:flex}.table{display:table}.flex-shrink{flex-shrink:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}:root{--container-width:1100px;--bg:#fff;--text:#111827;--muted:#6b7280;--card:#fff;--border:#0f172a0f;--bg-r:255;--bg-g:255;--bg-b:255;--nav-alpha:.6;--nav-bg:rgba(var(--bg-r), var(--bg-g), var(--bg-b), var(--nav-alpha))}.dark{--bg:#121212;--text:#e6e6e6;--muted:#9ca3af;--card:#1e1e1e;--border:#ffffff1f;--bg-r:18;--bg-g:18;--bg-b:18;--nav-alpha:.5;--nav-bg:rgba(var(--bg-r), var(--bg-g), var(--bg-b), var(--nav-alpha))}html,body{height:100%;color:var(--text);background:var(--bg);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial}.tech-stack{flex-wrap:wrap;align-items:center;gap:.6rem;margin-top:.6rem;display:flex}.tech-item{background:var(--card);border:1px solid var(--border);border-radius:8px;justify-content:center;align-items:center;width:42px;height:42px;display:flex;box-shadow:0 6px 18px #0206170a}.tech-item img{object-fit:contain;width:60%;height:60%;display:block}.tech-stack.small{gap:.4rem}.tech-pill.small{width:36px;height:36px}.tech-pill.small img{width:60%;height:60%}.tech-stack .tech-pill.text.small{height:32px;padding:0 .5rem;font-size:.85rem}.socials{align-items:center;gap:.5rem;display:flex}.socials a.social-icon{background:var(--card);border:1px solid var(--border);border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;text-decoration:none;transition:transform .12s,box-shadow .12s;display:inline-flex}.socials a.social-icon img{object-fit:contain;width:60%;height:60%;display:block}.socials a.social-icon:hover{transform:translateY(-3px)scale(1.05);box-shadow:0 8px 22px #0206170f}.footer-container .links{align-items:center;gap:1rem;display:flex}.nav-container .theme-toggle{margin-left:1rem}img{max-width:100%;display:block}.container{max-width:var(--container-width);margin:0 auto;padding:0 1rem}.project-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-top:1rem;display:grid}.project-card{background:var(--card);border:1px solid var(--border);border-radius:12px;flex-direction:column;padding:1rem;transition:transform .16s,box-shadow .16s;display:flex;overflow:hidden;box-shadow:0 6px 18px #0206170a}.project-card:hover{transform:translateY(-6px);box-shadow:0 12px 30px #02061714}.project-image-wrap{border-radius:8px;width:100%;height:160px;position:relative;overflow:hidden}.project-image{object-fit:cover;width:100%;height:100%;display:block}.project-badge{background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:.15rem .5rem;font-size:.75rem;position:absolute;top:10px;left:10px}.project-body{flex-direction:column;flex-grow:1;gap:.5rem;padding-top:.75rem;display:flex}.project-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.project-card .project-title{color:var(--text);font-weight:700;text-decoration:none}.project-role{background:var(--card);border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:.15rem .5rem;font-size:.85rem}.project-stack-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.tech-pill{background:var(--card);border:1px solid var(--border);border-radius:8px;justify-content:center;align-items:center;width:48px;height:48px;transition:transform .12s,box-shadow .12s;display:inline-flex;position:relative;box-shadow:0 6px 18px #0206170a}.tech-pill img{object-fit:contain;width:60%;height:60%;display:block}.tech-pill.text{border-radius:8px;width:auto;height:40px;padding:0 .75rem;font-size:.95rem}.tech-pill:hover{transform:translateY(-3px)scale(1.05);box-shadow:0 8px 22px #0206170f}.tech-pill:after{content:attr(data-label);opacity:0;pointer-events:none;background:var(--card);color:var(--text);border:1px solid var(--border);white-space:nowrap;z-index:40;border-radius:6px;padding:.25rem .5rem;font-size:.75rem;transition:opacity .12s,transform .12s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(6px)}.tech-pill:hover:after{opacity:1;transform:translate(-50%)translateY(0)}.project-footer{justify-content:flex-end;margin-top:auto;display:flex}.project-date{color:var(--muted);font-size:.9rem}.post-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1rem;margin-top:1rem;display:grid}.post-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1rem;transition:transform .16s,box-shadow .16s}.post-card:hover{transform:translateY(-6px);box-shadow:0 12px 30px #02061714}.blog-list{--date-col-width:220px;--timeline-col-width:48px;flex-direction:column;gap:1rem;margin-top:1rem;display:flex;position:relative}.blog-row{grid-template-columns:var(--date-col-width) var(--timeline-col-width) 1fr;align-items:center;gap:1rem;display:grid}.blog-date{flex-direction:column;gap:.75rem;display:flex}.date-box{background:var(--card);border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:.75rem 1rem;font-size:.95rem}.blog-timeline{justify-content:center;align-items:center;display:flex;position:relative}.blog-timeline .dot{background:var(--muted);border-radius:999px;width:12px;height:12px;margin:0;display:inline-block}.blog-list:before{content:"";left:calc(var(--date-col-width) + 1rem + (var(--timeline-col-width) / 2));background:var(--border);z-index:1;border-radius:2px;width:2px;position:absolute;top:0;bottom:0;transform:translate(-50%)}.blog-timeline{z-index:2}.blog-timeline .dot{z-index:3}.post-card-inner{align-items:center;gap:1rem;display:flex}.post-body{flex:1}.post-image-wrap{border-radius:8px;flex-shrink:0;width:220px;height:88px;overflow:hidden}.post-image-wrap img{object-fit:cover;width:100%;height:100%;display:block}.project-card .tech-pill{width:36px;height:36px}.project-card .tech-pill img{width:60%;height:60%}.theme-toggle{border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--text);background:0 0;border-radius:8px;justify-content:center;align-items:center;padding:0;font-size:0;display:inline-flex}a{color:inherit;text-decoration:none}.empty-state{background:var(--card);border:1px solid var(--border);text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:.5rem;max-width:680px;margin:1.25rem auto;padding:1.5rem;display:flex}.empty-state svg{width:56px;height:56px;color:var(--muted)}.empty-state h3{margin:.25rem 0 0}.empty-state .muted{color:var(--muted);margin:0}.post-desc{color:var(--muted);margin-top:.5rem}.post-dates small{color:var(--muted);align-items:center;gap:.5rem;font-size:.95rem;display:inline-flex}.post-dates .sep{vertical-align:middle;width:1em;height:1em;color:var(--muted);justify-content:center;align-items:center;font-size:1rem;line-height:1;display:inline-flex}.date-box .published{display:block}.date-box .updated{color:var(--muted);margin-top:.25rem;font-size:.95rem;display:block}.page-header{align-items:center;gap:.75rem;display:flex}.page-header h1{margin:0}.rss-button{background:var(--card);border:1px solid var(--border);width:36px;height:36px;color:var(--muted);border-radius:8px;justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.rss-button svg{stroke:currentColor;display:block}.rss-button:hover{color:var(--text);transition:color .12s,transform .12s;transform:translateY(-2px)}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}.site-nav[data-astro-cid-5blmo7yk]{border-bottom:1px solid rgba(var(--bg-r),var(--bg-g),var(--bg-b),.12);background:linear-gradient(180deg,rgba(var(--bg-r),var(--bg-g),var(--bg-b),.65),rgba(var(--bg-r),var(--bg-g),var(--bg-b),.48));backdrop-filter:blur(10px) saturate(120%);-webkit-backdrop-filter:blur(10px) saturate(120%);position:sticky;top:0;z-index:60;box-shadow:0 6px 18px #0206170f}.nav-container[data-astro-cid-5blmo7yk]{max-width:1100px;margin:0 auto;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand[data-astro-cid-5blmo7yk]{font-weight:700;color:var(--text);text-decoration:none}nav[data-astro-cid-5blmo7yk]{display:flex;align-items:center;gap:1rem}nav[data-astro-cid-5blmo7yk] a[data-astro-cid-5blmo7yk]{margin:0;color:var(--muted);text-decoration:none;font-weight:500}nav[data-astro-cid-5blmo7yk] a[data-astro-cid-5blmo7yk]:hover{color:var(--text);transform:translateY(-2px);transition:color .12s ease,transform .12s ease}@media(max-width:640px){nav[data-astro-cid-5blmo7yk] a[data-astro-cid-5blmo7yk]{margin-left:.75rem}}.site-footer[data-astro-cid-sz7xmlte]{border-top:1px solid var(--border);background:var(--nav-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:1.5rem 1rem}.footer-container[data-astro-cid-sz7xmlte]{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem}.meta[data-astro-cid-sz7xmlte] p[data-astro-cid-sz7xmlte]{margin:.25rem 0 0;color:var(--muted)}.socials[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{margin-right:.75rem;color:var(--muted);text-decoration:none}.socials[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--text)}.copyright[data-astro-cid-sz7xmlte]{color:var(--muted);font-size:.9rem}@media(max-width:640px){.footer-container[data-astro-cid-sz7xmlte]{flex-direction:column;align-items:flex-start}}:root{--container-width: 1100px}html,body{margin:0;width:100%;height:100%;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;color:var(--text);background:var(--bg)}main[data-astro-cid-sckkx6r4]{max-width:var(--container-width);margin:0 auto;padding:2rem 1rem;min-height:calc(100vh - 160px)}.site-nav[data-astro-cid-sckkx6r4]{border-bottom:1px solid rgba(var(--bg-r),var(--bg-g),var(--bg-b),.12);background:linear-gradient(180deg,rgba(var(--bg-r),var(--bg-g),var(--bg-b),.65),rgba(var(--bg-r),var(--bg-g),var(--bg-b),.48));backdrop-filter:blur(10px) saturate(120%);-webkit-backdrop-filter:blur(10px) saturate(120%);position:sticky;top:0;z-index:60;box-shadow:0 6px 18px #0206170f}.nav-container[data-astro-cid-sckkx6r4]{max-width:1100px;margin:0 auto;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand[data-astro-cid-sckkx6r4]{font-weight:700;color:var(--text);text-decoration:none}nav[data-astro-cid-sckkx6r4] a[data-astro-cid-sckkx6r4]{margin-left:1rem;color:var(--muted);text-decoration:none;font-weight:500}nav[data-astro-cid-sckkx6r4] a[data-astro-cid-sckkx6r4]:hover{color:var(--text)}@media(max-width:640px){nav[data-astro-cid-sckkx6r4] a[data-astro-cid-sckkx6r4]{margin-left:.75rem}}.site-footer[data-astro-cid-sckkx6r4]{border-top:1px solid var(--border);background:var(--nav-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:2rem 1rem}.footer-container[data-astro-cid-sckkx6r4]{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem}.meta[data-astro-cid-sckkx6r4] p[data-astro-cid-sckkx6r4]{margin:.25rem 0 0;color:var(--muted)}.socials[data-astro-cid-sckkx6r4] a[data-astro-cid-sckkx6r4]{margin-right:.75rem;color:var(--muted);text-decoration:none}.socials[data-astro-cid-sckkx6r4] a[data-astro-cid-sckkx6r4]:hover{color:var(--text)}.copyright[data-astro-cid-sckkx6r4]{color:var(--muted);font-size:.9rem}@media(max-width:640px){.footer-container[data-astro-cid-sckkx6r4]{flex-direction:column;align-items:flex-start}}
