body{letter-spacing:.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-bottom:5rem}html{scroll-behavior:smooth}.hero{display:flex;align-items:flex-start;gap:2.5rem;margin-bottom:.5rem}.hero-text{flex:1;min-width:0}.hero-text h1{font-size:2.4rem;letter-spacing:-.02em;margin-bottom:.15rem;margin-top:0;background:linear-gradient(135deg, #f5f5f5 0%, #7b93e0 100%);-webkit-background-clip:text;-webkit-text-fill-color:rgba(0,0,0,0);background-clip:text;line-height:1.2}.hero-text p{line-height:1.65;color:#c8c8c8}.hero-tagline{font-size:1rem;letter-spacing:.06em;text-transform:uppercase;color:#8e8e8e !important;margin-bottom:1.25rem;margin-top:0}.hero-photo{width:320px;min-width:320px;border-radius:6px;border:1px solid rgba(255,255,255,.08);margin-top:.5rem}main h2{font-size:1.3rem;letter-spacing:.05em;text-transform:uppercase;color:#c8c8c8;margin-top:2.5rem;margin-bottom:1.2rem;padding-bottom:.4rem;border-bottom:2px solid #6082e6;display:inline-block}main>h1:first-child{font-size:2.2rem;letter-spacing:-.02em;margin-bottom:.25rem;background:linear-gradient(135deg, #f5f5f5 0%, #7b93e0 100%);-webkit-background-clip:text;-webkit-text-fill-color:rgba(0,0,0,0);background-clip:text}main h3{font-size:1.1rem;letter-spacing:.02em;color:#f5f5f5;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08)}main h2+h3{border-top:none;padding-top:.75rem}main h4{font-size:1rem;color:#7b93e0;letter-spacing:.06em;margin-top:1.5rem;margin-bottom:.5rem}nav{padding:.5rem 0;gap:.5rem}nav a{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;padding:.35rem .75rem;border-radius:2px;transition:background-color .2s ease,color .2s ease}nav a:hover{background-color:rgba(96,130,230,.15);color:#7b93e0}nav a.active{background-color:rgba(96,130,230,.15);color:#7b93e0;border-bottom:2px solid #6082e6}header hr{border:none;height:1px;background:linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(255,255,255,.12) 20%, #6082e6 50%, rgba(255,255,255,.12) 80%, rgba(0,0,0,0) 100%);margin-top:0}.project-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1rem}.project-card{display:flex;flex-direction:column;background-color:#262525;border:1px solid rgba(255,255,255,.08);border-radius:6px;overflow:hidden;text-decoration:none;color:#c8c8c8;transition:border-color .25s ease,transform .25s ease,box-shadow .25s ease}.project-card:hover{border-color:#6082e6;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3),0 0 0 1px rgba(96,130,230,.15)}.project-card img{width:100%;height:180px;object-fit:cover;border-bottom:1px solid rgba(255,255,255,.08)}.project-card-body{padding:1rem 1.15rem;display:flex;flex-direction:column;gap:.4rem;flex:1}.project-card-body strong{font-size:1.05rem;color:#f5f5f5;letter-spacing:.01em}.project-card-body span{font-size:.88rem;line-height:1.55;color:#8e8e8e}.project-row{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1.5rem}.project-pill{display:inline-flex;align-items:baseline;gap:.4rem;font-size:.85rem;font-weight:600;color:#dce4f9;text-decoration:none;padding:.4rem .85rem;background-color:#262525;border:1px solid rgba(255,255,255,.12);border-radius:4px;transition:border-color .2s ease,background-color .2s ease}.project-pill span{font-weight:400;font-size:.78rem;color:#8e8e8e}.project-pill:hover{background-color:rgba(96,130,230,.15);border-color:#6082e6;color:#7b93e0}.project-entry{background-color:#262525;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:1.5rem 1.5rem 1.25rem;margin-bottom:1.25rem;transition:border-color .2s ease}.project-entry:hover{border-color:rgba(96,130,230,.3)}.project-entry h3{border-top:none;padding-top:0;margin-top:0;margin-bottom:.75rem;font-size:1.15rem}.project-entry p{margin-top:.5rem;margin-bottom:.5rem}.project-entry .project-thumb{margin-top:0}.project-entry h3+p>a,.project-entry .project-thumb+p>a{font-size:.82rem;letter-spacing:.03em;padding:.15rem .5rem;border:1px solid rgba(255,255,255,.12);border-radius:3px;text-decoration:none;transition:background-color .15s ease,border-color .15s ease}.project-entry h3+p>a:hover,.project-entry .project-thumb+p>a:hover{background-color:rgba(96,130,230,.15);border-color:#6082e6}.project-entry h3~p>strong:first-child{color:#f5f5f5;line-height:1.5;display:block;margin-bottom:.15rem}.project-entry h3~p>em{color:#8e8e8e;font-size:.9rem}main h3+p>a{font-size:.82rem;letter-spacing:.03em;padding:.15rem .5rem;border:1px solid rgba(255,255,255,.12);border-radius:3px;text-decoration:none;transition:background-color .15s ease,border-color .15s ease}main h3+p>a:hover{background-color:rgba(96,130,230,.15);border-color:#6082e6}main h3~p>strong:first-child{color:#f5f5f5;line-height:1.5;display:block;margin-bottom:.15rem}main h3~p>strong:first-child+br,main h3~p>strong+br{display:block;margin-bottom:.2rem}main h3~p>em{color:#8e8e8e;font-size:.9rem}.news-list{list-style:none !important;padding-left:0 !important}.news-list li{padding:.65rem .9rem;margin-bottom:.4rem;background-color:#262525;border-left:3px solid #6082e6;border-radius:0 4px 4px 0;transition:border-color .2s ease,background-color .2s ease,transform .2s ease}.news-list li:hover{border-left-color:#7b93e0;background-color:#2a2929;transform:translateX(3px)}.news-list li a{text-decoration:none;color:#dce4f9}.news-list li a:hover{color:#7b93e0}.callout{background-color:#262525;border:1px solid rgba(255,255,255,.08);border-left:3px solid #6082e6;border-radius:0 6px 6px 0;padding:1.25rem 1.5rem}.callout h3{margin-top:0;padding-top:0;border-top:none;font-size:1.05rem;color:#7b93e0;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.5rem}.callout p{margin:0;font-size:.95rem;line-height:1.6;color:#c8c8c8}.callout code{color:#7b93e0}a{transition:color .15s ease,text-decoration-color .15s ease}details{background-color:#262525;border:1px solid rgba(255,255,255,.08);border-radius:4px;padding:.75rem 1rem;margin-bottom:1.5rem}details summary{cursor:pointer;font-weight:600;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:#c8c8c8;user-select:none}details ol,details ul{margin-top:.5rem;font-size:.95rem}details a{text-decoration:none}details a:hover{text-decoration:underline}main hr{border:none;height:1px;background:linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(255,255,255,.12) 30%, rgba(255,255,255,.12) 70%, rgba(0,0,0,0) 100%);margin:2.5rem 0}main li{margin-bottom:.35rem}main>ul,main>ol{padding-left:1.2rem}code{background-color:#262525;border-color:rgba(255,255,255,.08);border-radius:3px;font-size:.88rem}pre{background-color:#262525;border-color:rgba(255,255,255,.08);border-radius:3px}blockquote{border-left-color:#6082e6;background-color:rgba(96,130,230,.04);padding:.5rem 1.5rem;border-radius:0 3px 3px 0}footer{position:fixed;bottom:0;left:0;right:0;text-align:center;padding:10px 1rem;background-color:rgba(31,30,30,.95);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);font-size:.8rem;letter-spacing:.02em;color:#8e8e8e;border-top:1px solid rgba(255,255,255,.08);z-index:100}footer a{color:#c8c8c8;text-decoration:none;transition:color .15s ease}footer a:hover{color:#7b93e0}.project-thumb{width:100%;max-height:220px;object-fit:cover;border-radius:4px;border:1px solid rgba(255,255,255,.08);margin-bottom:.75rem}.profile-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1rem}.profile-link{display:flex;flex-direction:column;align-items:center;text-decoration:none;padding:.6rem 1rem;background-color:#262525;border:1px solid rgba(255,255,255,.08);border-radius:6px;transition:border-color .2s ease,transform .2s ease;min-width:100px;text-align:center}.profile-link strong{font-size:.85rem;color:#dce4f9;margin-bottom:.15rem}.profile-link span{font-size:.72rem;color:#8e8e8e}.profile-link svg{width:28px;height:28px;fill:#8e8e8e;margin-bottom:.25rem;transition:fill .2s ease}.profile-link:hover{border-color:#6082e6;transform:translateY(-1px)}.profile-link:hover svg{fill:#7b93e0}.link-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.link-cards-compact{grid-template-columns:1fr 1fr}.link-card{display:flex;flex-direction:column;background-color:#262525;border:1px solid rgba(255,255,255,.08);border-radius:6px;overflow:hidden;text-decoration:none;color:#c8c8c8;transition:border-color .25s ease,transform .25s ease}.link-card:hover{border-color:#6082e6;transform:translateY(-2px)}.link-card img{width:100%;height:120px;object-fit:cover;border-bottom:1px solid rgba(255,255,255,.08)}.link-card-body{padding:.75rem .9rem;display:flex;flex-direction:column;gap:.25rem;flex:1}.link-card-body strong{font-size:.95rem;color:#f5f5f5}.link-card-body span{font-size:.8rem;line-height:1.45;color:#8e8e8e}.blog-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:.5rem}.blog-category{background-color:#262525;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:1rem 1.15rem}.blog-category h4{margin-top:0;margin-bottom:.6rem;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;color:#7b93e0}.blog-category a{display:block;font-size:.88rem;color:#dce4f9;text-decoration:none;padding:.2rem 0;transition:color .15s ease}.blog-category a:hover{color:#7b93e0}::selection{background-color:rgba(96,130,230,.35);color:#f5f5f5}@media (max-width: 768px){.hero{flex-direction:column-reverse;gap:1.25rem;text-align:center}.hero-photo{width:180px;min-width:auto;margin:0 auto}.hero-text h1{font-size:1.9rem}.hero-tagline{font-size:.85rem}.hero-text p{text-align:left}.project-grid{grid-template-columns:1fr}.project-card img{height:150px}.project-row{flex-direction:column}.project-pill{justify-content:center}.link-cards{grid-template-columns:1fr}.link-cards-compact{grid-template-columns:1fr}.blog-grid{grid-template-columns:1fr}.profile-row{justify-content:center}}@media (max-width: 600px){main h2{font-size:1.15rem}main>h1:first-child{font-size:1.7rem}nav a{font-size:.72rem;padding:.3rem .5rem}.project-entry{padding:1rem}.callout{padding:1rem}}