*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #050d1a;--bg-light: #112240;--bg-card: #1d2d50;--text: #ccd6f6;--text-muted:#8e98b4;--accent: #64ffda;--accent-dim:rgba(100,255,218,.1);--border: rgba(100,255,218,.15);--font-sans: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--sidebar-w: 280px;--transition: all .2s ease}html{scroll-behavior:smooth}body:before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;background:radial-gradient(ellipse 70% 55% at 12% 8%,rgba(120,0,255,.09) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 88% 15%,rgba(0,60,255,.07) 0%,transparent 55%),radial-gradient(ellipse 80% 60% at 55% 52%,rgba(0,160,200,.04) 0%,transparent 60%),radial-gradient(ellipse 55% 45% at 18% 82%,rgba(180,0,130,.05) 0%,transparent 50%),radial-gradient(ellipse 65% 55% at 80% 78%,rgba(80,0,200,.06) 0%,transparent 55%),radial-gradient(ellipse 40% 35% at 42% 22%,rgba(0,200,180,.03) 0%,transparent 45%)}body:after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.1;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='2.5'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");background-repeat:repeat;background-size:300px 300px;mix-blend-mode:screen}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:16px;line-height:1.7;min-height:100vh}a{color:var(--accent);text-decoration:none;transition:var(--transition)}a:hover{color:var(--accent);opacity:.8}h1,h2,h3,h4{color:var(--text);font-weight:600;line-height:1.2}.mono{font-family:var(--font-mono);font-size:.85em;color:var(--accent)}.section-label{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);letter-spacing:.15em;text-transform:uppercase;margin-bottom:.5rem}.section-title{font-size:2rem;color:var(--text);margin-bottom:2.5rem;display:flex;align-items:center;gap:1rem;white-space:nowrap}.section-title:after{content:"";display:block;height:1px;width:100%;max-width:300px;background:var(--border)}.layout{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;display:flex;flex-direction:column;padding:3rem 2rem;border-right:1px solid var(--border);background:var(--bg);z-index:100;overflow-y:auto}.sidebar-header{margin-bottom:2rem}.sidebar-name{font-size:1.4rem;font-weight:700;color:var(--text);line-height:1.2}.sidebar-title{font-family:var(--font-mono);font-size:.8rem;color:var(--accent);margin-top:.35rem}.sidebar-location{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.sidebar-nav{flex:1;margin-top:2.5rem}.sidebar-nav ul{list-style:none;display:flex;flex-direction:column;gap:.25rem}.sidebar-nav a{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;color:var(--text-muted);font-family:var(--font-mono);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;transition:var(--transition)}.sidebar-nav a:before{content:"";display:block;height:1px;width:2rem;background:var(--text-muted);transition:var(--transition)}.sidebar-nav a:hover,.sidebar-nav a.active{color:var(--accent)}.sidebar-nav a:hover:before,.sidebar-nav a.active:before{width:3.5rem;background:var(--accent)}.sidebar-social{display:flex;gap:1rem;margin-top:2rem}.sidebar-social a{color:var(--text-muted);font-size:1.1rem;transition:var(--transition);display:flex;align-items:center}.sidebar-social a:hover{color:var(--accent);transform:translateY(-2px)}.main{margin-left:var(--sidebar-w);flex:1;padding:5rem 4rem 5rem 5rem;max-width:900px}section{padding:5rem 0;border-bottom:1px solid var(--border)}section:last-child{border-bottom:none}.about-greeting{font-family:var(--font-mono);font-size:1rem;color:var(--accent);margin-bottom:1rem}.about-name{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;color:var(--text);line-height:1.1}.about-tagline{font-size:clamp(1.5rem,3vw,2.2rem);color:var(--text);font-weight:600;margin-top:.25rem;margin-bottom:2rem}.about-bio{max-width:580px;color:var(--text-muted);font-size:1rem;line-height:1.8}.about-bio p+p{margin-top:1rem}.exp-tabs{display:flex;flex-direction:column;gap:2.5rem}.exp-item{display:grid;grid-template-columns:140px 1fr;gap:1.5rem}.exp-dates{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);padding-top:.25rem;letter-spacing:.05em;line-height:1.6}.exp-company{font-size:1.05rem;font-weight:600;color:var(--text)}.exp-role{font-family:var(--font-mono);font-size:.8rem;color:var(--accent);margin-top:.15rem;margin-bottom:.6rem}.exp-desc{color:var(--text-muted);font-size:.92rem;line-height:1.7}.exp-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.tag{font-family:var(--font-mono);font-size:.72rem;color:var(--accent);background:var(--accent-dim);border:1px solid var(--border);border-radius:3px;padding:.2rem .6rem;letter-spacing:.05em}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem}.skill-group{background:var(--bg-light);border:1px solid var(--border);border-radius:6px;padding:1.25rem 1.5rem;transition:var(--transition)}.skill-group:hover{border-color:var(--accent);background:var(--bg-card)}.skill-group-title{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem}.skill-list{list-style:none;display:flex;flex-direction:column;gap:.3rem}.skill-list li{font-size:.88rem;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.skill-list li:before{content:"▹";color:var(--accent);font-size:.75rem;flex-shrink:0}.billboard{position:relative;margin-bottom:2rem;background:var(--bg-light);border:1px solid var(--border);border-radius:12px;overflow:hidden;min-height:280px}.billboard-slides{position:relative}.billboard-slide{display:none;grid-template-columns:1.1fr 1fr;align-items:center;text-decoration:none;color:inherit;cursor:pointer;padding:2rem;gap:2rem;transition:opacity .4s ease}.billboard-slide.is-active{display:grid;animation:billboardFadeIn .5s ease}@keyframes billboardFadeIn{0%{opacity:0}to{opacity:1}}.billboard-visual{display:flex;justify-content:center;align-items:center}.billboard-screenshot{max-width:100%;max-height:220px;object-fit:contain;border-radius:8px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2))}.billboard-content{display:flex;flex-direction:column;gap:.3rem}.billboard-logo{width:42px;height:42px;border-radius:10px;object-fit:contain;margin-bottom:.3rem}.billboard-logo-round{border-radius:12px}.billboard-name{font-size:1.4rem;font-weight:700;color:var(--text)}.billboard-type{font-size:.78rem;font-family:var(--font-mono);color:var(--accent);margin-bottom:.3rem}.billboard-desc{font-size:.88rem;color:var(--text-muted);line-height:1.55}.billboard-cta{font-family:var(--font-mono);font-size:.8rem;color:var(--accent);margin-top:.5rem;opacity:.7;transition:opacity .2s ease}.billboard-slide:hover .billboard-cta{opacity:1}.billboard-nav{display:flex;justify-content:center;gap:.5rem;padding:0 0 1.2rem}.billboard-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--text-muted);opacity:.3;cursor:pointer;transition:opacity .2s ease,transform .2s ease;padding:0}.billboard-dot.is-active{opacity:.8;background:var(--accent);transform:scale(1.3)}.billboard-dot:hover{opacity:.6}@media(max-width:700px){.billboard-slide{grid-template-columns:1fr;padding:1.5rem;gap:1rem}.billboard-screenshot{max-height:160px}.billboard{min-height:auto}}.featured-card{display:grid;grid-template-columns:1.1fr 1fr;background:var(--bg-light);border:1px solid var(--border);border-radius:6px;overflow:hidden;margin-bottom:1.5rem;transition:var(--transition);text-decoration:none;color:inherit;cursor:pointer}.featured-card:hover{border-color:var(--accent);background:var(--bg-card);opacity:1}.featured-screenshot{background:linear-gradient(135deg,var(--bg-light),var(--bg-card));display:flex;align-items:center;justify-content:center;min-height:280px;overflow:hidden}.featured-screenshot img{width:100%;height:100%;object-fit:cover}.featured-body{padding:2rem;display:flex;flex-direction:column;justify-content:center}.featured-label{font-family:var(--font-mono);font-size:.68rem;color:var(--accent);letter-spacing:.15em;text-transform:uppercase;margin-bottom:.5rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;margin-bottom:1.5rem}.project-card{background:var(--bg-light);border:1px solid var(--border);border-radius:6px;overflow:hidden;transition:var(--transition);text-decoration:none;color:inherit;display:block}.project-card:hover{border-color:var(--accent);background:var(--bg-card);transform:translateY(-3px);opacity:1}.project-screenshot{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,var(--bg-light),var(--bg-card));overflow:hidden;display:flex;align-items:center;justify-content:center}.project-screenshot img{width:100%;height:100%;object-fit:cover}.project-body{padding:.75rem 1rem 1rem}.project-card .project-desc{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-name{font-size:1.05rem;font-weight:600;color:var(--text)}.project-org{font-family:var(--font-mono);font-size:.72rem;color:var(--accent);letter-spacing:.05em;margin-top:.15rem}.project-desc{color:var(--text-muted);font-size:.92rem;line-height:1.7}.project-link{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.78rem;color:var(--accent);margin-top:1rem;opacity:.7;transition:var(--transition)}.project-card:hover .project-link,.featured-card:hover .project-link{opacity:1}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem;margin-top:2rem}.product-tile{display:flex;align-items:center;gap:.9rem;padding:.9rem 1.1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;text-decoration:none;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}.product-tile:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.product-icon{width:38px;height:38px;border-radius:10px;flex-shrink:0;object-fit:contain}.product-icon-round{border-radius:12px}.product-info{flex:1;min-width:0}.product-name{font-size:.88rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-type{font-size:.72rem;color:var(--text-muted);font-family:var(--font-mono);margin-top:.15rem}.product-badge{font-size:.58rem;font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em;padding:.12em .5em;border-radius:4px;background:#4b7bec26;color:#4b7bec;margin-left:.4rem;vertical-align:middle}.product-arrow{color:var(--text-muted);font-size:.85rem;opacity:0;transition:opacity .15s ease,transform .15s ease;flex-shrink:0}.product-tile:hover .product-arrow{opacity:1;transform:translate(2px)}.app-store-link{display:inline-block;margin-top:.75rem;opacity:.85;transition:var(--transition)}.app-store-link:hover{opacity:1;transform:scale(1.03)}.app-store-link img{display:block}.project-bullets{list-style:none;margin-top:.75rem;display:flex;flex-direction:column;gap:.35rem}.project-bullets li{font-size:.88rem;color:var(--text-muted);display:flex;align-items:flex-start;gap:.5rem}.project-bullets li:before{content:"▹";color:var(--accent);font-size:.75rem;flex-shrink:0;margin-top:.2rem}.beyond-intro{max-width:540px;color:var(--text-muted);font-size:1rem;line-height:1.8;margin-bottom:2rem}.interests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1rem}.interest-card{background:var(--bg-light);border:1px solid var(--border);border-radius:6px;padding:1.25rem;display:flex;align-items:flex-start;gap:1rem;transition:var(--transition)}.interest-card:hover{border-color:var(--accent);background:var(--bg-card)}.interest-icon{font-size:1.4rem;flex-shrink:0;line-height:1.3}.interest-name{font-size:.88rem;font-weight:600;color:var(--text);margin-bottom:.3rem}.interest-desc{font-size:.8rem;color:var(--text-muted);line-height:1.5}.blog-empty{background:var(--bg-light);border:1px dashed var(--border);border-radius:6px;padding:3rem;text-align:center;color:var(--text-muted);font-family:var(--font-mono);font-size:.85rem}.blog-list{display:flex;flex-direction:column;gap:1rem}.blog-item{display:flex;align-items:baseline;gap:1.5rem;padding:1rem 0;border-bottom:1px solid var(--border);transition:var(--transition)}.blog-item:hover .blog-title{color:var(--accent)}.blog-date{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.blog-title{color:var(--text);font-size:.95rem}.back-link{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);transition:var(--transition)}.back-link:hover{color:var(--accent)}.post-title{font-size:1.7rem;font-weight:600;color:var(--text);margin:.5rem 0 1rem;line-height:1.3}.post-meta{display:flex;align-items:center;gap:1rem;margin-bottom:2.5rem;flex-wrap:wrap}.post-date{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}.post-tags{display:flex;gap:.5rem;flex-wrap:wrap}.post-tag{font-family:var(--font-mono);font-size:.7rem;color:var(--accent);border:1px solid var(--border);border-radius:3px;padding:.15rem .5rem}.audio-badge{display:inline-flex;align-items:center;color:var(--accent);opacity:.6;margin-left:.4rem;vertical-align:middle;transition:opacity .2s}.audio-badge:hover{opacity:1}.post-title-row{display:flex;align-items:baseline;gap:.75rem}.post-title-row .post-title{margin-bottom:0}.audio-toggle{background:none;border:1px solid var(--border);border-radius:4px;padding:.3rem .4rem;color:var(--accent);cursor:pointer;display:inline-flex;align-items:center;opacity:.6;transition:opacity .2s,border-color .2s;flex-shrink:0;align-self:center}.audio-toggle:hover{opacity:1}.audio-toggle.active{opacity:1;border-color:var(--accent)}.audio-player{display:flex;align-items:center;padding:.5rem 0;margin-bottom:.5rem}.audio-player audio{flex:1;height:36px;min-width:0}.post-prose{color:var(--text-muted);line-height:1.85;font-family:var(--font-sans);font-size:.95rem}.post-prose h1,.post-prose h2,.post-prose h3,.post-prose h4{color:var(--text);margin:2rem 0 .75rem;font-weight:600;line-height:1.3}.post-prose h2{font-size:1.2rem}.post-prose h3{font-size:1rem}.post-prose p{margin-bottom:1.25rem}.post-prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}.post-prose a:hover{opacity:.8}.post-prose code{font-family:var(--font-mono);font-size:.82em;background:var(--bg-light);border:1px solid var(--border);border-radius:3px;padding:.1em .4em;color:var(--accent)}.post-prose pre{background:var(--bg-light);border:1px solid var(--border);border-radius:6px;padding:1.25rem;overflow-x:auto;margin:1.5rem 0}.post-prose pre code{background:none;border:none;padding:0;color:var(--text);font-size:.82rem}.post-prose ul,.post-prose ol{margin:1rem 0 1.25rem 1.5rem}.post-prose li{margin-bottom:.4rem}.post-prose blockquote{border-left:3px solid var(--accent);padding-left:1.25rem;color:var(--text-muted);font-style:italic;margin:1.5rem 0}.post-prose hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.post-prose strong{color:var(--text);font-weight:600}.post-prose img{width:100%;border-radius:6px;border:1px solid var(--border);margin:1.5rem 0;display:block}.post-prose .table-wrap{overflow-x:auto;margin:1.5rem 0;border:1px solid var(--border);border-radius:6px}.post-prose table{width:100%;border-collapse:collapse;font-size:.85rem;line-height:1.5}.post-prose thead th{background:var(--bg-light);color:var(--accent);font-family:var(--font-mono);font-size:.78rem;font-weight:600;text-align:left;padding:.6rem .85rem;border-bottom:1px solid var(--border);white-space:nowrap}.post-prose tbody td{padding:.55rem .85rem;border-bottom:1px solid var(--border);color:var(--text-muted);vertical-align:top}.post-prose tbody tr:last-child td{border-bottom:none}.post-prose tbody tr:hover{background:#64ffda08}.post-prose td strong{color:var(--text)}.contact-text{max-width:500px;color:var(--text-muted);margin-bottom:2rem;line-height:1.8}.contact-links{display:flex;flex-wrap:wrap;gap:1rem}.contact-btn{font-family:var(--font-mono);font-size:.8rem;color:var(--accent);border:1px solid var(--accent);border-radius:4px;padding:.75rem 1.5rem;letter-spacing:.08em;transition:var(--transition)}.contact-btn:hover{background:var(--accent-dim);opacity:1}.mobile-nav{display:none;position:fixed;top:0;left:0;right:0;z-index:200;background:#0a192ff2;backdrop-filter:blur(10px);border-bottom:1px solid var(--border);padding:1rem 1.5rem;align-items:center;justify-content:space-between}.mobile-nav-name{font-family:var(--font-mono);font-size:.85rem;color:var(--accent)}.mobile-menu-toggle{background:none;border:1px solid var(--accent);color:var(--accent);font-family:var(--font-mono);font-size:.75rem;padding:.35rem .75rem;cursor:pointer;border-radius:3px;letter-spacing:.05em}.mobile-menu{display:none;position:fixed;top:0;right:0;bottom:0;width:75vw;max-width:300px;background:var(--bg-light);border-left:1px solid var(--border);z-index:300;padding:5rem 2rem 2rem;flex-direction:column;gap:1.5rem}.mobile-menu.open{display:flex}.mobile-menu a{color:var(--text-muted);font-family:var(--font-mono);font-size:.9rem;letter-spacing:.08em;padding:.5rem 0}.mobile-menu a:hover{color:var(--accent)}.mobile-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:250}.mobile-overlay.open{display:block}@media(max-width:900px){.sidebar{display:none}.mobile-nav{display:flex}.main{margin-left:0;padding:5rem 1.5rem 3rem;max-width:100%}.exp-item{grid-template-columns:1fr;gap:.25rem}.section-title:after{max-width:100px}.featured-card{grid-template-columns:1fr}.featured-screenshot{min-height:180px}}@media(max-width:480px){.about-name{font-size:2rem}.about-tagline{font-size:1.3rem}.skills-grid{grid-template-columns:1fr}.main{padding:5rem 1rem 3rem}}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}.skip-link{position:absolute;top:-100%;left:1rem;z-index:999;background:var(--bg);color:var(--accent);border:1px solid var(--accent);border-radius:4px;padding:.5rem 1rem;font-family:var(--font-mono);font-size:.85rem;text-decoration:none}.skip-link:focus{top:1rem}.blog-item{cursor:pointer;border-radius:4px;padding-left:.75rem;padding-right:.75rem;margin-left:-.75rem;margin-right:-.75rem}.blog-item:hover{background:var(--accent-dim);transform:translateY(-1px);box-shadow:0 2px 8px #0003}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}html{scroll-behavior:auto}}
