@import "https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg:#0c0a09;--surface:#1c1917;--surface-hover:#252120;--border:#38322e;--text:#f5f0eb;--text-muted:#9e9087;--accent:#fbbf24;--accent-hover:#f59e0b;--accent-dim:rgba(251, 191, 36, 0.08);--font-display:'Syne', sans-serif;--font-body:'DM Sans', sans-serif;--font-mono:'JetBrains Mono', monospace;--radius:8px;--radius-lg:14px;--max-w:768px;--ease:cubic-bezier(0.16, 1, 0.3, 1);--fast:0.15s;--normal:0.25s}:root[data-theme=light]{--bg:#fafaf8;--surface:#f0ede9;--surface-hover:#e8e3dc;--border:#d5cfc7;--text:#1a1613;--text-muted:#6b6057;--accent:#c2410c;--accent-hover:#9a3412;--accent-dim:rgba(194, 65, 12, 0.08)}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}*::selection{background:var(--accent);color:#fff}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.65;-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none}img{display:block;max-width:100%}main{flex:1}header{border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.site-header{max-width:var(--max-w);margin:0 auto;padding:.8rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.site-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none;flex-shrink:0}.site-logo img{width:32px;height:32px;border-radius:50%;border:2px solid var(--border);object-fit:cover;transition:border-color var(--fast)}.site-logo:hover img{border-color:var(--accent)}.logo-text{font-family:var(--font-display);font-weight:700;font-size:.95rem;color:var(--text);letter-spacing:-.02em;line-height:1}.site-nav{display:flex;align-items:center;gap:.1rem;list-style:none}.site-nav li a{font-family:var(--font-mono);font-size:.76rem;color:var(--text-muted);padding:.4rem .6rem;border-radius:6px;transition:color var(--fast),background var(--fast);letter-spacing:.02em;display:block}.site-nav li a:hover{color:var(--text);background:var(--surface)}.nav-cta{color:var(--accent)!important;border:1px solid var(--border);margin-left:.3rem;border-color:color-mix(in srgb,var(--accent) 40%,transparent)!important}.nav-cta:hover{background:var(--accent-dim)!important;color:var(--accent)!important;border-color:var(--accent)!important}.theme-switcher{cursor:pointer;color:var(--text-muted);padding:.4rem;border-radius:6px;display:flex;align-items:center;transition:color var(--fast),background var(--fast);margin-left:.3rem}.theme-switcher:hover{color:var(--text);background:var(--surface)}.theme-switcher svg{width:15px;height:15px;fill:currentColor}.theme-icon-light{display:none}.theme-icon-dark{display:flex}.hero-section{max-width:var(--max-w);margin:0 auto;padding:5rem 1.5rem 3.5rem;position:relative}.hero-section::before{content:'';position:absolute;top:-10%;right:-5%;width:420px;height:420px;background:radial-gradient(circle,var(--accent-dim) 0%,transparent 70%);pointer-events:none;z-index:0}.hero-content{position:relative;z-index:1}.hero-status{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:2rem}.status-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;box-shadow:0 0 0 2px rgba(74,222,128,.2);flex-shrink:0;animation:status-pulse 2.5s ease-in-out infinite}@keyframes status-pulse{0%,100%{box-shadow:0 0 0 2px rgba(74,222,128,.2)}50%{box-shadow:0 0 0 6px rgba(74,222,128,0)}}.hero-name{font-family:var(--font-display);font-weight:800;font-size:clamp(3.5rem,9vw,5.5rem);line-height:.92;letter-spacing:-.04em;color:var(--text);margin-bottom:1.25rem}.hero-tagline{font-family:var(--font-mono);font-size:.95rem;color:var(--text-muted);margin-bottom:1.5rem;display:flex;align-items:center}.hero-tagline::before{content:'> ';color:var(--accent);margin-right:.3em;font-weight:500}.cursor{display:inline-block;width:2px;height:1em;background:var(--accent);margin-left:2px;vertical-align:text-bottom;animation:blink 1s step-end infinite}@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}.hero-bio{font-size:1.1rem;color:var(--text-muted);max-width:460px;margin-bottom:2.5rem;line-height:1.75}.hero-actions{display:flex;align-items:center;gap:.75rem;margin-bottom:3rem;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;font-family:var(--font-body);font-weight:500;font-size:.9rem;padding:.6rem 1.25rem;border-radius:var(--radius);text-decoration:none;transition:all var(--fast)var(--ease);white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);color:#fff;transform:translateY(-1px);box-shadow:0 6px 20px var(--accent-dim)}.btn-outline{color:var(--text-muted);border:1px solid var(--border)}.btn-outline:hover{color:var(--text);border-color:var(--text-muted);transform:translateY(-1px)}.btn-sm{font-size:.82rem;padding:.45rem 1rem}.about-me-info{display:flex;flex-wrap:wrap;gap:1.25rem}.about-me-info>span{display:flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);letter-spacing:.03em}.about-me-info svg{width:13px;height:13px;flex-shrink:0}.section-divider{border:none;border-top:1px solid var(--border)}.page-section{padding:3.5rem 1.5rem;max-width:var(--max-w);margin:0 auto}.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:2rem;gap:1rem}.section-label-group{display:flex;align-items:baseline;gap:.65rem}.section-num{font-family:var(--font-mono);font-size:.68rem;color:var(--accent);letter-spacing:.12em;font-weight:500}.section-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--text);letter-spacing:-.025em}.see-more-link{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);letter-spacing:.03em;white-space:nowrap;transition:color var(--fast)}.see-more-link:hover{color:var(--accent)}.projects-grid-home{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;text-decoration:none;display:flex;flex-direction:column;transition:border-color var(--normal),transform var(--normal)var(--ease),box-shadow var(--normal)}.project-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 12px 36px var(--accent-dim)}.project-card-img{aspect-ratio:16/9;overflow:hidden;background:var(--surface-hover)}.project-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}.project-card:hover .project-card-img img{transform:scale(1.05)}.project-card-body{padding:.9rem;flex:1;display:flex;flex-direction:column;gap:.4rem}.project-card-title{font-family:var(--font-display);font-size:.92rem;font-weight:600;color:var(--text);letter-spacing:-.01em;transition:color var(--fast)}.project-card:hover .project-card-title{color:var(--accent)}.project-card-summary{font-size:.78rem;color:var(--text-muted);line-height:1.5;flex:1}.project-card-stack{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.25rem}.tech-chip{font-family:var(--font-mono);font-size:.65rem;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);padding:.1rem .45rem;border-radius:4px;letter-spacing:.02em}.posts-list{display:flex;flex-direction:column}.post-item{display:grid;grid-template-columns:1fr auto;align-items:start;gap:1rem;padding:1.25rem 0 1.25rem 1rem;border-bottom:1px solid var(--border);text-decoration:none;position:relative;transition:background var(--fast)}.post-item:first-child{border-top:1px solid var(--border)}.post-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);opacity:0;transition:opacity var(--fast);border-radius:0 2px 2px 0}.post-item:hover::before{opacity:1}.post-item-title{font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--text);letter-spacing:-.015em;margin-bottom:.3rem;transition:color var(--fast)}.post-item:hover .post-item-title{color:var(--accent)}.post-item-summary{font-size:.85rem;color:var(--text-muted);line-height:1.5;margin-bottom:.6rem}.post-item-tags{display:flex;gap:.35rem;flex-wrap:wrap}.post-tag{font-family:var(--font-mono);font-size:.65rem;color:var(--accent);background:var(--accent-dim);padding:.1rem .45rem;border-radius:4px;text-decoration:none;letter-spacing:.02em}.post-item-date{font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);white-space:nowrap;padding-top:.25rem}footer{border-top:1px solid var(--border)}.site-footer{max-width:var(--max-w);margin:0 auto;padding:1.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.footer-left{display:flex;flex-direction:column;gap:.2rem}.footer-email{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);transition:color var(--fast)}.footer-email:hover{color:var(--accent)}.footer-copy{font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);opacity:.6}.social-links{display:flex;gap:.75rem;align-items:center}.social-link{color:var(--text-muted);display:flex;transition:color var(--fast),transform var(--fast)}.social-link:hover{color:var(--accent);transform:translateY(-2px)}.social-link svg{width:18px;height:18px}.list-page{max-width:var(--max-w);margin:0 auto;padding:3.5rem 1.5rem}.page-title{font-family:var(--font-display);font-size:clamp(2.25rem,6vw,3.5rem);font-weight:800;letter-spacing:-.04em;color:var(--text);margin-bottom:.5rem}.page-subtitle{font-size:1rem;color:var(--text-muted);margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}.projects-grid-full{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.single-post{max-width:660px;margin:0 auto;padding:3rem 1.5rem}.post-header{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}.post-header-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.post-date{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted)}.post-tags{display:flex;gap:.35rem;flex-wrap:wrap}.post-title{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;letter-spacing:-.035em;color:var(--text);line-height:1.1}.post-body{font-size:1.05rem;line-height:1.8;color:var(--text)}.post-body h2{font-family:var(--font-display);font-size:1.5rem;font-weight:700;letter-spacing:-.025em;margin:2.5rem 0 1rem}.post-body h3{font-family:var(--font-display);font-size:1.15rem;font-weight:600;letter-spacing:-.015em;margin:2rem 0 .75rem}.post-body p{margin-bottom:1.35rem}.post-body p:last-child{margin-bottom:0}.post-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}.post-body code{font-family:var(--font-mono);font-size:.875em;background:var(--surface);border:1px solid var(--border);padding:.1em .4em;border-radius:4px}.post-body pre{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;overflow-x:auto;margin:1.5rem 0}.post-body pre code{background:0 0;border:none;padding:0;font-size:.875rem;line-height:1.7}.post-body ul,.post-body ol{padding-left:1.5rem;margin-bottom:1.35rem}.post-body li{margin-bottom:.4rem}.post-body blockquote{border-left:3px solid var(--accent);padding:.25rem 0 .25rem 1.25rem;color:var(--text-muted);font-style:italic;margin:1.75rem 0}.post-body hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.single-project{max-width:660px;margin:0 auto;padding:3rem 1.5rem}.project-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.035em;color:var(--text);margin-bottom:1.5rem;line-height:1.05}.project-meta-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:2.5rem;display:flex;flex-direction:column;gap:1rem}.tech-stack-row{display:flex;flex-wrap:wrap;gap:.35rem}.project-links-row{display:flex;gap:.65rem;flex-wrap:wrap}.project-launch{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted)}.project-body{font-size:1.05rem;line-height:1.8}.project-body h2{font-family:var(--font-display);font-size:1.35rem;font-weight:700;letter-spacing:-.02em;margin:2rem 0 .75rem;color:var(--text)}.project-body p{color:var(--text-muted);margin-bottom:1.25rem}.project-body ul{padding-left:1.25rem;margin-bottom:1.25rem}.project-body li{color:var(--text-muted);margin-bottom:.4rem}.static-page{max-width:660px;margin:0 auto;padding:3.5rem 1.5rem}.static-page h1{font-family:var(--font-display);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.04em;color:var(--text);margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.static-page h2{font-family:var(--font-display);font-size:1.2rem;font-weight:700;letter-spacing:-.02em;color:var(--text);margin:2.25rem 0 .65rem}.static-page p{font-size:1.05rem;color:var(--text-muted);line-height:1.8;margin-bottom:1.1rem}.static-page strong{color:var(--text);font-weight:500}.static-page a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}@media(max-width:640px){.hero-section{padding:3.5rem 1.25rem 2.5rem}.hero-name{font-size:3rem}.logo-text{display:none}.projects-grid-home{grid-template-columns:1fr}.post-item{grid-template-columns:1fr}.post-item-date{display:none}.page-section{padding:2.5rem 1.25rem}.list-page{padding:2.5rem 1.25rem}.single-post{padding:2rem 1.25rem}.single-project{padding:2rem 1.25rem}.static-page{padding:2.5rem 1.25rem}.site-footer{flex-direction:column;align-items:flex-start}.section-header{flex-direction:column;align-items:flex-start}}@media(min-width:641px) and (max-width:900px){.projects-grid-home{grid-template-columns:repeat(2,1fr)}}