/* ═══════════════════════════════════════════
   ROOT VARIABLES
═══════════════════════════════════════════ */
:root {
  --bg:     #080808;
  --bg2:    #101010;
  --card:   rgba(18,18,18,0.92);
  --glass:  rgba(8,8,8,0.78);
  --border: rgba(200,200,200,0.10);
  --b2:     rgba(200,200,200,0.20);

  --tx:  #f0f0f0;
  --tx2: #909090;
  --tx3: #555555;

  --silver:  #c0c0c0;
  --silver2: #e8e8e8;

  --grad:    linear-gradient(135deg,#606060,#c8c8c8);
  --grad-tx: linear-gradient(135deg,#b0b0b0,#f0f0f0);

  --sb: 240px;
  --mob-h: 58px;
  --ease: cubic-bezier(.4,0,.2,1);
  --spring: cubic-bezier(.34,1.56,.64,1);
  --t: .3s;
}

/* ═══════════════════════════════════════════
   RESET
═══════════════════════════════════════════ */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; font-size:16px }
body {
  font-family:'Space Grotesk',sans-serif;
  background:var(--bg);
  color:var(--tx);
  line-height:1.65;
  overflow-x:hidden;
  cursor:none;
}
body.locked { overflow:hidden }
a  { text-decoration:none; color:inherit }
ul { list-style:none }
img { max-width:100%; display:block }
button { cursor:pointer; border:none; background:none; font-family:inherit }
input,textarea { font-family:inherit; color:var(--tx) }
* { cursor:none !important }
::-webkit-scrollbar { width:4px }
::-webkit-scrollbar-track { background:var(--bg) }
::-webkit-scrollbar-thumb { background:var(--silver); border-radius:2px }

/* ═══════════════════════════════════════════
   WATER CANVAS
═══════════════════════════════════════════ */
#waterCanvas {
  position:fixed; inset:0;
  width:100%; height:100%;
  z-index:0; pointer-events:none;
}

/* ═══════════════════════════════════════════
   RIPPLE (click effect)
═══════════════════════════════════════════ */
.w-ripple {
  position:fixed;
  border-radius:50%;
  border:1px solid rgba(200,200,200,0.55);
  transform:translate(-50%,-50%) scale(0);
  animation:rippleOut 1.1s var(--ease) forwards;
  pointer-events:none;
  z-index:9990;
}
@keyframes rippleOut {
  0%   { transform:translate(-50%,-50%) scale(0); opacity:0.9 }
  100% { transform:translate(-50%,-50%) scale(5); opacity:0;
         border-color:rgba(200,200,200,0.05) }
}

/* ═══════════════════════════════════════════
   CUSTOM CURSOR
═══════════════════════════════════════════ */
#cur-dot, #cur-ring {
  position:fixed; top:0; left:0;
  pointer-events:none; z-index:99999;
  border-radius:50%;
  transform:translate(-50%,-50%);
  will-change:left,top;
  transition:width .2s var(--spring), height .2s var(--spring);
}
#cur-dot {
  width:10px; height:10px;
  background:var(--silver2);
  box-shadow:0 0 10px var(--silver), 0 0 22px rgba(200,200,200,.5);
}
#cur-ring {
  width:40px; height:40px;
  border:1.5px solid rgba(200,200,200,.55);
  box-shadow:0 0 8px rgba(200,200,200,.12);
  transition:width .35s var(--spring), height .35s var(--spring),
             border-color .3s;
}
body.cur-hov #cur-dot { width:6px; height:6px; background:#fff; box-shadow:0 0 8px #fff }
body.cur-hov #cur-ring { width:56px; height:56px; border-color:rgba(200,200,200,.9) }
body.cur-click #cur-dot { width:16px; height:16px }
body.cur-click #cur-ring { width:28px; height:28px }

/* ═══════════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════════ */
.sidebar {
  position:fixed; top:0; left:0; bottom:0;
  width:var(--sb);
  z-index:100;
  display:flex; flex-direction:column;
  background:rgba(6,6,6,.92);
  backdrop-filter:blur(28px) saturate(140%);
  -webkit-backdrop-filter:blur(28px) saturate(140%);
  border-right:1px solid var(--border);
  box-shadow:2px 0 40px rgba(0,0,0,.7);
  padding:0;
}

.sb-logo {
  padding:28px 24px 24px;
  border-bottom:1px solid var(--border);
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:20px; font-weight:800; letter-spacing:-.5px;
}
.sb-logo-b { color:var(--silver) }

.sb-nav {
  flex:1; padding:20px 12px;
  display:flex; flex-direction:column; gap:2px;
}
.sb-link {
  display:flex; align-items:center; gap:12px;
  padding:11px 14px; border-radius:10px;
  font-size:14px; font-weight:600; letter-spacing:.2px;
  color:var(--tx2); position:relative; overflow:hidden;
  transition:color var(--t), background var(--t), transform var(--t);
}
.sb-link:hover { color:var(--tx); transform:translateX(3px) }
.sb-link:hover .sb-icon { color:var(--silver) }
.sb-link.active {
  color:#fff;
  background:linear-gradient(90deg,rgba(200,200,200,.10),rgba(200,200,200,.03));
}
.sb-link.active::before {
  content:'';
  position:absolute; left:0; top:15%; bottom:15%;
  width:2.5px; background:var(--silver); border-radius:0 2px 2px 0;
}
.sb-icon {
  width:18px; display:flex; justify-content:center;
  font-size:14px; flex-shrink:0;
  color:var(--tx3); transition:color var(--t);
}
.sb-link.active .sb-icon { color:var(--silver) }

.sb-bottom {
  padding:20px 12px 24px;
  border-top:1px solid var(--border);
}
.sb-socials {
  display:flex; gap:8px; justify-content:center;
  margin-bottom:16px;
}
.sb-soc {
  width:36px; height:36px; border-radius:50%;
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; color:var(--tx3);
  transition:all var(--t);
}
.sb-soc:hover { border-color:var(--silver); color:var(--silver); transform:translateY(-2px) }
.sb-status {
  display:flex; align-items:center; gap:7px;
  font-size:11px; color:var(--tx3);
  justify-content:center;
}
.sb-dot-green {
  width:7px; height:7px; border-radius:50%;
  background:#22c55e;
  box-shadow:0 0 7px #22c55e;
  animation:sdPulse 2s ease-in-out infinite;
}
@keyframes sdPulse { 0%,100%{opacity:1} 50%{opacity:.4} }

/* ═══════════════════════════════════════════
   MOBILE HEADER
═══════════════════════════════════════════ */
.mob-header {
  display:none;
  position:fixed; top:0; left:0; right:0;
  height:var(--mob-h); z-index:200;
  align-items:center; justify-content:space-between;
  padding:0 20px;
  background:rgba(6,6,6,.96);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.mob-logo {
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:18px; font-weight:800;
}
.mob-logo span { color:var(--silver) }
.mob-burger {
  display:flex; flex-direction:column; gap:5px;
  width:32px; height:32px; align-items:center; justify-content:center;
}
.mob-burger span {
  display:block; width:20px; height:2px;
  background:var(--tx); border-radius:2px;
  transition:transform var(--t), opacity var(--t);
}
.mob-burger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg) }
.mob-burger.open span:nth-child(2) { opacity:0 }
.mob-burger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg) }

.mob-menu {
  display:none;
  position:fixed; inset:0; z-index:190;
  background:rgba(6,6,6,.98);
  backdrop-filter:blur(32px);
  padding-top:var(--mob-h);
  opacity:0; pointer-events:none;
  transition:opacity .25s var(--ease);
}
.mob-menu.open { opacity:1; pointer-events:all }
.mob-nav { padding:20px 0 }
.mob-nav a {
  display:flex; align-items:center; gap:14px;
  padding:16px 28px; font-size:20px; font-weight:700;
  color:var(--tx2); border-bottom:1px solid var(--border);
  transition:color var(--t), padding var(--t);
}
.mob-nav a:hover, .mob-nav a.active { color:var(--silver); padding-left:36px }
.mob-nav a i { font-size:16px; width:18px; color:var(--tx3) }
.mob-nav a:hover i, .mob-nav a.active i { color:var(--silver) }

/* ═══════════════════════════════════════════
   MAIN LAYOUT
═══════════════════════════════════════════ */
.main { margin-left:var(--sb); position:relative; z-index:1 }

/* ═══════════════════════════════════════════
   SECTION WRAPPER
═══════════════════════════════════════════ */
.sec { padding:72px 60px; min-height:100vh }
.sec-head { margin-bottom:56px }
.sec-eyebrow {
  font-family:'JetBrains Mono',monospace;
  font-size:11px; font-weight:600; letter-spacing:3px; text-transform:uppercase;
  color:var(--silver); display:block; margin-bottom:12px;
}
.sec-title {
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(32px,4vw,52px);
  font-weight:800; letter-spacing:-1.5px; line-height:1.08;
}
.grad { background:var(--grad-tx); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text }
.sec-line { width:48px; height:3px; background:var(--grad); border-radius:2px; margin-top:20px }

/* ═══════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  font-family:'Space Grotesk',sans-serif; font-size:14px; font-weight:700;
  padding:12px 26px; border-radius:50px;
  transition:all var(--t) var(--ease);
  position:relative; overflow:hidden;
}
.btn-prim {
  background:var(--grad); color:#0a0a0a;
  box-shadow:0 0 20px rgba(180,180,180,.15),0 6px 24px rgba(0,0,0,.4);
}
.btn-prim:hover { transform:translateY(-2px); box-shadow:0 0 32px rgba(200,200,200,.25),0 10px 36px rgba(0,0,0,.5) }
.btn-sec {
  background:transparent; color:var(--tx);
  border:1.5px solid rgba(200,200,200,.25);
}
.btn-sec:hover { border-color:var(--silver); color:var(--silver); background:rgba(200,200,200,.06); transform:translateY(-2px) }

/* ═══════════════════════════════════════════
   REVEAL ANIMATIONS
═══════════════════════════════════════════ */
.rv-up,.rv-l,.rv-r {
  opacity:0;
  transition:opacity .7s var(--ease),transform .7s var(--ease);
  transition-delay:var(--d,0s);
}
.rv-up { transform:translateY(44px) }
.rv-l  { transform:translateX(-52px) }
.rv-r  { transform:translateX(52px) }
.rv-up.in,.rv-l.in,.rv-r.in { opacity:1; transform:none }

/* ═══════════════════════════════════════════
   HOME PAGE
═══════════════════════════════════════════ */
.home-sec {
  min-height:100vh;
  display:flex; flex-direction:column; justify-content:center;
  padding:60px;
  position:relative;
}

.home-top {
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:40px; margin-bottom:40px;
}
.home-text { flex:1; max-width:680px }

/* Pixel name */
.home-name {
  font-family:'JetBrains Mono',monospace;
  font-size:clamp(28px,4vw,48px);
  font-weight:700; letter-spacing:4px; text-transform:uppercase;
  color:var(--silver2);
  text-shadow:0 0 30px rgba(200,200,200,.35);
  margin-bottom:10px;
  line-height:1.2;
}
.home-role {
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(13px,1.5vw,16px); font-weight:500;
  color:var(--tx2); letter-spacing:.3px;
  margin-bottom:18px;
}
.home-role b { color:var(--tx); font-weight:700 }
.home-bio {
  font-size:15px; color:var(--tx2); line-height:1.8;
  max-width:560px; margin-bottom:24px;
}

/* Location + social row */
.home-meta {
  display:flex; align-items:center; gap:20px; flex-wrap:wrap;
  margin-bottom:28px;
}
.home-loc {
  display:flex; align-items:center; gap:6px;
  font-size:13px; color:var(--tx3);
}
.home-loc i { color:var(--silver); font-size:12px }
.home-icons { display:flex; gap:8px }
.hi {
  width:36px; height:36px; border-radius:8px;
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; color:var(--tx3);
  transition:all var(--t);
}
.hi:hover { border-color:var(--silver); color:var(--silver); transform:translateY(-2px) }

/* Profile photo card */
.home-photo {
  flex-shrink:0;
  position:relative;
}
.home-photo img {
  width:130px; height:130px;
  object-fit:cover; object-position:center top;
  border-radius:14px;
  border:2px solid rgba(200,200,200,.15);
  box-shadow:0 0 28px rgba(200,200,200,.1);
}
.online-badge {
  position:absolute; bottom:-6px; right:-6px;
  background:var(--bg2); border:1.5px solid var(--border);
  border-radius:20px; padding:3px 8px;
  display:flex; align-items:center; gap:5px;
  font-size:10px; font-weight:700; color:var(--tx2);
}
.online-dot { width:6px; height:6px; border-radius:50%; background:#22c55e }

/* CTA buttons */
.home-ctas { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:48px }

/* Contrib grid */
.contrib-section { margin-bottom:0 }
.contrib-label {
  font-size:12px; color:var(--tx3); margin-bottom:10px;
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:6px;
}
/* Scroll wrapper — lets mobile swipe horizontally */
.contrib-scroll {
  width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding-bottom:4px;
}
.contrib-scroll::-webkit-scrollbar { height:3px }
.contrib-scroll::-webkit-scrollbar-track { background:transparent }
.contrib-scroll::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px }

.contrib-grid {
  display:grid;
  grid-template-columns:repeat(52,11px);
  grid-template-rows:repeat(7,11px);
  grid-auto-flow:column;
  gap:3px;
  min-width:max-content;
}
.cg-cell {
  width:11px; height:11px;
  border-radius:2px;
  transition:transform .15s, opacity .15s;
}
.cg-cell:hover { transform:scale(1.5); opacity:.85 }
.cg-0 { background:rgba(255,255,255,.05) }
.cg-1 { background:rgba(200,200,200,.20) }
.cg-2 { background:rgba(200,200,200,.42) }
.cg-3 { background:rgba(200,200,200,.68) }
.cg-4 { background:#c8c8c8 }

.contrib-footer {
  margin-top:8px; font-size:11px; color:var(--tx3);
  min-width:max-content;
}
.contrib-legend { display:flex; align-items:center; gap:4px }
.cl-box { width:10px; height:10px; border-radius:2px; }

/* ═══════════════════════════════════════════
   ABOUT PAGE
═══════════════════════════════════════════ */
.about-grid {
  display:grid; grid-template-columns:1fr 1.3fr;
  gap:64px; align-items:start; margin-bottom:56px;
}
.about-photo-wrap { position:relative; width:300px; height:380px }
.about-photo-bg {
  position:absolute; inset:14px 0 0 14px;
  background:var(--grad); border-radius:20px; opacity:.12;
}
.about-photo-frame {
  position:absolute; inset:0 14px 14px 0;
  background:var(--card); border-radius:20px;
  border:1px solid var(--border); overflow:hidden;
}
.about-photo-frame img { width:100%; height:100%; object-fit:cover; object-position:top }

.about-facts { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:20px }
.fact {
  background:rgba(200,200,200,.04); border:1px solid var(--border);
  border-radius:10px; padding:14px;
  display:flex; align-items:center; gap:10px;
  transition:all var(--t);
}
.fact:hover { border-color:var(--silver); transform:translateY(-2px) }
.fact i { color:var(--silver); font-size:18px; width:20px; flex-shrink:0 }
.fact-n {
  font-family:'Plus Jakarta Sans',sans-serif; font-size:20px; font-weight:800;
  background:var(--grad-tx); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.fact-l { font-size:10px; color:var(--tx3); font-weight:600; text-transform:uppercase; letter-spacing:.8px }

.about-name { font-family:'Plus Jakarta Sans',sans-serif; font-size:26px; font-weight:800; letter-spacing:-.5px; margin-bottom:6px }
.about-role { color:var(--silver); font-size:14px; font-weight:600; letter-spacing:.3px; margin-bottom:14px }
.about-body { font-size:15px; color:var(--tx2); line-height:1.82; margin-bottom:28px }

.skills-head { font-size:10px; font-weight:800; letter-spacing:3px; text-transform:uppercase; color:var(--silver); margin-bottom:16px }
.skills { display:flex; flex-direction:column; gap:14px; margin-bottom:28px }
.sk-meta { display:flex; justify-content:space-between; font-size:13px; font-weight:600; margin-bottom:6px }
.sk-bar { height:5px; background:rgba(255,255,255,.06); border-radius:3px; overflow:hidden }
.sk-fill { height:100%; background:var(--grad); border-radius:3px; width:0; transition:width 1.3s var(--ease) }

.about-ctas { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:40px }

/* Tech stack */
.tech-head { font-size:10px; font-weight:800; letter-spacing:3px; text-transform:uppercase; color:var(--silver); text-align:center; margin-bottom:20px }
.tech-grid {
  display:grid; grid-template-columns:repeat(8,1fr); gap:12px;
  row-gap:12px;
}
.tech-item {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  padding:16px 8px; border-radius:12px;
  background:rgba(200,200,200,.03); border:1px solid var(--border);
  transition:all var(--t);
}
.tech-item:hover { border-color:var(--silver); transform:translateY(-3px); background:rgba(200,200,200,.07) }
.tech-item i { font-size:24px; color:var(--silver) }
.tech-item span { font-size:10px; font-weight:700; color:var(--tx3); text-transform:uppercase; letter-spacing:.5px }

/* Timeline */
.tl-head { font-family:'Plus Jakarta Sans',sans-serif; font-size:22px; font-weight:800; margin-bottom:28px }
.timeline { display:flex; flex-direction:column; gap:0 }
.tl-item {
  display:flex; gap:20px; padding-bottom:24px;
  position:relative;
}
.tl-item::before {
  content:''; position:absolute; left:6px; top:20px; bottom:0;
  width:1px; background:var(--border);
}
.tl-item:last-child::before { display:none }
.tl-dot {
  width:13px; height:13px; border-radius:50%; flex-shrink:0; margin-top:3px;
  background:var(--bg); border:2px solid var(--silver);
  box-shadow:0 0 8px rgba(200,200,200,.3);
}
.tl-body { flex:1 }
.tl-date { font-size:11px; color:var(--silver); font-weight:700; letter-spacing:.5px; margin-bottom:4px }
.tl-title { font-family:'Plus Jakarta Sans',sans-serif; font-size:15px; font-weight:700; margin-bottom:2px }
.tl-sub { font-size:13px; color:var(--tx2); margin-bottom:6px }
.tl-tag {
  display:inline-block; font-size:10px; font-weight:700; letter-spacing:.5px; text-transform:uppercase;
  padding:3px 10px; border-radius:50px;
}
.tl-work { background:rgba(200,200,200,.1); color:var(--silver) }
.tl-edu  { background:rgba(120,120,120,.12); color:#909090 }

/* ═══════════════════════════════════════════
   SERVICE PAGE
═══════════════════════════════════════════ */
.service-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.svc-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px; padding:28px;
  transition:all var(--t); position:relative; overflow:hidden;
}
.svc-card::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--grad);
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease);
}
.svc-card:hover { border-color:rgba(200,200,200,.22); transform:translateY(-5px); box-shadow:0 16px 48px rgba(0,0,0,.6) }
.svc-card:hover::after { transform:scaleX(1) }
.svc-icon {
  width:52px; height:52px; border-radius:12px;
  background:rgba(200,200,200,.08); border:1px solid rgba(200,200,200,.16);
  display:flex; align-items:center; justify-content:center;
  font-size:22px; color:var(--silver); margin-bottom:18px;
  transition:all var(--t);
}
.svc-card:hover .svc-icon { background:rgba(200,200,200,.14) }
.svc-card h3 { font-family:'Plus Jakarta Sans',sans-serif; font-size:17px; font-weight:700; margin-bottom:10px }
.svc-card p  { font-size:13px; color:var(--tx2); line-height:1.72; margin-bottom:16px }
.svc-list li {
  font-size:12px; color:var(--tx2); padding-left:14px;
  position:relative; margin-bottom:5px;
}
.svc-list li::before {
  content:''; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:5px; height:5px; border-radius:50%; background:var(--silver);
}

/* ═══════════════════════════════════════════
   WORKS PAGE
═══════════════════════════════════════════ */
.works-filter {
  display:flex; gap:8px; flex-wrap:wrap; margin-bottom:40px;
}
.wf {
  font-family:'Space Grotesk',sans-serif; font-size:12px; font-weight:700;
  padding:8px 20px; border-radius:50px;
  border:1.5px solid var(--border); color:var(--tx2);
  background:transparent; transition:all var(--t); letter-spacing:.3px;
}
.wf:hover,.wf.active {
  background:var(--grad); border-color:transparent;
  color:#0a0a0a; box-shadow:0 6px 20px rgba(180,180,180,.15);
}
.works-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.wc {
  background:var(--card); border:1px solid var(--border);
  border-radius:18px; overflow:hidden;
  transition:all var(--t); position:relative;
}
.wc.hidden { display:none }
.wc:hover { border-color:rgba(200,200,200,.22); transform:translateY(-5px); box-shadow:0 16px 48px rgba(0,0,0,.7) }
.wc-img { position:relative; height:196px; overflow:hidden }
.wc-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease) }
.wc:hover .wc-img img { transform:scale(1.05) }
.wc-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(4,4,4,.97),rgba(4,4,4,.62));
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:18px; opacity:0; transition:opacity .3s;
}
.wc:hover .wc-overlay { opacity:1 }
.wc-overlay p { font-size:12px; color:rgba(220,220,220,.85); line-height:1.5; margin-bottom:10px }
.wc-links { display:flex; gap:7px }
.wc-lnk {
  width:32px; height:32px; border-radius:50%;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:12px; transition:background var(--t);
}
.wc-lnk:hover { background:var(--silver); border-color:var(--silver); color:#000 }
.wc-body { padding:18px }
.wc-tags { display:flex; gap:5px; flex-wrap:wrap; margin-bottom:8px }
.wtag {
  font-size:9px; font-weight:800; letter-spacing:.5px; text-transform:uppercase;
  padding:3px 9px; border-radius:50px;
  background:rgba(200,200,200,.08); color:var(--silver);
  border:1px solid rgba(200,200,200,.16);
}
.wc-title { font-family:'Plus Jakarta Sans',sans-serif; font-size:15px; font-weight:700; margin-bottom:5px; transition:color var(--t) }
.wc:hover .wc-title { color:var(--silver2) }
.wc-desc { font-size:12px; color:var(--tx2); line-height:1.55 }

/* ═══════════════════════════════════════════
   CONTACT PAGE
═══════════════════════════════════════════ */
.contact-grid {
  display:grid; grid-template-columns:1fr 1.15fr;
  gap:60px; align-items:start;
}
.contact-blurb { font-size:15px; color:var(--tx2); line-height:1.82; margin-bottom:32px }
.contact-info { display:flex; flex-direction:column; gap:18px; margin-bottom:28px }
.ci-row { display:flex; align-items:center; gap:14px }
.ci-icon {
  width:44px; height:44px; border-radius:11px; flex-shrink:0;
  background:rgba(200,200,200,.06); border:1px solid rgba(200,200,200,.14);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; color:var(--silver); transition:all var(--t);
}
.ci-row:hover .ci-icon { background:var(--silver); color:#0a0a0a; transform:scale(1.08) }
.ci-lbl { font-size:10px; font-weight:800; letter-spacing:1.5px; text-transform:uppercase; color:var(--tx3); margin-bottom:2px }
.ci-val { font-size:14px; font-weight:600; color:var(--tx); transition:color var(--t) }
.ci-val:hover { color:var(--silver) }
.contact-socs { display:flex; gap:8px; margin-bottom:32px }
.cs {
  width:40px; height:40px; border-radius:50%;
  border:1px solid var(--border); background:var(--card);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; color:var(--tx2); transition:all var(--t);
}
.cs:hover { border-color:var(--silver); color:var(--silver); background:rgba(200,200,200,.06); transform:translateY(-2px) }

/* Form */
.cf-wrap {
  background:rgba(14,14,14,.94);
  backdrop-filter:blur(20px);
  border:1px solid var(--border);
  border-radius:20px; padding:36px;
}
.cf { display:flex; flex-direction:column; gap:18px }
.fw { position:relative }
.fw input,.fw textarea {
  width:100%;
  background:rgba(255,255,255,.03);
  border:1.5px solid var(--border);
  border-radius:10px; padding:15px;
  font-size:14px; outline:none; resize:none;
  transition:border-color var(--t),box-shadow var(--t);
}
.fw textarea { min-height:100px }
.fw label {
  position:absolute; top:15px; left:15px;
  font-size:13px; font-weight:500; color:var(--tx3);
  pointer-events:none;
  transition:all .24s var(--ease);
  background:transparent; padding:0 4px;
}
.fw input:focus,.fw textarea:focus {
  border-color:var(--silver);
  box-shadow:0 0 0 3px rgba(200,200,200,.07);
}
.fw input:focus ~ label,
.fw input:not(:placeholder-shown) ~ label,
.fw textarea:focus ~ label,
.fw textarea:not(:placeholder-shown) ~ label {
  top:-9px; left:12px; font-size:10px; font-weight:800;
  letter-spacing:1.5px; text-transform:uppercase;
  color:var(--silver); background:var(--bg2);
}
.btn-full { width:100%; justify-content:center }
.btn-spinner {
  display:none; width:16px; height:16px;
  border:2px solid rgba(255,255,255,.3); border-top-color:#fff;
  border-radius:50%; animation:spin .7s linear infinite; position:absolute;
}
@keyframes spin { to{transform:rotate(360deg)} }
.btn-sending .bl,.btn-sending .bi { opacity:0 }
.btn-sending .btn-spinner { display:block }
.form-ok { display:none; text-align:center; padding:40px 20px }
.form-ok.show { display:block; animation:scIn .5s var(--spring) }
@keyframes scIn { from{opacity:0;transform:scale(.85)} to{opacity:1;transform:none} }
.ok-icon {
  width:64px; height:64px; border-radius:50%;
  background:rgba(200,200,200,.08); border:2px solid rgba(200,200,200,.25);
  display:flex; align-items:center; justify-content:center;
  font-size:24px; color:var(--silver); margin:0 auto 16px;
}
.form-ok h4 { font-family:'Plus Jakarta Sans',sans-serif; font-size:20px; font-weight:800; margin-bottom:6px }
.form-ok p  { color:var(--tx2); font-size:14px }

/* ═══════════════════════════════════════════
   BLOG PAGE — Custom article cards
═══════════════════════════════════════════ */
.blog-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px; margin-bottom:56px;
}

/* Article card */
.bp-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:20px; overflow:hidden;
  display:flex; flex-direction:column;
  transition:border-color var(--t), box-shadow var(--t), transform var(--t);
}
.bp-card:hover {
  border-color:rgba(200,200,200,.22);
  box-shadow:0 18px 52px rgba(0,0,0,.55);
  transform:translateY(-5px);
}

/* Cover image / gradient placeholder */
.bp-cover {
  width:100%; height:186px; overflow:hidden; flex-shrink:0;
}
.bp-cover img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease) }
.bp-card:hover .bp-cover img { transform:scale(1.06) }
.bp-cover-grad {
  background:linear-gradient(135deg,#111 0%,#1a1a1a 40%,#0d0d0d 100%);
  position:relative;
}
.bp-cover-grad::after {
  content:'\f08c'; font-family:'Font Awesome 6 Brands';
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:52px; color:rgba(10,102,194,.35);
}

/* Body */
.bp-body {
  padding:22px; flex:1;
  display:flex; flex-direction:column; gap:14px;
}

/* Tags + read time row */
.bp-top {
  display:flex; align-items:center; justify-content:space-between; gap:8px; flex-wrap:wrap;
}
.bp-tags { display:flex; gap:6px; flex-wrap:wrap }
.bp-tag {
  font-size:10px; font-weight:700; letter-spacing:.4px; text-transform:lowercase;
  padding:3px 10px; border-radius:50px;
  background:rgba(200,200,200,.07); color:var(--silver);
  border:1px solid rgba(200,200,200,.13);
}
.bp-rt {
  font-size:11px; color:var(--tx3); display:flex; align-items:center; gap:5px;
  white-space:nowrap; flex-shrink:0;
}
.bp-rt i { font-size:10px; color:var(--silver) }

/* Title */
.bp-title {
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:17px; font-weight:800; line-height:1.35;
  letter-spacing:-.3px; color:var(--tx);
  transition:color var(--t);
}
.bp-card:hover .bp-title { color:var(--silver2) }

/* Excerpt */
.bp-excerpt {
  font-size:13px; color:var(--tx2); line-height:1.75;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical;
  overflow:hidden; flex:1;
}

/* Bottom row: date + CTA */
.bp-bottom {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:14px; border-top:1px solid var(--border);
  flex-wrap:wrap; gap:8px; margin-top:auto;
}
.bp-date { font-size:11px; color:var(--tx3); font-weight:600 }
.bp-cta {
  display:inline-flex; align-items:center; gap:6px;
  font-size:12px; font-weight:700; color:#0a66c2;
  background:rgba(10,102,194,.1); border:1px solid rgba(10,102,194,.25);
  padding:5px 14px; border-radius:50px;
  transition:all var(--t); text-decoration:none;
}
.bp-cta:hover { background:rgba(10,102,194,.22); border-color:rgba(10,102,194,.5); color:#70b5f9 }
.bp-cta i { font-size:13px }

/* Empty state */
.bp-empty {
  grid-column:1/-1;
  display:flex; flex-direction:column; align-items:center;
  gap:16px; padding:64px 24px; text-align:center;
  color:var(--tx3);
}
.bp-empty i { font-size:48px; color:rgba(10,102,194,.4) }
.bp-empty p { font-size:14px; max-width:400px; line-height:1.7 }
.bp-empty code {
  font-family:'JetBrains Mono',monospace; font-size:12px;
  background:rgba(200,200,200,.08); padding:2px 7px; border-radius:4px;
  color:var(--silver);
}

/* LinkedIn CTA banner */
.blog-cta { margin-top:8px; margin-bottom:16px }
.blog-cta-inner {
  background:var(--card); border:1px solid rgba(10,102,194,.22);
  border-radius:16px; padding:24px 28px;
  display:flex; align-items:center; gap:18px; flex-wrap:wrap;
}
.blog-cta-icon { font-size:32px; color:#0a66c2; flex-shrink:0 }
.blog-cta-title { font-family:'Plus Jakarta Sans',sans-serif; font-size:16px; font-weight:800 }
.blog-cta-sub { font-size:13px; color:var(--tx2) }
.blog-cta-inner .btn { margin-left:auto }

/* Footer bar */
.page-footer {
  border-top:1px solid var(--border);
  padding:24px 60px;
  display:flex; align-items:center; justify-content:space-between;
  font-size:12px; color:var(--tx3); position:relative; z-index:1;
}
.top-btn {
  width:36px; height:36px; border-radius:50%;
  border:1px solid var(--border); background:var(--card);
  color:var(--tx2); display:flex; align-items:center; justify-content:center;
  font-size:13px; transition:all var(--t);
}
.top-btn:hover { background:var(--silver); border-color:var(--silver); color:#0a0a0a; transform:translateY(-2px) }

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media(max-width:1100px) {
  .sec { padding:60px 40px }
  .home-sec { padding:50px 40px }
  .tech-grid { grid-template-columns:repeat(4,1fr) }
  .service-grid { grid-template-columns:repeat(2,1fr) }
  .blog-grid { grid-template-columns:repeat(2,1fr) }
  .blog-cta-inner .btn { margin-left:0 }
  .page-footer { padding:20px 40px }
}
@media(max-width:900px) {
  :root { --sb:0px }
  .sidebar { display:none }
  .mob-header,.mob-menu { display:block }
  .mob-header { display:flex }
  .main { margin-left:0; padding-top:var(--mob-h) }
  .sec { padding:50px 24px }
  .home-sec { padding:50px 24px }
  .home-top { flex-direction:column-reverse }
  .home-photo img { width:90px; height:90px }
  .about-grid { grid-template-columns:1fr; gap:40px }
  .about-photo-wrap { width:100%; max-width:280px; margin:0 auto }
  .works-grid { grid-template-columns:repeat(2,1fr) }
  .blog-grid { grid-template-columns:1fr }
  .service-grid { grid-template-columns:1fr }
  .contact-grid { grid-template-columns:1fr; gap:36px }
  /* contrib-grid scrolls natively on mobile */
  .page-footer { padding:18px 24px }
}
@media(max-width:600px) {
  .sec { padding:40px 16px }
  .home-sec { padding:40px 16px }
  .works-grid { grid-template-columns:1fr }
  .tech-grid { grid-template-columns:repeat(4,1fr) }
  .home-ctas { flex-direction:column }
  .home-ctas .btn { width:100%; justify-content:center }
  /* contrib-grid visible on all sizes — scrollable via .contrib-scroll */
  .cf-wrap { padding:24px 16px }
  .page-footer { flex-direction:column; gap:12px; text-align:center }
}
