:root{
  /* Palette */
  --bg0:#070a12;
  --bg1:#0b1020;
  --surface: rgba(255,255,255,.06);
  --surface2: rgba(255,255,255,.045);
  --surface3: rgba(255,255,255,.035);

  --text:#eaf0ff;
  --muted:#b7c1dd;

  --border: rgba(255,255,255,.10);
  --border2: rgba(255,255,255,.14);

  --accent:#7c5cff;
  --accent2:#2dd4bf;
  --accent3:#ff4fd8;

  --shadow: 0 18px 60px rgba(0,0,0,.55);
  --shadow2: 0 10px 30px rgba(0,0,0,.40);
  --radius: 18px;

  --ease: cubic-bezier(.2,.8,.2,1);
  --dur: 180ms;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{
  margin:0;padding:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  line-height:1.55;
  color:var(--text);
  max-width:100%;
  overflow-x:hidden;
  background:
    radial-gradient(1200px 900px at 12% -10%, rgba(124,92,255,.25), transparent 55%),
    radial-gradient(900px 700px at 85% 0%, rgba(45,212,191,.16), transparent 55%),
    radial-gradient(900px 700px at 50% 110%, rgba(255,79,216,.10), transparent 60%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
}

/* Subtle grid texture (no image) */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.22;
  background:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(900px 700px at 50% 15%, black 35%, transparent 70%);
}

a{color:inherit;text-decoration:none}
.muted{color:var(--muted)}

:focus-visible{
  outline:2px solid rgba(124,92,255,.85);
  outline-offset:3px;
}

.container{
  max-width:1120px;
  margin:0 auto;
  padding-left:max(18px, env(safe-area-inset-left));
  padding-right:max(18px, env(safe-area-inset-right));
}

/* ===== Header / Nav ===== */
.header{position:relative}

.headerTop{
  position:sticky;
  top:0;
  z-index:1000;
  padding-top:env(safe-area-inset-top);
  background: rgba(7,10,18,.55);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:14px;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
}

.brand__dot{
  width:10px;height:10px;border-radius:999px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  box-shadow: 0 0 0 4px rgba(124,92,255,.12);
}

.brand__text{
  font-weight:900;
  letter-spacing:.3px;
}

.nav{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.nav a{
  opacity:.92;
  padding:8px 10px;
  border-radius: 12px;
  transition: background var(--dur) var(--ease), opacity var(--dur) var(--ease);
}

.nav a:hover{
  opacity:1;
  background: rgba(255,255,255,.06);
}

.nav__cta{
  padding:9px 12px;
  border:1px solid var(--border2);
  border-radius:999px;
  background: rgba(255,255,255,.04);
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}

.nav__cta:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.20);
}

.nav__cta--ghost{
  background: transparent;
}

.menuBtn{
  display:none;
  min-height:44px;
  min-width:44px;
  border:1px solid var(--border2);
  background: rgba(255,255,255,.04);
  color:var(--text);
  border-radius:14px;
  padding:10px 12px;
  font-size:18px;
  line-height:1;
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease);
}
.menuBtn:hover{transform: translateY(-1px); background: rgba(255,255,255,.07);}

.navBackdrop{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.62);
  opacity:0;
  pointer-events:none;
  transition: opacity 220ms var(--ease);
  z-index:1100;
}
.navBackdrop.show{opacity:1;pointer-events:auto}

/* ===== Hero ===== */
.hero{
  padding:28px 0 44px;
}


/* GitHub avatar */
.hero__avatarLink{
  display:inline-flex;
  width:96px;
  height:96px;
  border-radius:999px;
  padding:3px;
  background: linear-gradient(135deg, rgba(104,255,194,.9), rgba(124,92,255,.9));
  box-shadow: 0 12px 30px rgba(0,0,0,.35);
  margin: 8px 0 12px;
}
.hero__avatar{
  width:100%;
  height:100%;
  border-radius:999px;
  object-fit:cover;
  background: rgba(255,255,255,.06);
}
@media (max-width: 720px){
  .hero__avatarLink{ width:84px; height:84px; }
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  box-shadow: var(--shadow2);
  margin:0 0 12px;
}

/* ---- Hero title layout (avatar + title in one row) ---- */
.hero__title{
  margin:0 0 10px;
  font-weight:950;
  letter-spacing:-.9px;
  font-size: clamp(34px, 4.4vw, 52px);
  line-height: 1.05;

  display:flex;
  align-items:center;
  gap:16px;
}

.heroTitleText{
  display:inline-block;
}

.heroDot{ margin-left:2px; }

/* Avatar */
.ghAvatarLink{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
}

.ghAvatarLink[hidden]{
  display:none !important;
}

.ghAvatar{
  width:56px;
  height:56px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  box-shadow: 0 0 0 5px rgba(124,92,255,.12);
}

/* Responsive: stack nicely on very small screens */
@media (max-width: 520px){
  .hero__title{
    gap:12px;
  }
  .ghAvatar{
    width:46px;
    height:46px;
    box-shadow: 0 0 0 4px rgba(124,92,255,.12);
  }
}

.accent{
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.hero__subtitle{
  max-width: 880px;
  margin:0;
  color: rgba(234,240,255,.86);
}

.hero__actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:18px;
}

/* Premium button */
.btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 16px;
  min-height:44px;
  border-radius:14px;
  border:1px solid transparent;

  background:
    linear-gradient(rgba(255,255,255,.07), rgba(255,255,255,.04)) padding-box,
    linear-gradient(135deg, rgba(124,92,255,.55), rgba(45,212,191,.45)) border-box;

  color:var(--text);
  font-weight:850;
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), filter var(--dur) var(--ease);
}

.btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 55px rgba(0,0,0,.55);
  filter: brightness(1.02);
}
.btn:active{transform: translateY(0px) scale(.99);}

.btn--ghost{
  background:
    linear-gradient(rgba(255,255,255,.04), rgba(255,255,255,.02)) padding-box,
    linear-gradient(135deg, rgba(255,255,255,.20), rgba(255,255,255,.08)) border-box;
}

/* Stats */
.hero__stats{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}

.stat{
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(124,92,255,.12), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--shadow2);
  padding:14px;
}

.stat__value{font-weight:950;font-size:20px}
.stat__label{opacity:.92;font-size:13px;color: rgba(183,193,221,.92)}

/* ===== Sections ===== */
.section{
  padding:58px 0;
  scroll-margin-top: 92px;
}

.section__head{
  margin-bottom:16px;
}

.section__head h2{
  margin:0 0 8px;
  font-weight:950;
  letter-spacing:-.4px;
  font-size: 28px;
}

.section__head p{
  margin:0;
}

/* Sub-head inside a section (e.g., Featured repos) */
.section__subhead{
  margin:22px 0 10px;
}
.section__subhead h3{
  margin:0 0 6px;
  font-weight:950;
  letter-spacing:-.2px;
  font-size:18px;
}

#pinnedBlock{
  margin-bottom: 16px;
}

/* ===== Cards / Grids ===== */
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}

.card{
  position:relative;
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(45,212,191,.08), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--shadow2);
  padding:16px;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.card:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.14);
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(124,92,255,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
}

.list{margin:10px 0 0;padding-left:18px}
.badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.badge{
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(124,92,255,.14);
  font-size:13px;
}

/* ===== Toolbar (Projects) ===== */
.toolbar{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.select, .input{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color:var(--text);
  border-radius:14px;
  padding:10px 12px;
  min-height:44px;
  min-width:220px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.select{min-width:180px}
.select:hover, .input:hover{
  border-color: rgba(255,255,255,.20);
  background: rgba(255,255,255,.05);
}
.select:focus-visible, .input:focus-visible{
  border-color: rgba(124,92,255,.55);
}

.notice{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px dashed rgba(255,255,255,.16);
  background: rgba(255,255,255,.035);
  display:none;
}
.notice.show{display:block}

.state{margin-top:10px}

/* ===== Projects cards (equal height + no overflow) ===== */
#projects .grid3{align-items:stretch}

.repoCard{
  display:flex;
  flex-direction:column;
  height:100%;
  overflow:hidden;
}

.repoTop{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  min-width:0;
}

.repoName{
  font-weight:950;
  min-width:0;
  overflow-wrap:anywhere;
  word-break:break-word;
  letter-spacing:-.2px;
}

.repoMeta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
  min-width:0;
  max-width:100%;
}

/* Meta “pill” */
.metaPill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color: rgba(183,193,221,.95);
  font-size:12px;
  white-space:nowrap;
}

.metaPill--pin{
  background: rgba(124,92,255,.16);
  border-color: rgba(124,92,255,.30);
  color: rgba(234,240,255,.96);
}

.repoDesc{
  margin:10px 0 0;
  color: rgba(183,193,221,.92);

  display:-webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow:hidden;
  min-height: 3.6em;
}

.repoFooter{
  margin-top:auto;
  display:flex;
  justify-content:flex-end;
  padding-top:12px;
}

.smallBtn{
  border:1px solid transparent;
  border-radius:14px;
  padding:10px 14px;
  min-height:40px;
  font-weight:900;
  color:var(--text);
  background:
    linear-gradient(rgba(255,255,255,.05), rgba(255,255,255,.03)) padding-box,
    linear-gradient(135deg, rgba(124,92,255,.45), rgba(45,212,191,.35)) border-box;
  box-shadow: 0 12px 34px rgba(0,0,0,.35);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.smallBtn:hover{transform: translateY(-2px); box-shadow: 0 16px 44px rgba(0,0,0,.48);}
.smallBtn:active{transform: translateY(0px) scale(.99);}

/* Contact */
.contactRow{display:flex;gap:12px;flex-wrap:wrap}

/* Footer */
.footer{
  border-top:1px solid rgba(255,255,255,.06);
  padding:18px 0;
  background: rgba(7,10,18,.35);
  backdrop-filter: blur(10px);
}
.footer__inner{display:flex;align-items:center;justify-content:space-between}

.toTop{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color:var(--text);
  border-radius:14px;
  padding:8px 10px;
  min-height:40px;
  min-width:40px;
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease);
}
.toTop:hover{transform: translateY(-1px); background: rgba(255,255,255,.07);}

/* ===== Responsive ===== */
@media (max-width: 920px){
  .grid3{grid-template-columns:repeat(2,1fr)}
  .hero__stats{grid-template-columns:1fr}
}

@media (max-width: 680px){
  .grid2,.grid3{grid-template-columns:1fr}

  /* Drawer nav */
  .menuBtn{display:inline-flex}
  .nav{
    position:fixed;
    top:0; right:0;
    height:100vh;
    width:min(82vw, 360px);
    padding:calc(18px + env(safe-area-inset-top)) 18px 18px;

    background: rgba(10,14,26,.92);
    backdrop-filter: blur(16px);
    border-left: 1px solid rgba(255,255,255,.10);
    box-shadow: var(--shadow);
    z-index:1200;

    flex-direction:column;
    align-items:flex-start;
    gap:12px;

    transform: translateX(105%);
    transition: transform 220ms var(--ease);
    overflow-y:auto;
  }
  .nav.open{transform: translateX(0)}

  .nav a{width:100%}
  .nav__cta{width:100%; text-align:center}

  .select,.input{width:100%; min-width:0}
  .toolbar{gap:10px}

  /* Mobile project card: stack to avoid overflow */
  .repoTop{flex-direction:column; align-items:flex-start}
  .repoMeta{justify-content:flex-start}
  .repoCard{padding:14px}
  .repoDesc{-webkit-line-clamp:4; min-height:auto}
}

@media (max-width: 420px){
  .hero__actions{flex-direction:column}
  .hero__actions .btn{width:100%}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{transition:none !important; animation:none !important}
  body::before{display:none}
}
