*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f0f0f;--surface: #1a1a1a;--border: #2a2a2a;--text: #e0e0e0;--text-muted: #888;--accent: #6c9eff;--accent-hover: #8bb4ff;--radius: 8px;--max-width: 1060px;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}body{min-height:100vh}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.site{display:flex;flex-direction:column;min-height:100vh}.main{flex:1;width:100%;max-width:var(--max-width);margin:0 auto;padding:2rem 1.5rem}.header{display:flex;align-items:center;justify-content:space-between;max-width:var(--max-width);margin:0 auto;padding:1.5rem;width:100%}.header__logo{font-size:1.1rem;font-weight:600;letter-spacing:-.02em}.header__nav{display:flex;gap:.75rem}.header__social{color:var(--text-muted);transition:color .2s}.header__social:hover{color:var(--accent)}.footer{text-align:center;padding:2rem 1.5rem;color:var(--text-muted);font-size:.85rem}.hero{padding:2rem 0 3rem}.hero h1{font-size:2.4rem;font-weight:700;letter-spacing:-.03em;margin-bottom:.75rem}.hero__blurb{color:var(--text-muted);font-size:1.1rem;max-width:540px;line-height:1.7}.hero__blurb+.hero__blurb{margin-top:1rem}.filter-bar{display:flex;gap:.5rem;margin-bottom:1.5rem}.filter-pill{font-family:inherit;font-size:.85rem;padding:.35em .9em;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;transition:all .2s}.filter-pill:hover{border-color:var(--accent);color:var(--text)}.filter-pill--active{background:var(--accent);border-color:var(--accent);color:#0f0f0f}.tech-filter{position:relative}.tech-filter__trigger{font-family:inherit;font-size:.85rem;padding:.35em .9em;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:2px}.tech-filter__trigger:hover{border-color:var(--accent);color:var(--text)}.tech-filter__trigger--active{border-color:var(--accent);color:var(--accent)}.tech-filter__selected{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;margin-bottom:1rem}.tech-filter__chip{font-family:inherit;font-size:.75rem;padding:.2em .55em;border-radius:4px;border:none;background:var(--border);color:var(--text);cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:background .15s}.tech-filter__chip:hover{background:#3a3a3a}.tech-filter__chip-x{font-size:.9em;opacity:.6}.tech-filter__clear{font-family:inherit;font-size:.75rem;padding:.2em .55em;border-radius:4px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:color .15s}.tech-filter__clear:hover{color:var(--text)}.tech-filter__dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:20;min-width:220px;max-height:320px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;box-shadow:0 8px 24px #0006}.tech-filter__search{font-family:inherit;font-size:.85rem;padding:.5rem .75rem;border:none;border-bottom:1px solid var(--border);background:transparent;color:var(--text);outline:none}.tech-filter__search::placeholder{color:var(--text-muted)}.tech-filter__list{list-style:none;overflow-y:auto;padding:.25rem 0}.tech-filter__option{font-family:inherit;font-size:.85rem;width:100%;padding:.4rem .75rem;border:none;background:transparent;color:var(--text-muted);cursor:pointer;text-align:left;display:flex;align-items:center;gap:6px;transition:background .1s}.tech-filter__option:hover{background:var(--border)}.tech-filter__option--active{color:var(--accent)}.tech-filter__check{width:14px;font-size:.8rem;flex-shrink:0}.tech-filter__empty{padding:.75rem;color:var(--text-muted);font-size:.85rem;text-align:center}.projects__heading{font-size:1.2rem;font-weight:600;margin-bottom:1.25rem}.projects__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s,transform .2s}.card:hover{border-color:var(--accent);transform:translateY(-2px)}.card__image{width:100%;aspect-ratio:16 / 9;overflow:hidden}.card__image img{width:100%;height:100%;object-fit:cover}.card__placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--border) 0%,var(--surface) 100%)}.card__body{padding:1.25rem;display:flex;flex-direction:column;gap:.4rem;flex:1}.card__category{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent)}.card__title{font-size:1.05rem;font-weight:600}.card__summary{color:var(--text-muted);font-size:.85rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:auto;padding-top:.5rem}.card__ai{font-size:.75rem;color:#6cc070;margin-top:.25rem}.card__wip{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.15em .5em;border-radius:4px;background:#3a3a00;color:#e8c840;margin-left:.5rem;vertical-align:middle}.tag{font-size:.75rem;padding:.2em .6em;border-radius:4px;background:var(--border);color:var(--text-muted)}.tag--ai{background:#1a2a1a;color:#6cc070}.project-detail{max-width:640px;margin:0 auto}.project-detail__back{display:inline-block;color:var(--text-muted);font-size:.9rem;margin-bottom:1.5rem;transition:color .2s}.project-detail__back:hover{color:var(--accent)}.project-detail h1{font-size:2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.75rem}.project-detail__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem}.project-detail__description{color:var(--text-muted);font-size:1rem;line-height:1.7;margin-bottom:2rem}.project-detail__links{display:flex;gap:1rem}.project-detail__links a{color:var(--accent);font-weight:500;font-size:.95rem;transition:color .2s}.project-detail__links a:hover{color:var(--accent-hover)}.project-detail__hero{margin-bottom:1.5rem;border-radius:var(--radius);overflow:hidden}.project-detail__hero img{width:100%;aspect-ratio:16 / 9;object-fit:cover}.project-detail__category{display:inline-block;font-size:.8rem;color:var(--accent);margin-bottom:.75rem}.project-detail__section{margin-bottom:2rem}.project-detail__section h2{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.project-detail__section p{color:var(--text-muted);line-height:1.7}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.image-grid__item{border:none;padding:0;background:none;cursor:pointer;border-radius:var(--radius);overflow:hidden;transition:transform .2s}.image-grid__item:hover{transform:scale(1.03)}.image-grid__item img{width:100%;aspect-ratio:16 / 10;object-fit:cover}.lightbox{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#000000d9;cursor:pointer;padding:2rem}.lightbox img{max-width:100%;max-height:90vh;border-radius:var(--radius);object-fit:contain}.not-found{text-align:center;padding:4rem 0}.not-found h1{margin-bottom:1rem}.not-found a{color:var(--accent)}@media(max-width:640px){.hero h1{font-size:1.8rem}.hero__blurb{font-size:1rem}.filter-bar{flex-wrap:wrap}.projects__grid{grid-template-columns:1fr}.image-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.project-detail h1{font-size:1.5rem}.lightbox{padding:1rem}}
