@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-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-gruvbox-bg:#1d2021;--color-gruvbox-fg:#ebdbb2;--color-gruvbox-accent:#fabd2f;--color-gruvbox-border:#3c3836}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}:root{--bg:#1d2021;--bg0:#0d0e0f;--bg1:#282828;--bg2:#3c3836;--bg3:#504945;--bg4:#665c54;--fg:#ebdbb2;--fg2:#d5c4a1;--fg3:#bdae93;--muted:#a89984;--accent:#fabd2f;--accent2:#fe8019;--green:#b8bb26;--blue:#83a598;--red:#fb4934;--purple:#d3869b;--aqua:#8ec07c;--border:#3c3836;--border2:#504945;--code-bg:#0d0e0f;--tag-bg:#fabd2f1a;--tag:#fabd2f;--shadow-sm:0 1px 4px #00000080;--shadow-md:0 4px 16px #0009;--shadow-lg:0 8px 32px #000000b3;--nav-bg:#0d0e0ff2;--hero-dot:var(--bg2);--footer-bg:#0d0e0f}body{background-color:var(--bg);color:var(--fg);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;line-height:1.75}a{color:var(--accent);text-decoration:none;transition:color .15s}a:hover{color:var(--accent2)}}@layer components{nav{background:var(--nav-bg);border-bottom:1px solid var(--border);z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;height:58px;padding:0 2rem;display:flex;position:sticky;top:0}.nav-brand{color:var(--accent);letter-spacing:-.01em;font-size:1rem;font-weight:800}.nav-brand:hover{color:var(--accent2)}.nav-links{gap:1.5rem;list-style:none;display:flex}.nav-links a{color:var(--muted);border-bottom:2px solid #0000;padding:.25rem 0;font-size:.875rem;font-weight:500;transition:color .15s}.nav-links a:hover,.nav-links a.active{color:var(--fg);border-bottom-color:var(--accent)}.container{max-width:1100px;margin:0 auto;padding:3rem 2rem}.container-narrow{max-width:780px;margin:0 auto;padding:3rem 2rem}.hero{text-align:center;margin-bottom:3rem;padding:5rem 1rem 4rem;position:relative;overflow:hidden}.hero:before{content:"";background-image:radial-gradient(circle,var(--hero-dot) 1px,transparent 1px);opacity:.45;pointer-events:none;background-size:28px 28px;position:absolute;inset:0}.hero:after{content:"";background:radial-gradient(ellipse at center,transparent 40%,var(--bg) 80%);pointer-events:none;position:absolute;inset:0}.hero-inner{z-index:1;position:relative}.hero-label{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:var(--tag-bg);border:1px solid #fabd2f40;border-radius:20px;margin-bottom:1.25rem;padding:.25rem .85rem;font-size:.75rem;font-weight:700;display:inline-block}.hero h1{letter-spacing:-.03em;background:linear-gradient(135deg,var(--fg) 0%,var(--accent) 55%,var(--accent2) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;font-size:3rem;font-weight:900;line-height:1.15}.hero p{color:var(--fg3);max-width:520px;margin:0 auto 1.75rem;font-size:1.15rem;line-height:1.7}.hero-cta{background:var(--accent);color:var(--bg0);border-radius:8px;align-items:center;gap:.5rem;padding:.65rem 1.4rem;font-size:.9rem;font-weight:700;transition:background .15s,transform .15s;display:inline-flex}.hero-cta:hover{background:var(--accent2);color:var(--bg0);transform:translateY(-2px)}.section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;margin-bottom:1.75rem;padding-bottom:.75rem;display:flex}.section-header h2{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:.8rem;font-weight:700}.section-header span{color:var(--muted);font-size:.8rem}.project-list{grid-template-columns:repeat(2,1fr);gap:1.25rem;list-style:none;display:grid}.project-card{background:var(--bg1);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:.75rem;padding:1.5rem;transition:transform .18s,border-color .18s,box-shadow .18s;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";background:linear-gradient(90deg,var(--accent),var(--accent2));opacity:0;height:3px;transition:opacity .18s;position:absolute;top:0;left:0;right:0}.project-card:hover{border-color:var(--border2);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.project-card:hover:before{opacity:1}.project-card--hero{grid-column:1/-1;min-height:260px;padding:2.5rem}.project-card-bg{object-fit:cover;object-position:left center;opacity:.07;z-index:0;pointer-events:none;transform-origin:0;width:auto;height:100%;position:absolute;inset:0 0 0 45%;transform:scale(1.8)}.project-card--hero>:not(.project-card-bg):not(.featured-badge){z-index:1;position:relative}.project-card--hero>.featured-badge{z-index:2}.featured-badge{letter-spacing:.08em;text-transform:uppercase;color:var(--bg0);background:var(--accent);border-radius:20px;padding:.2rem .55rem;font-size:.68rem;font-weight:700;position:absolute;top:1rem;right:1rem}.project-card-header{padding-right:4rem}.project-card h2{margin:0;font-size:1.2rem;font-weight:700;line-height:1.3}.project-card h2 a{color:var(--fg)}.project-card h2 a:hover{color:var(--accent)}.project-desc{color:var(--fg3);flex:1;font-size:.92rem;line-height:1.65}.project-tech{flex-wrap:wrap;gap:.4rem;display:flex}.project-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:auto;padding-top:.75rem;display:flex}.project-link{color:var(--accent);align-items:center;gap:.3rem;font-size:.85rem;font-weight:600;transition:gap .15s;display:inline-flex}.project-link:hover{gap:.6rem}.tag{background:var(--tag-bg);color:var(--tag);letter-spacing:.02em;border:1px solid #fabd2f33;border-radius:20px;padding:.15rem .6rem;font-size:.7rem;font-weight:600;display:inline-block}.post-list{list-style:none}.post-card{border-bottom:1px solid var(--border);padding:1.5rem 0;transition:all .15s}.post-card:last-child{border-bottom:none}.post-card h2{margin-bottom:.35rem;font-size:1.2rem;font-weight:600}.post-card h2 a{color:var(--fg)}.post-card h2 a:hover{color:var(--accent)}.post-meta{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.post-date{color:var(--muted);font-size:.8rem}.post-excerpt{color:var(--fg3);font-size:.92rem}.post-header{border-bottom:1px solid var(--border);margin-bottom:2rem;padding-bottom:1.5rem}.post-header h1{letter-spacing:-.02em;margin-bottom:.75rem;font-size:2rem;font-weight:800}.post-content h2{border-bottom:1px solid var(--border);margin:2rem 0 .75rem;padding-bottom:.4rem;font-size:1.4rem;font-weight:700}.post-content h3{color:var(--aqua);margin:1.5rem 0 .5rem;font-size:1.1rem;font-weight:600}.post-content p{margin-bottom:1rem}.post-content ul,.post-content ol{margin-bottom:1rem;padding-left:1.5rem}.post-content li{margin-bottom:.3rem}.post-content strong{color:var(--fg)}.post-content blockquote{border-left:3px solid var(--accent);background:var(--bg1);color:var(--fg3);border-radius:0 6px 6px 0;margin:1.25rem 0;padding:.75rem 1rem}.post-content hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.post-content code{background:var(--bg1);color:var(--green);border-radius:4px;padding:.15em .45em;font-family:Fira Code,JetBrains Mono,Menlo,Consolas,monospace;font-size:.875em}.post-content pre{background:var(--code-bg);border:1px solid var(--border);border-radius:8px;margin-bottom:1.25rem;padding:1.25rem;overflow-x:auto}.post-content pre code{color:var(--fg2);background:0 0;padding:0;font-size:.85rem}.kw{color:#fb4934}.str{color:#b8bb26}.fn{color:#83a598}.cm{color:#7c6f64;font-style:italic}.num{color:#d3869b}.tp{color:#fabd2f}.post-content table{border-collapse:collapse;width:100%;margin-bottom:1.25rem;font-size:.9rem}.post-content th{background:var(--bg1);text-align:left;border:1px solid var(--border);color:var(--fg);padding:.6rem 1rem;font-weight:600}.post-content td{border:1px solid var(--border);color:var(--fg3);padding:.6rem 1rem}.post-content tr:nth-child(2n) td{background:#3c38364d}.post-content img{border:1px solid var(--border);border-radius:8px;max-width:100%;margin:1rem 0}.video-wrap{border:1px solid var(--border);height:0;box-shadow:var(--shadow-md);border-radius:10px;margin:1.25rem 0;padding-bottom:56.25%;position:relative;overflow:hidden}.video-wrap iframe{border:none;width:100%;height:100%;position:absolute;top:0;left:0}.timeline{margin:1.5rem 0;padding-left:1.75rem;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom,var(--accent),var(--border));width:2px;position:absolute;top:0;bottom:0;left:0}.tl-item{margin-bottom:1.75rem;position:relative}.tl-item:before{content:"";background:var(--accent);border:2px solid var(--bg);border-radius:50%;width:10px;height:10px;position:absolute;top:.4rem;left:-1.875rem;box-shadow:0 0 0 3px #fabd2f26}.tl-date{color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.2rem;font-size:.78rem;font-weight:700}.tl-item h3{color:var(--fg);margin-bottom:.3rem;font-size:1.05rem}.tl-item p{color:var(--fg3);font-size:.92rem}.personal-info{text-align:center;margin-bottom:1rem;padding:2rem 0}.personal-name{letter-spacing:-.02em;background:linear-gradient(135deg,var(--fg) 0%,var(--accent) 55%,var(--accent2) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.75rem;font-size:2rem;font-weight:900}.personal-bio{color:var(--fg3);max-width:520px;margin:0 auto;font-size:1.05rem;line-height:1.7}.back{color:var(--muted);align-items:center;gap:.4rem;margin-bottom:2rem;font-size:.875rem;transition:color .15s,gap .15s;display:inline-flex}.back:hover{color:var(--accent);gap:.6rem}.project-hero{border-bottom:1px solid var(--border);margin-bottom:2.5rem;padding:2rem 0}.project-hero h1{letter-spacing:-.03em;background:linear-gradient(135deg,var(--fg) 0%,var(--accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.75rem;font-size:2.2rem;font-weight:900}.project-repo-link{align-items:center;gap:.4rem;margin-top:1rem;font-size:.875rem;font-weight:600;display:inline-flex}.section-title{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:.5rem;font-size:.78rem;font-weight:700}.project-screenshot{border:1px solid var(--border);box-shadow:var(--shadow-md);border-radius:10px;margin:2rem 0;overflow:hidden}.project-image{aspect-ratio:auto;object-fit:cover;width:100%;max-width:100%;height:auto;display:block}.image-blend{object-fit:cover;object-position:left center;opacity:.06;pointer-events:none;z-index:-1;width:60%;height:100vh;position:fixed;top:0;bottom:0;right:0}footer{border-top:1px solid var(--border);background:var(--footer-bg);margin-top:4rem}.footer-inner{grid-template-columns:1fr auto;align-items:start;gap:2rem;max-width:1100px;margin:0 auto;padding:3rem 2rem 2rem;display:grid}.footer-brand{color:var(--accent);margin-bottom:.5rem;font-size:1.1rem;font-weight:800;display:block}.footer-tagline{color:var(--muted);max-width:320px;margin-bottom:1.25rem;font-size:.875rem;line-height:1.6}.footer-cta{background:var(--tag-bg);color:var(--accent);border:1px solid #fabd2f40;border-radius:8px;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;transition:background .15s,border-color .15s;display:inline-flex}.footer-cta:hover{border-color:var(--accent);color:var(--accent);background:#fabd2f33}.footer-links{text-align:right;flex-direction:column;gap:.5rem;display:flex}.footer-links a{color:var(--muted);font-size:.875rem;font-weight:500;transition:color .15s}.footer-links a:hover{color:var(--fg)}.footer-bottom{border-top:1px solid var(--border);max-width:1100px;color:var(--bg3);margin:0 auto;padding:1rem 2rem 1.5rem;font-size:.78rem}.social-links{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:1.5rem;display:flex}.social-link{border:1px solid var(--border2);background:var(--bg2);color:var(--fg);border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;text-decoration:none;transition:all .2s;display:inline-flex}.social-link:hover{background:var(--bg3);color:var(--fg2);transform:translateY(-2px)}.social-link svg{width:20px;height:20px}.social-link span{font-weight:500}}@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.static{position:static}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.block{display:block}.grid{display:grid}.inline{display:inline}.table{display:table}.border{border-style:var(--tw-border-style);border-width:1px}.border-gruvbox-border{border-color:var(--color-gruvbox-border)}.bg-gruvbox-bg{background-color:var(--color-gruvbox-bg)}.text-gruvbox-accent{color:var(--color-gruvbox-accent)}.text-gruvbox-fg{color:var(--color-gruvbox-fg)}.shadow,.shadow\/gradient{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}@media(max-width:1024px){.project-list{grid-template-columns:repeat(2,1fr)}.container{max-width:100%}}@media(max-width:768px){.hero h1{font-size:2.25rem}.hero p{font-size:1rem}.project-list,.footer-inner{grid-template-columns:1fr}.footer-links{text-align:left;flex-flow:wrap;gap:.75rem 1.5rem}.project-card-bg{left:0;transform:none}.image-blend{display:none}}@media(max-width:600px){nav{padding:0 1rem}.nav-links{gap:1rem}.hero{padding:3.5rem 1rem 2.5rem}.hero h1{font-size:1.9rem}.container,.container-narrow{padding:1.75rem 1rem}.footer-inner{padding:2rem 1rem 1rem}.footer-bottom{padding:1rem}.personal-bio{max-width:100%}}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
