*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#1a1a1a;
  --surface:#242424;
  --surface2:#2e2e2e;
  --text:#d0d0d0;
  --text-dim:#888;
  --text-bright:#eee;
  --accent:#6ba0d0;
  --accent-dim:#4a7aaa;
  --border:#3a3a3a;
  --glow:0 0 8px rgba(107,160,208,0.3);
  --radius:6px;
  --nav-h:44px;
  --overlay-z:1000;
  --font:sans-serif;
  --font-mono:"SF Mono","Fira Code","Cascadia Code",monospace;
}
html{font-size:16px;scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font);
  line-height:1.6;
  min-height:100vh;
}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--text-bright);text-shadow:var(--glow)}
img{max-width:100%;height:auto}
code,pre{font-family:var(--font-mono);font-size:.875rem}
pre{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1rem;
  overflow-x:auto;
  margin:1rem 0;
}
code{
  background:var(--surface);
  padding:.1em .3em;
  border-radius:3px;
}
pre code{padding:0;background:none;border:none}

/* Nav */
.navbar{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  height:var(--nav-h);
  position:sticky;
  top:0;
  z-index:100;
}
.nav-inner{
  max-width:960px;
  margin:0 auto;
  display:flex;
  align-items:center;
  height:100%;
  padding:0 1rem;
}
.nav-logo{
  color:var(--text-bright);
  font-weight:700;
  font-size:1.05rem;
  margin-right:2rem;
  white-space:nowrap;
}
.nav-logo:hover{color:var(--accent);text-shadow:var(--glow)}
.nav-links{display:flex;gap:.25rem;margin-left:auto}
.nav-link{
  color:var(--text-dim);
  padding:.35rem .75rem;
  border-radius:var(--radius);
  font-size:.9rem;
  transition:color .15s,background .15s,box-shadow .15s;
}
.nav-link:hover{
  color:var(--accent);
  background:rgba(107,160,208,.08);
  box-shadow:var(--glow);
}

/* Content */
.content{
  max-width:960px;
  margin:0 auto;
  padding:2rem 1rem 4rem;
  min-height:calc(100vh - var(--nav-h) - 60px);
}
.page-title{
  font-size:1.8rem;
  margin-bottom:1.5rem;
  color:var(--text-bright);
}
.page h1,.page h2,.page h3,.page h4{margin-top:1.5em;margin-bottom:.5em;color:var(--text-bright)}
.page h1{font-size:1.6rem;border-bottom:1px solid var(--border);padding-bottom:.3em}
.page h2{font-size:1.3rem}
.page h3{font-size:1.1rem}
.page p,.page ul,.page ol{margin-bottom:1rem}
.page ul,.page ol{padding-left:1.5rem}
.page li{margin-bottom:.25rem}
.page blockquote{
  border-left:3px solid var(--accent);
  padding:.5rem 1rem;
  margin:1rem 0;
  background:var(--surface);
  border-radius:0 var(--radius) var(--radius) 0;
  color:var(--text-dim);
}
.page table{
  width:100%;
  border-collapse:collapse;
  margin:1rem 0;
}
.page th,.page td{
  border:1px solid var(--border);
  padding:.5rem .75rem;
  text-align:left;
}
.page th{background:var(--surface);color:var(--text-bright)}
.page img{border-radius:var(--radius);margin:1rem 0}
.page hr{border:none;border-top:1px solid var(--border);margin:2rem 0}

/* Cards */
.card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1rem;
}
.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.25rem;
  transition:border-color .15s,box-shadow .15s;
}
.card:hover{border-color:var(--accent-dim);box-shadow:0 0 0 1px var(--accent-dim)}
.card-header{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-bottom:.5rem;
}
.card-header h3{font-size:1.1rem;color:var(--text-bright)}
.card-stars{color:var(--text-dim);font-size:.85rem;white-space:nowrap}
.card-desc{color:var(--text-dim);font-size:.9rem;margin-bottom:1rem;line-height:1.5}
.card-links{display:flex;gap:.5rem;flex-wrap:wrap}
.btn{
  display:inline-flex;
  align-items:center;
  padding:.4rem .85rem;
  border-radius:var(--radius);
  font-size:.85rem;
  cursor:pointer;
  border:1px solid var(--border);
  background:var(--surface2);
  color:var(--text);
  text-decoration:none;
  transition:border-color .15s,color .15s,box-shadow .15s;
  line-height:1;
}
.btn:hover{color:var(--accent);border-color:var(--accent-dim);box-shadow:var(--glow)}
.btn-gh,.btn-ext{color:var(--accent)}
.btn-readme{color:var(--text-dim)}

/* Portfolio cards */
.card-portfolio{padding:0;overflow:hidden}
.card-thumb{
  width:100%;
  aspect-ratio:16/9;
  overflow:hidden;
  background:var(--surface2);
}
.card-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.card-body{padding:1rem 1.25rem 1.25rem}
.card-body h3{font-size:1.1rem;color:var(--text-bright);margin-bottom:.75rem}

/* Overlay */
.overlay{
  display:none;
  position:fixed;
  inset:0;
  z-index:var(--overlay-z);
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(2px);
}
.overlay.open{display:block}
.overlay-inner{
  position:fixed;
  inset:var(--nav-h) 0 0 0;
  background:var(--bg);
  border-top:1px solid var(--border);
  display:flex;
  flex-direction:column;
}
.overlay-top{
  display:flex;
  justify-content:flex-end;
  gap:.5rem;
  padding:.5rem 1rem;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.overlay-close{
  background:none;
  border:none;
  color:var(--text-dim);
  font-size:1.5rem;
  cursor:pointer;
  padding:0 .25rem;
  line-height:1;
}
.overlay-close:hover{color:var(--text-bright)}
.overlay-toggle{
  background:var(--surface2);
  border:1px solid var(--border);
  color:var(--text-dim);
  padding:.25rem .6rem;
  border-radius:var(--radius);
  cursor:pointer;
  font-size:.8rem;
}
.overlay-toggle:hover{color:var(--accent);border-color:var(--accent-dim)}
.overlay-toggle.active{color:var(--accent);border-color:var(--accent-dim)}
.overlay-body{
  flex:1;
  display:grid;
  grid-template-columns:1fr;
  overflow:hidden;
}
.overlay-body.cols-dual{
  grid-template-columns:200px 1fr;
}
.overlay-toc{
  display:none;
  overflow-y:auto;
  padding:1rem;
  border-right:1px solid var(--border);
  background:var(--surface);
}
.overlay-body.cols-dual .overlay-toc{display:block}
.overlay-toc ul{list-style:none;padding:0}
.overlay-toc li{margin-bottom:.15rem}
.overlay-toc a{
  display:block;
  padding:.2rem .5rem;
  font-size:.85rem;
  color:var(--text-dim);
  border-radius:3px;
  transition:color .1s,background .1s;
}
.overlay-toc a:hover{color:var(--accent);background:rgba(107,160,208,.08)}
.overlay-toc .toc-h2{padding-left:1.2rem}
.overlay-toc .toc-h3{padding-left:2.4rem}
.overlay-content{
  flex:1;
  overflow-y:auto;
  padding:1.5rem 2rem;
}
.overlay-content h1{font-size:1.5rem;border-bottom:1px solid var(--border);padding-bottom:.3em;margin-bottom:.8em;color:var(--text-bright)}
.overlay-content h2{font-size:1.25rem;margin-top:1.5em;margin-bottom:.5em;color:var(--text-bright)}
.overlay-content h3{font-size:1.1rem;margin-top:1.2em;margin-bottom:.4em;color:var(--text-bright)}
.overlay-content p,.overlay-content ul,.overlay-content ol{margin-bottom:.8rem}
.overlay-content ul,.overlay-content ol{padding-left:1.5rem}
.overlay-content blockquote{
  border-left:3px solid var(--accent);
  padding:.4rem 1rem;
  margin:.8rem 0;
  background:var(--surface);
  border-radius:0 var(--radius) var(--radius) 0;
  color:var(--text-dim);
}
.overlay-content table{
  width:100%;
  border-collapse:collapse;
  margin:.8rem 0;
}
.overlay-content th,.overlay-content td{
  border:1px solid var(--border);
  padding:.4rem .6rem;
  text-align:left;
  font-size:.9rem;
}
.overlay-content th{background:var(--surface);color:var(--text-bright)}
.overlay-content img{border-radius:var(--radius);max-width:100%;margin:.8rem 0}

/* Footer */
.footer{
  border-top:1px solid var(--border);
  background:var(--surface);
  padding:1rem 0;
  text-align:center;
  color:var(--text-dim);
  font-size:.85rem;
}

/* Code highlighting */
.hl-string{color:#98c379}
.hl-comment{color:#5c6370;font-style:italic}
.hl-number{color:#d19a66}
.hl-keyword{color:#c678dd}
.hl-func{color:#61afef}
.hl-command{color:#56b6c2}

/* Responsive */
@media(max-width:640px){
  .nav-inner{flex-wrap:wrap;padding:0 .5rem;gap:0}
  .nav-logo{font-size:.95rem;margin-right:1rem}
  .nav-link{padding:.3rem .5rem;font-size:.82rem}
  .content{padding:1rem .5rem 3rem}
  .card-grid{grid-template-columns:1fr}
  .overlay-body.cols-dual{grid-template-columns:1fr}
  .overlay-body.cols-dual .overlay-toc{display:none}
  .overlay-content{padding:1rem}
}
