*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--mono);
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  cursor:default;
}

/* Grain overlay */
body::before{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;
  z-index:1000;
  opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ─── NAV ─── */
nav{
  position:fixed;top:0;left:0;right:0;
  z-index:100;
  padding:20px 40px;
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(10,10,11,.6);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.logo{
  font-weight:700;font-size:13px;letter-spacing:-.02em;
  display:flex;align-items:center;gap:10px;
}
.logo-dot{
  width:8px;height:8px;background:var(--accent);border-radius:50%;
  box-shadow:0 0 12px var(--accent);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.nav-links{display:flex;gap:32px;font-size:12px;color:var(--ink-dim)}
.nav-links a{transition:color .2s;position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a::before{content:'/ ';color:var(--ink-faint)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--accent);box-shadow:0 0 8px var(--accent);opacity:0;transition:opacity .2s}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{opacity:1}
.nav-status{
  font-size:11px;color:var(--ink-dim);display:flex;align-items:center;gap:8px;
}
.status-dot{
  position:relative;
  width:6px;height:6px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 8px var(--accent);
  flex-shrink:0;
}
.status-dot::after{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  border:1.5px solid var(--accent);opacity:0;
  animation:ping 1.8s ease-out infinite;
}
@keyframes ping{
  0%{transform:scale(.6);opacity:.8}
  100%{transform:scale(2.2);opacity:0}
}

/* ─── LAYOUT ─── */
section{
  padding:120px 40px;
  position:relative;
  border-bottom:1px solid var(--line);
}
.container{max-width:1280px;margin:0 auto}
.section-label{
  display:flex;align-items:center;gap:12px;
  font-size:11px;color:var(--ink-faint);
  letter-spacing:.15em;text-transform:uppercase;
  margin-bottom:48px;
  font-weight:500;
}
.section-label::before{
  content:'';width:32px;height:1px;background:var(--accent);
}
.section-num{color:var(--accent)}

/* ─── HERO ─── */
.hero{
  min-height:100vh;
  padding:clamp(90px,12vh,160px) 40px clamp(40px,6vh,80px);
  display:flex;flex-direction:column;justify-content:center;
  position:relative;
}
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at 70% 30%,black 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at 70% 30%,black 30%,transparent 75%);
  opacity:.5;
  pointer-events:none;
}
.hero-glow{
  position:absolute;
  top:10%;right:5%;
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(212,255,63,.08),transparent 60%);
  filter:blur(40px);
  pointer-events:none;
}
.hero-inner{
  max-width:1280px;margin:0 auto;width:100%;
  display:grid;grid-template-columns:1.2fr .9fr;gap:80px;align-items:center;
  position:relative;z-index:2;
}
.hero-identity{
  display:flex;flex-direction:column;gap:6px;
  margin-bottom:28px;
}
.hero-name{
  font-family:var(--serif);
  font-size:38px;font-weight:400;
  color:var(--ink);
  letter-spacing:-.02em;
  line-height:1;
}
.hero-role{
  font-size:13px;color:var(--accent);
  letter-spacing:.15em;text-transform:uppercase;
  font-weight:500;
}

.hero-meta{
  font-size:11px;color:var(--ink-dim);
  display:flex;gap:16px;margin-bottom:32px;
  letter-spacing:.1em;text-transform:uppercase;
}
.hero-meta span{display:flex;align-items:center;gap:6px}
.hero-meta .dot{width:4px;height:4px;background:var(--ink-faint);border-radius:50%}

h1.hero-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(48px,7vw,96px);
  line-height:.95;
  letter-spacing:-.04em;
  margin-bottom:32px;
}
.hero-title .em{
  font-style:italic;
  font-weight:400;
  color:var(--accent);
}
.hero-title .strike{
  position:relative;display:inline-block;
}
.hero-title .strike::after{
  content:'';position:absolute;left:-4px;right:-4px;top:55%;height:3px;
  background:var(--accent);
  transform:scaleX(0);transform-origin:left;
  animation:strike 1.2s ease-out 1.4s forwards;
}
@keyframes strike{to{transform:scaleX(1)}}

.hero-sub{
  font-family:var(--serif);
  font-size:18px;
  color:var(--ink-dim);
  max-width:700px;
  margin-bottom:48px;
  line-height:1.5;
}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:-24px}
.btn{
  font-family:var(--mono);
  font-size:12px;font-weight:500;
  padding:14px 24px;
  letter-spacing:.05em;text-transform:uppercase;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:all .2s;
  border:1px solid transparent;
  width:200px;
}
.btn-primary{
  background:var(--accent);color:#0a0a0b;
}
.btn-primary:hover{
  background:transparent;color:var(--accent);
  border-color:var(--accent);
  box-shadow:0 0 24px rgba(212,255,63,.3);
}
.btn-ghost{
  border:1px solid var(--line-strong);color:var(--ink-dim);
}
.btn-ghost:hover{
  border-color:var(--accent);color:var(--accent);
}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary:hover .arrow,
.btn-ghost:hover .arrow{
  transform:translateX(8px);
  text-shadow:0 0 8px currentColor,
              -4px 0 6px rgba(212,255,63,.4),
              -8px 0 4px rgba(212,255,63,.2);
}
.btn-amber:hover .arrow{
  transform:translateY(8px);
  text-shadow:0 0 8px currentColor,
              0 -4px 6px rgba(255,179,71,.4),
              0 -8px 4px rgba(255,179,71,.2);
}
.btn-amber{
  background:var(--amber);color:#0a0a0b;
}
.btn-amber:hover{
  background:transparent;color:var(--amber);
  border-color:var(--amber);
  box-shadow:0 0 24px rgba(255,179,71,.2);
}

/* ─── TERMINAL ─── */
.terminal{
  background:var(--bg-card);
  border:1px solid var(--line-strong);
  border-radius:8px;
  overflow:hidden;
  font-size:13px;
  box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 0 1px rgba(212,255,63,.03);
}
.terminal-bar{
  background:#08080A;
  padding:10px 14px;
  display:flex;align-items:center;gap:8px;
  border-bottom:1px solid var(--line);
}
.term-dot{width:10px;height:10px;border-radius:50%}
.term-dot.r{background:#FF5F56}
.term-dot.y{background:#FFBD2E}
.term-dot.g{background:#27C93F}
.terminal-bar-title{
  flex:1;text-align:center;color:var(--ink-faint);
  font-size:12px;letter-spacing:.05em;
}
.terminal-body{
  padding:24px 26px;
  min-height:440px;
  font-family:var(--mono);
  line-height:1.7;
}
.term-line{display:flex;gap:10px;color:var(--ink-dim);font-size:13px;opacity:0;animation:fadeUp .4s forwards}
.term-line .prompt{color:var(--accent)}
.term-line .pass{color:var(--accent);font-weight:500}
.term-line .fail{color:var(--red)}
.term-line .skip{color:var(--amber)}
.term-line .dim{color:var(--ink-faint)}
.term-line .ok{color:var(--ink)}
.cursor{
  display:inline-block;width:7px;height:13px;
  background:var(--accent);
  animation:blink 1s steps(1) infinite;
  vertical-align:text-bottom;
}
@keyframes blink{50%{opacity:0}}
@keyframes fadeUp{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ─── ABOUT ─── */
.about-grid{
  display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:start;
}
.about-side{position:sticky;top:120px}
.about-profile-img{
  display:block;
  width:min(100%,420px);
  aspect-ratio:1;
  object-fit:cover;
  border:1px solid var(--line-strong);
  border-radius:8px;
}
.about-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px;
}
.stat{
  border-top:1px solid var(--line-strong);
  padding-top:16px;
}
.stat-num{
  font-family:var(--serif);
  font-size:48px;font-weight:300;
  color:var(--accent);
  line-height:1;
  letter-spacing:-.04em;
}
.stat-label{
  font-size:10px;color:var(--ink-dim);
  letter-spacing:.1em;text-transform:uppercase;
  margin-top:8px;
}
.about-text{
  font-family:var(--serif);font-size:21px;line-height:1.65;color:var(--ink);
  font-weight:300;margin-top:-68px;
}
.about-text p{margin-bottom:24px}
.about-text .accent{color:var(--accent);font-style:italic}
.about-text strong{color:var(--ink);font-weight:500}

/* ─── SKILLS ─── */
.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.skill-cat{
  background:var(--bg);
  padding:32px 24px;
  min-height:280px;
  display:flex;flex-direction:column;
  transition:background .3s,border-color .2s,box-shadow .2s;
  border:1px solid var(--line);
}
.skill-cat:hover{background:var(--bg-elevated);border-color:var(--amber);box-shadow:0 0 24px rgba(255,179,71,.2)}
.skill-cat-num{
  font-size:11px;color:var(--ink-faint);
  letter-spacing:.1em;margin-bottom:12px;
}
.skill-cat-name{
  font-family:var(--mono);
  font-size:13px;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--accent);
  padding-bottom:10px;margin-bottom:16px;
  border-bottom:1px solid var(--line);
}
.skill-tags{display:flex;flex-wrap:wrap;gap:6px}

/* ─── CERTIFICATIONS ─── */
.certs-label{
  font-size:11px;color:var(--ink-faint);
  letter-spacing:.1em;
  margin-top:32px;margin-bottom:12px;
  padding-left:2px;
}
.certs-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--line);
  border:1px solid var(--line);
}
.cert-card{
  background:var(--bg);
  padding:24px;
  display:flex;flex-direction:column;gap:6px;
  transition:background .3s,border-color .2s,box-shadow .2s;
  border:1px solid var(--line);
}
.cert-card:hover{background:var(--bg-elevated);border-color:var(--amber);box-shadow:0 0 24px rgba(255,179,71,.2)}
.cert-num{
  font-size:11px;color:var(--ink-dim);
  letter-spacing:.1em;margin-bottom:4px;
}
.cert-name{
  font-family:var(--mono);font-size:13px;font-weight:700;
  color:var(--accent);line-height:1.35;
}
.cert-meta{
  font-size:12px;color:var(--ink-dim);
  font-family:var(--mono);
}
.cert-year{
  font-size:11px;color:var(--ink-dim);
  margin-top:auto;padding-top:8px;
  border-top:1px solid var(--line);
}

/* ─── EXPERIENCE — GIT LOG ─── */
.git-header{
  display:flex;align-items:center;justify-content:space-between;
  font-size:11px;color:var(--ink-faint);
  padding-bottom:16px;margin-bottom:24px;
  border-bottom:1px solid var(--line);
  letter-spacing:.05em;
  font-family:var(--mono);
}
.git-header .branch-pill{
  color:var(--accent);
  display:inline-flex;align-items:center;gap:8px;
  padding:4px 10px;
  border:1px solid var(--accent);
  border-radius:2px;
  background:rgba(212,255,63,.05);
  font-size:11px;
  letter-spacing:.02em;
}
.git-header .branch-pill::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 6px var(--accent);
}
.git-header .meta-right{display:flex;gap:20px}
.git-header .meta-right span{color:var(--ink-dim)}
.git-header .meta-right .ok{color:var(--accent)}

.gitlog{
  position:relative;
  font-family:var(--mono);
}
.commit{
  display:grid;
  grid-template-columns:80px 32px 1fr;
  gap:0;
  position:relative;
  padding:8px 8px 32px 8px;
  cursor:pointer;
  transition:background .2s;
  border-radius:4px;
}
.commit:hover{background:rgba(212,255,63,.025)}
.commit:hover .commit-msg{color:var(--accent)}

.commit-rail{
  position:relative;
  display:flex;justify-content:center;
}
.commit-rail::before{
  content:'';
  position:absolute;
  left:50%;top:0;bottom:-32px;
  width:1px;
  background:var(--line-strong);
  transform:translateX(-50%);
}
.commit:last-child .commit-rail::before{
  background:linear-gradient(to bottom,var(--line-strong) 0%,transparent 100%);
}
.commit-node{
  position:relative;z-index:2;
  width:14px;height:14px;
  border-radius:50%;
  background:var(--bg);
  border:2px solid var(--accent);
  margin-top:6px;
  box-shadow:0 0 0 4px var(--bg),0 0 12px rgba(212,255,63,.4);
  transition:all .3s;
}
.commit:hover .commit-node{
  background:var(--accent);
  box-shadow:0 0 0 4px var(--bg),0 0 20px var(--accent);
  transform:scale(1.15);
}
.commit.merge:hover .commit-node{
  background:var(--accent);
  box-shadow:0 0 0 4px var(--bg),0 0 20px var(--accent);
  transform:scale(1.15);
}

.commit-hash{
  font-size:11px;color:var(--ink-faint);
  padding-top:8px;
  text-align:right;padding-right:16px;
  letter-spacing:.05em;
  font-weight:500;
  font-family:var(--mono);
}

.commit-body{
  padding-left:24px;padding-top:4px;
  min-width:0;
}
.commit-meta-row{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-size:11px;color:var(--ink-faint);
  margin-bottom:10px;
  font-family:var(--mono);
}
.commit-author{color:var(--ink-dim)}
.commit-author::before{content:'<';color:var(--ink-faint)}
.commit-author::after{content:'>';color:var(--ink-faint)}
.commit-date{color:var(--amber)}.commit-date.current{font-weight:500}
.commit-tag{
  font-size:10px;color:var(--accent);
  border:1px solid var(--accent);
  padding:1px 8px;
  border-radius:2px;
  letter-spacing:.05em;
  background:rgba(212,255,63,.05);
  text-transform:uppercase;
}
.commit-tag.head{
  background:var(--accent);color:#0a0a0b;font-weight:500;
}
.commit-tag.merge-tag{
  color:var(--ink-dim);border-color:var(--line-strong);
  background:transparent;
}
.commit-msg{
  font-family:var(--serif);
  font-size:24px;font-weight:400;
  letter-spacing:-.01em;
  line-height:1.25;
  margin-bottom:6px;
  color:var(--ink);
  transition:color .2s;
}
.commit-company{
  font-size:12px;color:var(--accent);
  margin-bottom:18px;letter-spacing:.02em;
  font-family:var(--mono);
}
.org-block{
  margin-bottom:10px;padding-bottom:10px;
  border-bottom:1px solid var(--line);
}
.org-name{
  font-size:13px;color:var(--accent);
  font-family:var(--mono);font-weight:500;
  letter-spacing:.02em;line-height:1.3;
}
.org-loc{
  font-size:11px;color:var(--ink-faint);
  font-family:var(--mono);margin-top:3px;
  display:flex;align-items:center;gap:5px;
  font-weight:700;
}
.org-loc::before{content:'⌖';font-size:13px;color:var(--ink-mid)}
.products-row{
  display:flex;align-items:center;gap:8px;
  flex-wrap:wrap;margin-bottom:16px;
}
.products-label{
  font-size:9px;color:var(--ink-faint);
  letter-spacing:.12em;text-transform:uppercase;
  flex-shrink:0;font-family:var(--mono);
}
.product-chip{
  font-size:10px;color:var(--amber);
  border:1px solid rgba(255,179,71,.35);
  background:rgba(255,179,71,.05);
  padding:3px 9px;border-radius:2px;
  letter-spacing:.04em;font-family:var(--mono);
}
.commit-diff{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-left:2px solid var(--accent);
  padding:14px 18px;
  margin-bottom:14px;
}
.diff-line{
  display:flex;gap:10px;
  line-height:1.6;
  padding:3px 0;
}
.diff-line .sign{
  flex-shrink:0;
  color:var(--accent);font-weight:500;
  user-select:none;
  font-family:var(--mono);
  font-size:13px;
  padding-top:2px;
}
.diff-line .text{
  font-family:var(--mono);
  font-size:12px;
  color:var(--ink-dim);
  line-height:1.6;
}
.diff-line .text strong{color:var(--ink);font-weight:500}

.commit-files{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-size:10px;color:var(--ink-faint);
  margin-top:14px;
}
.commit-files .label{
  color:var(--ink-faint);
  letter-spacing:.05em;text-transform:uppercase;
  margin-right:4px;
  font-family:var(--mono);
}
.commit-files .file{
  font-size:10px;color:var(--ink-dim);
  padding:3px 8px;
  border:1px solid var(--line-strong);
  border-radius:2px;
  letter-spacing:.02em;
  background:var(--bg);
  font-family:var(--mono);
  transition:transform .15s ease,border-color .15s ease,color .15s ease,background .15s ease;
  cursor:default;
}
.commit-files .file:hover{
  transform:translateY(-2px);
  border-color:var(--accent);
  color:var(--ink);
  background:var(--bg-elevated);
}
.commit-files .file::before{
  content:'+ ';color:var(--accent);font-weight:500;
}

.chip{
  font-size:14px;color:var(--ink-dim);
  padding:5px 12px;
  border:1px solid var(--line-strong);
  border-radius:2px;
  letter-spacing:.03em;
  font-family:var(--mono);
}
.skill-tags .chip{
  transition:transform .15s ease,border-color .15s ease,color .15s ease,background .15s ease;
  cursor:default;
}
.skill-tags .chip:hover{
  transform:translateY(-2px);
  border-color:var(--accent);
  color:var(--ink);
  background:var(--bg-elevated);
}


/* ─── PROJECTS ─── */
.projects-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.project{
  background:var(--bg-card);
  border:1px solid var(--line);
  padding:32px;
  position:relative;
  overflow:hidden;
  transition:all .3s;
  cursor:pointer;
}
.project:hover{
  border-color:var(--accent);
  background:var(--bg-elevated);
  transform:translateY(-2px);
}
.project::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  transform:translateX(-100%);transition:transform .6s;
}
.project:hover::before{transform:translateX(100%)}
.project-meta{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:24px;
}
.project-num{
  font-size:11px;color:var(--ink-faint);letter-spacing:.1em;
}
.project-status{
  font-size:10px;color:var(--accent);
  display:flex;align-items:center;gap:6px;
  letter-spacing:.05em;text-transform:uppercase;
}
.project-status .dot{
  width:6px;height:6px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 8px var(--accent);
}
.project-title{
  font-family:var(--serif);
  font-size:32px;font-weight:400;
  letter-spacing:-.02em;
  margin-bottom:8px;line-height:1.15;
}
.project-tagline{
  font-size:12px;color:var(--ink-dim);
  margin-bottom:24px;letter-spacing:.02em;
}
.project-block{margin-bottom:16px}
.project-block-label{
  font-size:10px;color:var(--accent);
  letter-spacing:.15em;text-transform:uppercase;
  margin-bottom:6px;font-weight:500;
}
.project-block-text{
  font-size:13px;color:var(--ink-dim);line-height:1.6;
  font-family:var(--serif);
}
.project-impact{
  margin-top:24px;padding-top:20px;
  border-top:1px solid var(--line);
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.impact-num{
  font-family:var(--serif);font-size:28px;font-weight:300;
  color:var(--accent);line-height:1;letter-spacing:-.02em;
}
.impact-label{
  font-size:10px;color:var(--ink-dim);
  letter-spacing:.1em;text-transform:uppercase;margin-top:6px;
}
.project-stack{
  display:flex;flex-wrap:wrap;gap:6px;margin-top:20px;
}

/* ─── BLOGS ─── */
.blogs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}
.blog-card{background:var(--bg-card);border:1px solid var(--line);padding:24px;display:flex;flex-direction:column;gap:12px;transition:border-color .2s,box-shadow .2s}
.blog-card:hover{border-color:var(--accent);box-shadow:0 0 24px rgba(212,255,63,.2)}
.blog-card-top{display:flex;justify-content:space-between;align-items:flex-start}
.blog-card-num{font-size:11px;color:var(--ink-faint)}
.blog-card-tag{font-size:10px;padding:3px 8px;border:1px solid var(--line);color:var(--accent);letter-spacing:.08em;text-transform:uppercase}
.blog-card-title{font-size:14px;color:var(--ink);line-height:1.45;font-weight:500}
.blog-card-excerpt{font-size:12px;color:var(--ink-dim);line-height:1.65;flex:1}
.blog-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--line);margin-top:auto}
.blog-card-meta{font-size:11px;color:var(--amber)}
.blog-card-link{font-size:11px;color:var(--accent);letter-spacing:.04em;transition:letter-spacing .15s}
.blog-card-link:hover{letter-spacing:.08em}
.blogs-cta{display:flex;justify-content:flex-end;margin-top:8px}
.view-all-link{font-size:12px;color:var(--ink-dim);border-bottom:1px solid var(--line);padding-bottom:4px;transition:color .2s,border-color .2s}
.view-all-link:hover{color:var(--accent);border-color:var(--accent)}

/* ─── CONTACT ─── */
.contact{padding:140px 40px 100px;text-align:center;position:relative}
.contact-glow{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:800px;height:800px;
  background:radial-gradient(circle,rgba(212,255,63,.06),transparent 60%);
  filter:blur(60px);pointer-events:none;
}
.contact-pretitle{
  font-size:11px;color:var(--accent);
  letter-spacing:.2em;text-transform:uppercase;
  margin-bottom:24px;
}
.contact-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(48px,8vw,120px);
  line-height:.95;letter-spacing:-.04em;
  margin-bottom:48px;
  position:relative;
}
.contact-title em{font-style:italic;color:var(--accent);font-weight:400}
.contact-email{
  display:inline-flex;align-items:center;gap:8px;
  font-size:18px;color:var(--ink);
  border-bottom:1px solid var(--accent);
  padding-bottom:4px;
  margin-bottom:48px;
  transition:color .2s;
  position:relative;cursor:pointer;
}
.contact-email:hover{color:var(--accent)}
.contact-email::after{
  content:'copied!';
  position:absolute;
  top:-32px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#000;
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 10px;border-radius:4px;
  opacity:0;pointer-events:none;
  transition:opacity .2s;
}
.contact-email.copied{color:var(--accent)}
.contact-email.copied::after{opacity:1}
.contact-socials{display:flex;justify-content:center;gap:32px;font-size:12px}
.contact-socials a{
  color:var(--ink-dim);
  letter-spacing:.05em;
  transition:color .2s;
  display:flex;align-items:center;gap:6px;
}
.contact-socials a:hover{color:var(--accent)}
.contact-socials a svg{flex-shrink:0}

footer{
  padding:32px 40px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;color:var(--ink-faint);
  border-top:1px solid var(--line);
  letter-spacing:.05em;
}
footer .build-info{display:flex;gap:16px;align-items:center}
footer .ok{color:var(--accent)}

/* ─── VISITOR COUNTER ─── */
.visitor-counter{
  display:flex;align-items:center;gap:8px;
  padding:12px 16px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  border-radius:8px;
  font-size:12px;
  color:var(--ink-dim);
  transition:all .3s ease;
  position:relative;
  overflow:hidden;
}
.visitor-counter.loaded{
  animation:borderLine 2s ease-in-out 1;
}
@keyframes borderLine{
  0%{
    border-color:var(--accent);
    box-shadow:0 0 0 0 rgba(251,146,60,.4);
  }
  50%{
    box-shadow:0 0 0 4px rgba(251,146,60,.1);
  }
  100%{
    border-color:var(--accent);
    box-shadow:0 0 0 0 rgba(251,146,60,0);
  }
}
.visitor-counter:hover{
  background:rgba(255,255,255,.06);
  color:var(--ink);
  border-color:var(--accent);
}
.visitor-counter-icon{
  width:16px;height:16px;
  display:flex;align-items:center;justify-content:center;
  opacity:.6;
}
.visitor-counter-text{
  letter-spacing:.03em;
}
.visitor-counter-number{
  color:var(--accent);
  font-weight:600;
  font-family:var(--mono);
}

/* ─── RESPONSIVE ─── */
@media (max-width:980px){
  nav{padding:16px 20px}
  .nav-links{display:none}
  .nav-status{display:none}
  section{padding:80px 20px}
  .hero{padding:120px 20px 60px}
  .hero-inner{grid-template-columns:1fr;gap:48px}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .about-side{position:static}
  .skills-grid{grid-template-columns:1fr 1fr}
  .certs-row{grid-template-columns:1fr 1fr}
  .commit{grid-template-columns:50px 24px 1fr;padding:8px 0 28px}
  .commit-hash{font-size:10px;padding-right:8px}
  .commit-body{padding-left:14px}
  .commit-msg{font-size:20px}
  .git-header{flex-direction:column;align-items:flex-start;gap:8px}
  .git-header .meta-right{flex-wrap:wrap;gap:12px}
  .projects-grid{grid-template-columns:1fr}
  .blogs-grid{grid-template-columns:1fr}
  .pipeline{flex-direction:column;align-items:stretch}
  .stage::after{content:'↓';right:50%;top:auto;bottom:-14px;transform:translateX(50%)}
  footer{flex-direction:column;gap:12px}
}
