
:root{
  --ink:#0a0a0a;--ink2:#111;--ink3:#181818;--ink4:#1e1e1e;
  --red:#c70039;--red2:#e5003d;
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.11);
  --text:#d8d8d8;--muted:rgba(216,216,216,.45);--white:#f0f0f0;
  --mono:'JetBrains Mono',monospace;--sans:'Syne',sans-serif;--serif:'Fraunces',serif;
  --ease:cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
::-webkit-scrollbar{width:2px}::-webkit-scrollbar-track{background:var(--ink)}::-webkit-scrollbar-thumb{background:var(--red)}
body{font-family:var(--sans);background:var(--ink);color:var(--text);overflow-x:hidden;cursor:none}
body::after{content:'';position:fixed;inset:0;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='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.016;pointer-events:none;z-index:2000}

/* LOADER */
#loader{position:fixed;inset:0;z-index:9000;background:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;transition:opacity .7s ease,visibility .7s ease}
#loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-logo{font-family:var(--serif);font-size:2.8rem;font-weight:900;color:var(--white);letter-spacing:-.03em}
.loader-logo b{color:var(--red)}
.loader-bar-wrap{width:220px;height:1px;background:var(--border2);position:relative;overflow:hidden}
.loader-bar{position:absolute;top:0;left:0;height:100%;width:0;background:var(--red);box-shadow:0 0 12px var(--red)}
.loader-pct{font-family:var(--mono);font-size:.65rem;letter-spacing:.25em;color:var(--muted);text-transform:uppercase}

/* SCROLL PROGRESS */
#scroll-prog{position:fixed;top:0;left:0;height:2px;width:0;background:var(--red);z-index:600;box-shadow:0 0 8px rgba(199,0,57,.6);transition:width .1s linear}

/* CURSOR */
#cur{position:fixed;width:9px;height:9px;background:var(--red);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .2s,height .2s}
#cur-o{position:fixed;width:38px;height:38px;border:1px solid rgba(199,0,57,.4);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .25s,height .25s,border-color .25s}
body.hov #cur{width:5px;height:5px}
body.hov #cur-o{width:52px;height:52px;border-color:rgba(199,0,57,.75)}

/* NAV */
nav{position:fixed;top:0;width:100%;z-index:500;display:flex;align-items:center;justify-content:space-between;padding:1.5rem 4rem;transition:all .4s var(--ease)}
nav.solid{background:rgba(10,10,10,.97);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);padding:1rem 4rem}
.n-logo{font-family:var(--serif);font-size:1.25rem;font-weight:700;color:var(--white);text-decoration:none;letter-spacing:-.02em}
.n-logo b{color:var(--red);font-weight:900}
.n-links{display:flex;gap:2rem}
.n-links a{font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .3s;position:relative}
.n-links a:hover,.n-links a.active{color:var(--white)}
.n-links a.active::after{content:'';position:absolute;bottom:-4px;left:0;width:100%;height:1px;background:var(--red)}
.n-cta{font-family:var(--mono);font-size:.67rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:.55rem 1.3rem;background:transparent;border:1px solid var(--red);color:var(--red);text-decoration:none;border-radius:1px;transition:all .3s}
.n-cta:hover{background:var(--red);color:var(--white)}
.n-burger{display:none;flex-direction:column;gap:5px;cursor:none;padding:.3rem;background:none;border:none}
.n-burger span{display:block;width:22px;height:1.5px;background:var(--white);transition:all .3s}
.mob-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(10,10,10,.98);z-index:450;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem}
.mob-menu.open{display:flex}
.mob-menu a{font-family:var(--serif);font-size:2.2rem;font-weight:700;color:var(--white);text-decoration:none;transition:color .3s}
.mob-menu a:hover{color:var(--red)}
.mob-close{position:absolute;top:1.5rem;right:2rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;color:var(--muted);cursor:none;text-transform:uppercase;border:1px solid var(--border2);padding:.4rem .8rem;border-radius:1px;transition:all .3s;background:none}
.mob-close:hover{color:var(--white);border-color:var(--white)}

/* HERO */
#hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden}
.h-left{padding:9rem 4rem 5rem;display:flex;flex-direction:column;justify-content:space-between;border-right:1px solid var(--border);position:relative;z-index:2}
.h-eyebrow{font-family:var(--mono);font-size:.65rem;letter-spacing:.25em;color:var(--red);text-transform:uppercase;margin-bottom:1.8rem;display:flex;align-items:center;gap:.8rem}
.h-eyebrow::before{content:'';width:28px;height:1px;background:var(--red)}
h1.h-name{font-family:var(--serif);font-size:clamp(3.2rem,5vw,5.5rem);font-weight:900;line-height:.97;color:var(--white);letter-spacing:-.03em;margin-bottom:2rem}
h1.h-name i{color:var(--red);font-style:italic;font-weight:300}
.h-roles{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2.5rem}
.rpill{font-family:var(--mono);font-size:.62rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.32rem .85rem;border:1px solid var(--border2);color:var(--muted);border-radius:2px;transition:all .3s}
.rpill:hover{border-color:var(--red);color:var(--red)}
.h-bio{font-size:.88rem;line-height:1.95;color:var(--muted);max-width:440px;margin-bottom:2.8rem}
.h-bio strong{color:var(--text);font-weight:600}
.h-btns{display:flex;gap:1rem;flex-wrap:wrap}
.btn-fill{font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:.85rem 2rem;background:var(--red);color:var(--white);text-decoration:none;border-radius:1px;border:1px solid var(--red);transition:all .35s;display:inline-block}
.btn-fill:hover{background:transparent;color:var(--red)}
.btn-line{font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:.85rem 2rem;background:transparent;color:var(--text);text-decoration:none;border-radius:1px;border:1px solid var(--border2);transition:all .35s;display:inline-block}
.btn-line:hover{border-color:var(--white);color:var(--white)}
.h-bottom{display:flex;gap:2.5rem;padding-top:2.5rem;border-top:1px solid var(--border);flex-wrap:wrap}
.h-stat-n{font-family:var(--serif);font-size:2.5rem;font-weight:700;color:var(--white);line-height:1}
.h-stat-n span{color:var(--red)}
.h-stat-l{font-family:var(--mono);font-size:.58rem;letter-spacing:.15em;color:var(--muted);margin-top:.3rem;text-transform:uppercase}
.h-right{position:relative;overflow:hidden;background:var(--ink2)}
.h-photo-bg{width:100%;height:100%;background:linear-gradient(160deg,#1c1c1c,#0d0d0d);display:flex;align-items:center;justify-content:center;min-height:100vh;position:relative}
.h-photo{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(15%);transition:filter .5s;position:absolute;inset:0}
.h-right:hover .h-photo{filter:grayscale(0%)}
.h-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(10,10,10,.45) 0%,transparent 40%),linear-gradient(to top,rgba(10,10,10,.65) 0%,transparent 50%)}
.h-status{position:absolute;bottom:2rem;left:-1px;background:rgba(10,10,10,.93);backdrop-filter:blur(16px);border:1px solid var(--border2);border-left:3px solid var(--red);padding:1rem 1.5rem}
.h-status-t{font-family:var(--mono);font-size:.58rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-bottom:.3rem}
.h-status-v{font-family:var(--sans);font-size:.85rem;font-weight:700;color:var(--white);display:flex;align-items:center;gap:.5rem}
.sdot{width:7px;height:7px;background:#22c55e;border-radius:50%;flex-shrink:0;animation:sdot 2s infinite}
@keyframes sdot{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(34,197,94,.4)}50%{opacity:.6;box-shadow:0 0 0 6px rgba(34,197,94,0)}}
.h-cos{position:absolute;bottom:2rem;right:2rem;display:flex;flex-direction:column;gap:.4rem;align-items:flex-end}
.hco{font-family:var(--mono);font-size:.57rem;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;background:rgba(10,10,10,.82);padding:.25rem .6rem;border-radius:1px}

/* TICKER */
.ticker-wrap{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--ink2);padding:.65rem 0}
.ticker{display:flex;width:max-content;animation:tick 38s linear infinite}
.ticker:hover{animation-play-state:paused}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.ti{font-family:var(--mono);font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);padding:0 2rem;white-space:nowrap;display:flex;align-items:center;gap:.8rem}
.ti::after{content:'·';color:var(--red)}

/* SECTION BASE */
section{padding:7rem 4rem;position:relative}
.sec-ey{font-family:var(--mono);font-size:.62rem;letter-spacing:.3em;color:var(--red);text-transform:uppercase;display:flex;align-items:center;gap:.8rem;margin-bottom:.8rem}
.sec-ey::before{content:'';width:24px;height:1px;background:var(--red)}
.sec-h{font-family:var(--serif);font-size:clamp(2rem,3.5vw,3.4rem);font-weight:900;color:var(--white);line-height:1.05;letter-spacing:-.03em;margin-bottom:1rem}
.sec-h i{color:var(--red);font-style:italic;font-weight:300}
.sec-p{font-size:.88rem;color:var(--muted);line-height:1.85;max-width:520px}
.divider{height:1px;background:var(--border);margin:0 4rem}

/* ABOUT */
#about{background:var(--ink2)}
.about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:6rem;margin-top:4.5rem;align-items:start}
.about-text p{font-size:.88rem;line-height:1.95;color:var(--muted);margin-bottom:1.3rem}
.about-text p strong{color:var(--text);font-weight:600}
.info-table{margin-top:2.5rem}
.ir{display:flex;padding:.85rem 0;border-bottom:1px solid var(--border);align-items:flex-start;gap:1rem}
.ir:first-child{border-top:1px solid var(--border)}
.ik{font-family:var(--mono);font-size:.57rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);min-width:85px;padding-top:.05rem;flex-shrink:0}
.iv{font-size:.83rem;font-weight:600;color:var(--text)}
.iv a{color:var(--red);text-decoration:none;transition:opacity .2s}
.iv a:hover{opacity:.75}
.iv.av{color:#22c55e;display:flex;align-items:center;gap:.45rem}
.fl-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:2px;overflow:hidden;margin-bottom:1.5rem}
.fl-stat{background:var(--ink2);padding:1.2rem 1.4rem;transition:background .3s}
.fl-stat:hover{background:var(--ink3)}
.fl-num{font-family:var(--serif);font-size:2rem;font-weight:900;color:var(--white);line-height:1}
.fl-num span{color:var(--red)}
.fl-label{font-family:var(--mono);font-size:.57rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.3rem}
.certs{display:flex;flex-direction:column;gap:.4rem;margin-top:1.5rem}
.cert{display:flex;align-items:center;gap:.9rem;padding:.85rem 1rem;background:var(--ink3);border:1px solid var(--border);border-radius:2px;transition:border-color .3s}
.cert:hover{border-color:rgba(199,0,57,.3)}
.cert-ic{width:30px;height:30px;background:rgba(199,0,57,.1);border-radius:1px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cert-n{font-size:.76rem;font-weight:600;color:var(--text)}
.cert-i{font-family:var(--mono);font-size:.55rem;color:var(--muted);margin-top:.1rem}

/* ═══════════════════════════════════════
   EXPERIENCE — clean layout
═══════════════════════════════════════ */
#experience{background:var(--ink)}
.exp-layout{display:grid;grid-template-columns:220px 1fr;gap:4rem;margin-top:4.5rem;align-items:start}
.exp-nav{position:sticky;top:7rem}
.exp-tab{
  display:flex;flex-direction:column;gap:.22rem;
  padding:.9rem 1rem .9rem 1.2rem;
  border-left:2px solid transparent;
  cursor:none;transition:all .25s;margin-bottom:.25rem;
  background:none;
}
.exp-tab.active{border-left-color:var(--red);background:rgba(199,0,57,.05)}
.exp-tab:hover:not(.active){border-left-color:var(--border2);background:rgba(255,255,255,.02)}
.exp-co{font-size:.78rem;font-weight:700;color:var(--muted);transition:color .25s;line-height:1.3}
.exp-tab.active .exp-co,.exp-tab:hover .exp-co{color:var(--white)}
.exp-per{font-family:var(--mono);font-size:.54rem;color:var(--muted);letter-spacing:.07em;line-height:1.5}
.exp-panel{display:none}
.exp-panel.active{display:block;animation:fadeup .35s ease}
@keyframes fadeup{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* role title + tags */
.exp-role{font-family:var(--serif);font-size:1.45rem;font-weight:700;color:var(--white);line-height:1.2;margin-bottom:.5rem;letter-spacing:-.01em}
.exp-meta{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;margin-bottom:2rem}
.etag{font-family:var(--mono);font-size:.54rem;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .6rem;border:1px solid var(--border2);color:var(--muted);border-radius:1px}
.etag.r{border-color:rgba(199,0,57,.4);color:var(--red)}

/* ── CLEAN BULLETS ──
   Plain sentence text, no bold fragments breaking the line.
   One thin rule between items. Dot sits inline with first line. */
.exp-bullets{list-style:none;margin:0;padding:0}
.exp-bullets li{
  display:flex;
  gap:.75rem;
  padding:.65rem 0;
  border-bottom:1px solid var(--border);
  align-items:baseline;
}
.exp-bullets li:last-child{border-bottom:none}
.eb-dot{
  flex-shrink:0;
  width:5px;height:5px;
  background:var(--red);border-radius:50%;
  margin-top:.55em;   /* aligns dot to cap-height */
}
.eb-text{
  font-size:.84rem;
  line-height:1.8;
  color:var(--muted);
  flex:1;
}

/* ── NEWSPAPER GALLERY ── */
.exp-gallery{margin-top:3rem}

/* masthead */
.np-head{
  border-top:3px solid var(--white);
  border-bottom:1px solid var(--white);
  padding:.4rem 0;
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:2px;
}
.np-name{font-family:var(--serif);font-size:.95rem;font-weight:700;color:var(--white);letter-spacing:-.01em}
.np-date{font-family:var(--mono);font-size:.54rem;letter-spacing:.16em;color:var(--muted);text-transform:uppercase}
.np-rule{height:1px;background:var(--border2);margin-bottom:.9rem}

/* photo grid */
.np-grid{
  display:grid;
  gap:3px;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  background:var(--border);
}
.np-grid.two-col{grid-template-columns:1fr 1fr}
.np-photo{
  position:relative;overflow:hidden;
  background:var(--ink3);cursor:none;
}
/* feature: first photo spans 2 cols */
.np-photo:first-child{grid-column:span 2;aspect-ratio:16/9}
.np-photo:not(:first-child){aspect-ratio:4/3}
.np-grid.two-col .np-photo:first-child{grid-column:span 1;aspect-ratio:4/3}

.np-photo img{
  width:100%;height:100%;
  object-fit:cover;display:block;
  filter:grayscale(22%) contrast(1.06) brightness(.96);
  transition:transform .55s var(--ease),filter .55s ease;
}
.np-photo:hover img{
  transform:scale(1.05);
  filter:grayscale(0%) contrast(1) brightness(1);
}

/* caption bar slides up on hover */
.np-cap{
  position:absolute;bottom:0;left:0;right:0;
  padding:.45rem .65rem;
  background:linear-gradient(to top,rgba(0,0,0,.88) 0%,transparent 100%);
  font-family:var(--mono);font-size:.52rem;letter-spacing:.12em;
  text-transform:uppercase;color:rgba(255,255,255,.75);
  transform:translateY(100%);
  transition:transform .3s ease;
}
.np-photo:hover .np-cap{transform:translateY(0)}

/* placeholder icon when no image */
.np-ph{
  width:100%;height:100%;min-height:160px;
  display:flex;align-items:center;justify-content:center;
  background:var(--ink3);
}
.np-ph svg{width:36px;height:36px;color:rgba(199,0,57,.13)}

/* expand icon overlay */
.np-zoom{
  position:absolute;top:.6rem;right:.6rem;
  width:26px;height:26px;
  background:rgba(10,10,10,.7);border:1px solid var(--border2);
  border-radius:1px;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .25s;
}
.np-photo:hover .np-zoom{opacity:1}

.np-hint{
  font-family:var(--mono);font-size:.53rem;letter-spacing:.09em;
  color:var(--muted);margin-top:.55rem;
  border-top:1px solid var(--border);padding-top:.45rem;
}

/* LIGHTBOX */
#lb{
  position:fixed;inset:0;z-index:9500;
  background:rgba(0,0,0,.96);backdrop-filter:blur(14px);
  display:none;align-items:center;justify-content:center;
  flex-direction:column;gap:.9rem;padding:2rem;
}
#lb.open{display:flex}
#lb-img{max-width:88vw;max-height:78vh;object-fit:contain;border:1px solid var(--border2);display:block}
#lb-cap{font-family:var(--mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);text-align:center}
#lb-counter{font-family:var(--mono);font-size:.56rem;letter-spacing:.15em;color:rgba(255,255,255,.3)}
#lb-close{position:absolute;top:1.5rem;right:1.5rem;width:40px;height:40px;background:rgba(10,10,10,.8);border:1px solid var(--border2);border-radius:1px;display:flex;align-items:center;justify-content:center;cursor:none;color:var(--white);transition:background .25s}
#lb-close:hover{background:var(--red)}
#lb-prev,#lb-next{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background:rgba(10,10,10,.8);border:1px solid var(--border2);border-radius:1px;display:flex;align-items:center;justify-content:center;cursor:none;color:var(--white);transition:all .25s}
#lb-prev{left:1.5rem}#lb-next{right:1.5rem}
#lb-prev:hover,#lb-next:hover{background:var(--red);border-color:var(--red)}

/* SKILLS BENTO */
#skills{background:var(--ink2)}
.bento{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:3px;overflow:hidden;margin-top:4rem}
.bc{background:var(--ink2);padding:1.8rem;transition:background .3s;position:relative;overflow:hidden}
.bc:hover{background:var(--ink3)}
.bc.wide{grid-column:span 2}.bc.tall{grid-row:span 2}
.bc.red{background:var(--red)}.bc.red:hover{background:var(--red2)}
.bc-lbl{font-family:var(--mono);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:1.1rem}
.bc.red .bc-lbl{color:rgba(255,255,255,.6)}
.chips{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.9rem}
.chip{font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;padding:.28rem .7rem;background:var(--ink);border:1px solid var(--border);color:var(--muted);border-radius:2px;transition:all .3s}
.chip:hover{border-color:var(--red);color:var(--red)}
.bars{display:flex;flex-direction:column;gap:1.1rem;margin-top:.5rem}
.bar-n{display:flex;justify-content:space-between;margin-bottom:.4rem}
.bar-name{font-size:.76rem;font-weight:600;color:var(--text)}
.bar-pct{font-family:var(--mono);font-size:.66rem;color:var(--red)}
.bar-tr{height:1.5px;background:rgba(255,255,255,.06)}
.bar-fi{height:100%;background:var(--red);width:0;transition:width 1.6s cubic-bezier(.4,0,.2,1)}
.bignum{font-family:var(--serif);font-size:4.5rem;font-weight:900;color:var(--white);line-height:1}
.bignum span{color:var(--red)}

/* CURRENT PROJECTS */
#now{background:var(--ink);position:relative}
#now::before{content:'';position:absolute;left:4rem;top:0;width:1px;height:100%;background:var(--border)}
.now-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem}
.now-card{background:var(--ink2);border:1px solid var(--border);border-radius:2px;padding:1.8rem;position:relative;overflow:hidden;transition:all .4s}
.now-card:hover{border-color:rgba(199,0,57,.3);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.4)}
.now-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--red);transform:scaleX(0);transition:transform .4s var(--ease);transform-origin:left}
.now-card:hover::before{transform:scaleX(1)}
.now-pulse{display:flex;align-items:center;gap:.5rem;margin-bottom:1.2rem}
.pulse-dot{width:6px;height:6px;background:var(--red);border-radius:50%;animation:sdot 2s infinite}
.pulse-label{font-family:var(--mono);font-size:.57rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red)}
.now-title{font-family:var(--serif);font-size:1.1rem;font-weight:700;color:var(--white);margin-bottom:.6rem;line-height:1.3}
.now-desc{font-size:.8rem;line-height:1.8;color:var(--muted);margin-bottom:1.2rem}
.now-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.now-tag{font-family:var(--mono);font-size:.57rem;letter-spacing:.08em;padding:.22rem .6rem;background:var(--ink3);border:1px solid var(--border);color:var(--muted);border-radius:1px}
.now-pct{position:absolute;bottom:1.5rem;right:1.5rem;font-family:var(--mono);font-size:.65rem;color:var(--muted);letter-spacing:.1em}

/* PROJECTS */
#projects{background:var(--ink2)}
.proj-filter{display:flex;gap:.6rem;flex-wrap:wrap;margin:2.5rem 0 2rem}
.pf-btn{font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;padding:.35rem .9rem;border:1px solid var(--border2);color:var(--muted);background:transparent;border-radius:2px;cursor:none;transition:all .3s}
.pf-btn.active,.pf-btn:hover{background:var(--red);border-color:var(--red);color:var(--white)}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.pc{background:var(--ink);border:1px solid var(--border);border-radius:2px;overflow:hidden;display:flex;flex-direction:column;transition:all .4s;position:relative;cursor:none}
.pc:hover{border-color:rgba(199,0,57,.3);transform:translateY(-5px);box-shadow:0 30px 80px rgba(0,0,0,.5)}
.pc.feat{grid-column:span 2}
.pi{width:100%;overflow:hidden;position:relative;aspect-ratio:16/9;background:var(--ink3);display:flex;align-items:center;justify-content:center}
.pc.feat .pi{aspect-ratio:21/9}
.pi img{width:100%;height:100%;object-fit:cover;transition:transform .5s;display:block}
.pc:hover .pi img{transform:scale(1.05)}
.pi-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.pi-ph svg{width:48px;height:48px;color:rgba(199,0,57,.15)}
.pi-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.85) 0%,transparent 60%)}
.pcat{position:absolute;top:1rem;left:1rem;background:var(--red);color:var(--white);font-family:var(--mono);font-size:.57rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;padding:.28rem .7rem;border-radius:1px}
.pstack{position:absolute;bottom:1rem;right:1rem;display:flex;gap:.35rem;flex-wrap:wrap;justify-content:flex-end}
.stag{font-family:var(--mono);font-size:.53rem;letter-spacing:.1em;text-transform:uppercase;padding:.18rem .5rem;background:rgba(10,10,10,.88);border:1px solid var(--border2);color:var(--muted);border-radius:1px}
.pb{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.pt{font-family:var(--serif);font-size:1.05rem;font-weight:700;color:var(--white);margin-bottom:.5rem;line-height:1.3}
.pd{font-size:.78rem;line-height:1.8;color:var(--muted);flex:1;margin-bottom:1.2rem}
.p-actions{display:flex;gap:.8rem;align-items:center;flex-wrap:wrap}
.pl{font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--red);text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;transition:gap .3s;background:none;border:none;cursor:none;padding:0}
.pl:hover{gap:.7rem}
.pl::after{content:'→'}
.pl-detail{font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:none;border:1px solid var(--border);padding:.35rem .9rem;border-radius:1px;cursor:none;transition:all .3s}
.pl-detail:hover{border-color:var(--border2);color:var(--white)}

/* MODAL */
.modal-bg{position:fixed;inset:0;z-index:800;background:rgba(5,5,5,.93);backdrop-filter:blur(20px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .4s,visibility .4s;overflow-y:auto;display:flex;align-items:flex-start;justify-content:center;padding:3rem 1.5rem}
.modal-bg.open{opacity:1;visibility:visible;pointer-events:all}
.modal{background:var(--ink2);border:1px solid var(--border2);border-radius:3px;max-width:820px;width:100%;transform:translateY(30px);transition:transform .4s;overflow:hidden;position:relative;margin:auto}
.modal-bg.open .modal{transform:translateY(0)}
.modal-img{width:100%;aspect-ratio:16/7;background:var(--ink3);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.modal-close{position:absolute;top:1rem;right:1rem;z-index:10;width:36px;height:36px;background:rgba(10,10,10,.85);border:1px solid var(--border2);border-radius:1px;display:flex;align-items:center;justify-content:center;cursor:none;color:var(--white);transition:background .3s}
.modal-close:hover{background:var(--red)}
.modal-body{padding:2.5rem}
.modal-cat{font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:.6rem}
.modal-title{font-family:var(--serif);font-size:2rem;font-weight:900;color:var(--white);line-height:1.1;margin-bottom:1.5rem;letter-spacing:-.02em}
.modal-sh{font-family:var(--mono);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:.8rem;margin-top:1.8rem;display:flex;align-items:center;gap:.6rem}
.modal-sh::before{content:'';width:16px;height:1px;background:var(--red)}
.modal-desc{font-size:.86rem;line-height:1.9;color:var(--muted)}
.modal-bullets{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin-top:.8rem}
.modal-bullets li{font-size:.84rem;line-height:1.8;color:var(--muted);display:flex;gap:.8rem;align-items:flex-start}
.modal-bullets li::before{content:'';flex-shrink:0;width:5px;height:5px;background:var(--red);border-radius:50%;margin-top:.58rem}
.modal-stack{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.8rem}
.modal-tag{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .8rem;background:var(--ink);border:1px solid var(--border2);color:var(--muted);border-radius:2px}
.modal-links{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:2rem}
.modal-link-btn{font-family:var(--mono);font-size:.67rem;letter-spacing:.12em;text-transform:uppercase;padding:.8rem 1.6rem;background:var(--red);color:var(--white);text-decoration:none;border-radius:1px;border:1px solid var(--red);transition:all .3s}
.modal-link-btn:hover{background:transparent;color:var(--red)}
.modal-link-btn.ghost{background:transparent;color:var(--text);border-color:var(--border2)}
.modal-link-btn.ghost:hover{border-color:var(--white);color:var(--white)}

/* GITHUB */
#github{background:var(--ink2)}
.gh-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;margin-top:4rem;align-items:start}
.gh-info-p{font-size:.87rem;line-height:1.9;color:var(--muted);margin-bottom:1.5rem}
.gh-info-p strong{color:var(--text)}
.gh-star-btn{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--mono);font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:.9rem 1.8rem;background:var(--ink3);color:var(--white);text-decoration:none;border:1px solid var(--border2);border-radius:1px;transition:all .4s;position:relative;overflow:hidden}
.gh-star-btn::before{content:'';position:absolute;inset:0;background:var(--red);transform:scaleX(0);transition:transform .4s var(--ease);transform-origin:left;z-index:0}
.gh-star-btn:hover::before{transform:scaleX(1)}
.gh-star-btn:hover{border-color:var(--red)}
.gh-star-btn span,.gh-star-btn svg{position:relative;z-index:1}
.gh-repos{display:flex;flex-direction:column;gap:.8rem}
.gh-repo{background:var(--ink);border:1px solid var(--border);border-radius:2px;padding:1.3rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;text-decoration:none;transition:all .3s}
.gh-repo:hover{border-color:rgba(199,0,57,.3);transform:translateX(4px)}
.gh-repo-name{font-size:.83rem;font-weight:700;color:var(--white);margin-bottom:.25rem}
.gh-repo-desc{font-size:.74rem;color:var(--muted);line-height:1.6}
.gh-repo-right{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem;flex-shrink:0}
.gh-lang{font-family:var(--mono);font-size:.57rem;letter-spacing:.1em;color:var(--muted);text-transform:uppercase}
.gh-star-count{display:flex;align-items:center;gap:.3rem;font-family:var(--mono);font-size:.6rem;color:var(--muted)}
.gh-stats-row{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.gh-stat-n{font-family:var(--serif);font-size:1.8rem;font-weight:900;color:var(--white);line-height:1}
.gh-stat-n span{color:var(--red)}
.gh-stat-l{font-family:var(--mono);font-size:.57rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.25rem}
.gh-visit-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.5rem;font-family:var(--mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--red);text-decoration:none;transition:gap .3s}
.gh-visit-link:hover{gap:.85rem}
.gh-visit-link::after{content:'→'}

/* BLOG */
#blog{background:var(--ink)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem}
.blog-card{background:var(--ink2);border:1px solid var(--border);border-radius:2px;overflow:hidden;display:flex;flex-direction:column;transition:all .4s;text-decoration:none;cursor:none}
.blog-card:hover{border-color:rgba(199,0,57,.3);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.4)}
.blog-img{width:100%;aspect-ratio:16/8;background:var(--ink3);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.blog-img svg{width:40px;height:40px;color:rgba(199,0,57,.12)}
.blog-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.6) 0%,transparent 60%)}
.blog-tag{position:absolute;bottom:.8rem;left:.8rem;z-index:2;font-family:var(--mono);font-size:.55rem;letter-spacing:.15em;text-transform:uppercase;padding:.2rem .6rem;background:rgba(199,0,57,.9);color:var(--white);border-radius:1px}
.blog-body{padding:1.4rem;flex:1;display:flex;flex-direction:column}
.blog-date{font-family:var(--mono);font-size:.57rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.blog-title{font-family:var(--serif);font-size:1rem;font-weight:700;color:var(--white);line-height:1.4;margin-bottom:.6rem;flex:1}
.blog-excerpt{font-size:.76rem;line-height:1.75;color:var(--muted);margin-bottom:1.1rem}
.blog-read{font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--red);display:inline-flex;align-items:center;gap:.35rem;transition:gap .3s}
.blog-read::after{content:'→'}
.blog-card:hover .blog-read{gap:.65rem}
.blog-cta{display:flex;align-items:center;justify-content:space-between;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border);flex-wrap:wrap;gap:1rem}
.blog-cta-text{font-size:.88rem;color:var(--muted)}
.blog-cta-text strong{color:var(--text)}
.medium-btn{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:.85rem 1.8rem;background:var(--white);color:var(--ink);text-decoration:none;border-radius:1px;transition:all .3s}
.medium-btn:hover{background:var(--red);color:var(--white)}

/* REVIEWS */
#freelance{background:var(--ink2)}
.fl-top-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:2px;overflow:hidden;margin-top:3rem}
.fl-top-cell{background:var(--ink2);padding:1.5rem;text-align:center;transition:background .3s}
.fl-top-cell:hover{background:var(--ink3)}
.fl-top-num{font-family:var(--serif);font-size:2.5rem;font-weight:900;color:var(--white);line-height:1}
.fl-top-num span{color:var(--red)}
.fl-top-lbl{font-family:var(--mono);font-size:.57rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:.35rem}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.rev-card{background:var(--ink);border:1px solid var(--border);padding:1.6rem;border-radius:2px;position:relative;transition:all .35s;display:flex;flex-direction:column}
.rev-card:hover{border-color:rgba(199,0,57,.25);transform:translateY(-3px)}
.rev-stars{color:var(--red);font-size:.8rem;letter-spacing:.05em;margin-bottom:.9rem}
.rev-text{font-size:.8rem;line-height:1.8;color:var(--muted);flex:1;margin-bottom:1rem;font-style:italic}
.rev-text::before{content:'\201C'}
.rev-text::after{content:'\201D'}
.rev-project{font-family:var(--mono);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:.3rem}
.rev-name{font-size:.78rem;font-weight:700;color:var(--text)}
.rev-loc{font-family:var(--mono);font-size:.56rem;color:var(--muted);margin-top:.15rem}
.rev-amount{position:absolute;top:1.2rem;right:1.2rem;font-family:var(--mono);font-size:.6rem;color:var(--muted);letter-spacing:.08em}

/* EDUCATION */
#education{background:var(--ink)}
.edu-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:4rem}
.edu-card{background:var(--ink2);border:1px solid var(--border);padding:2.2rem;border-radius:2px;position:relative;overflow:hidden;transition:border-color .3s}
.edu-card:hover{border-color:rgba(199,0,57,.25)}
.edu-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--red);transition:height .4s ease}
.edu-card:hover::before{height:100%}
.edu-yr{font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;color:var(--red);margin-bottom:.8rem;text-transform:uppercase}
.edu-deg{font-family:var(--serif);font-size:1.15rem;font-weight:700;color:var(--white);margin-bottom:.3rem;line-height:1.3}
.edu-sch{font-size:.8rem;color:var(--muted);margin-bottom:1rem}
.edu-gpa{display:inline-block;font-family:var(--mono);font-size:.63rem;letter-spacing:.1em;padding:.3rem .8rem;background:rgba(199,0,57,.08);border:1px solid rgba(199,0,57,.2);color:var(--red);border-radius:2px}

/* CONTACT */
#contact{background:var(--ink2)}
.ct-layout{display:grid;grid-template-columns:1fr 1.3fr;gap:5rem;margin-top:4.5rem;align-items:start}
.c-list{display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:2px;overflow:hidden}
.c-item{background:var(--ink2);padding:1.2rem 1.5rem;display:flex;align-items:center;gap:1.1rem;transition:background .3s;text-decoration:none}
.c-item:hover{background:var(--ink3)}
.c-ico{width:38px;height:38px;background:rgba(199,0,57,.08);border:1px solid rgba(199,0,57,.18);border-radius:2px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.c-lbl{font-family:var(--mono);font-size:.57rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:.2rem}
.c-val{font-size:.83rem;font-weight:600;color:var(--text)}
.c-soc{display:flex;gap:.6rem;margin-top:1.5rem}
.csb{width:40px;height:40px;background:var(--ink2);border:1px solid var(--border);border-radius:2px;display:flex;align-items:center;justify-content:center;color:var(--muted);text-decoration:none;transition:all .3s}
.csb:hover{background:var(--red);color:var(--white);border-color:var(--red)}
.c-note{margin-top:1.8rem;padding:1.2rem 1.5rem;background:rgba(34,197,94,.05);border:1px solid rgba(34,197,94,.15);border-radius:2px}
.c-note p{font-size:.8rem;color:var(--muted);line-height:1.8}
.c-note strong{color:#22c55e}
.fg{margin-bottom:1.1rem}
.fg label{display:block;font-family:var(--mono);font-size:.57rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.45rem}
.fg input,.fg textarea,.fg select{width:100%;background:var(--ink);border:1px solid var(--border);border-radius:2px;padding:.82rem 1.1rem;color:var(--text);font-family:var(--sans);font-size:.83rem;outline:none;transition:border-color .3s;appearance:none}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:rgba(199,0,57,.5)}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(216,216,216,.18)}
.fg select option{background:var(--ink2)}
.fg textarea{height:110px;resize:none}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.sbtn{width:100%;padding:1rem;background:var(--red);color:var(--white);border:1px solid var(--red);border-radius:2px;cursor:none;font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;transition:all .35s}
.sbtn:hover{background:transparent;color:var(--red)}
.form-success{display:none;margin-top:1rem;padding:1rem;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.2);border-radius:2px;font-family:var(--mono);font-size:.68rem;color:#22c55e;text-align:center;letter-spacing:.1em}

/* FOOTER */
footer{background:var(--ink);border-top:1px solid var(--border);padding:2rem 4rem;display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;color:var(--muted)}
.f-logo{font-family:var(--serif);font-size:1.1rem;font-weight:700;color:var(--white)}
.f-logo b{color:var(--red)}
.f-links{display:flex;gap:1.5rem}
.f-links a{color:var(--muted);text-decoration:none;transition:color .3s}
.f-links a:hover{color:var(--white)}

/* BACK TO TOP */
#btt{position:fixed;bottom:2rem;right:2rem;z-index:400;width:42px;height:42px;background:var(--ink2);border:1px solid var(--border2);border-radius:2px;display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:none;transition:all .3s;opacity:0;visibility:hidden}
#btt.show{opacity:1;visibility:visible}
#btt:hover{background:var(--red);color:var(--white);border-color:var(--red)}

/* REVEAL ANIMATIONS */
.rv{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s ease}
.rvl{opacity:0;transform:translateX(-28px);transition:opacity .75s ease,transform .75s ease}
.rvr{opacity:0;transform:translateX(28px);transition:opacity .75s ease,transform .75s ease}
.rv.on,.rvl.on,.rvr.on{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:1100px){
  #hero{grid-template-columns:1fr}.h-right{display:none}
  nav,nav.solid{padding:1rem 2rem}
  section{padding:5rem 2rem}.divider{margin:0 2rem}
  .about-grid,.gh-layout,.ct-layout{grid-template-columns:1fr;gap:3rem}
  .exp-layout{grid-template-columns:1fr}
  .exp-nav{position:static;display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:2rem}
  .exp-tab{padding:.55rem 1rem;border-left:none;border-bottom:2px solid transparent}
  .exp-tab.active{border-bottom-color:var(--red);border-left:none}
  .bento{grid-template-columns:1fr 1fr}
  .bc.wide{grid-column:span 2}.bc.tall{grid-row:span 1}
  .now-grid,.proj-grid,.blog-grid{grid-template-columns:1fr 1fr}
  .pc.feat{grid-column:span 2}
  .rev-grid,.edu-grid{grid-template-columns:1fr 1fr}
  .fl-top-grid{grid-template-columns:1fr 1fr}
  footer{padding:1.5rem 2rem;flex-direction:column;gap:.8rem;text-align:center}
  .n-links{display:none}
  .n-burger{display:flex}
  .np-grid{grid-template-columns:1fr 1fr}
  .np-photo:first-child{grid-column:span 2;aspect-ratio:16/9}
  .np-grid.two-col .np-photo:first-child{grid-column:span 1}
}
@media(max-width:640px){
  section{padding:4rem 1.5rem}.h-left{padding:7rem 1.5rem 3rem}
  .bento{grid-template-columns:1fr}.bc.wide{grid-column:span 1}
  .now-grid,.proj-grid,.blog-grid,.rev-grid,.edu-grid{grid-template-columns:1fr}
  .pc.feat{grid-column:span 1}
  .frow{grid-template-columns:1fr}
  .np-grid,.np-grid.two-col{grid-template-columns:1fr 1fr}
  .np-photo:first-child{grid-column:span 2}
  .modal-body{padding:1.5rem}
  .modal-title{font-size:1.5rem}
}
