/* ============================================================
   NJ Tech Repair — Portfolio Viewer
   ============================================================ */

#gallery{background:var(--bg2);}

/* ════ CATEGORY TABS ════ */
.gallery-tabs{
  display:flex;gap:4px;
  background:var(--surf);border:1px solid var(--border);
  border-radius:10px;padding:4px;
  width:fit-content;margin-bottom:24px;
}
.gallery-tab{
  background:none;border:none;cursor:pointer;
  padding:8px 18px;border-radius:7px;
  font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;
  color:var(--muted);letter-spacing:.04em;transition:all .2s;
}
.gallery-tab:hover{color:var(--text);}
.gallery-tab.active{background:var(--accent);color:#06070d;}
.gallery-tab-count{
  display:inline-block;background:rgba(0,0,0,.2);
  font-size:10px;font-weight:700;padding:1px 6px;
  border-radius:99px;margin-left:4px;
}
.gallery-tab.active .gallery-tab-count{background:rgba(0,0,0,.25);color:#06070d;}

/* ════ PORTFOLIO VIEWER LAYOUT ════ */
.portfolio-viewer{
  display:grid;
  grid-template-columns:1fr 260px;
  grid-template-rows:1fr auto;
  gap:10px;
  height:clamp(320px,40vw,540px);
}

/* ── MAIN DISPLAY ── */
.pv-main{
  grid-row:span 2;
  position:relative;
  border-radius:var(--rL);overflow:hidden;
  background:var(--surf);border:1px solid var(--border);
  transition:border-color .3s;
}
.pv-main:hover{border-color:rgba(200,255,0,.18);}
.pv-media{width:100%;height:100%;}
.pv-media img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:brightness(.9);
}
.pv-media video{width:100%;height:100%;object-fit:cover;display:block;}
.pv-placeholder{
  width:100%;height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;background:var(--surf2);
}
.pv-placeholder-icon{font-size:48px;opacity:.3;}
.pv-placeholder-text{font-size:13px;color:var(--dim);}

/* Caption bar */
.pv-caption{
  position:absolute;bottom:0;left:0;right:0;
  padding:20px 22px;
  background:linear-gradient(to top,rgba(6,7,13,.95) 0%,rgba(6,7,13,.4) 60%,transparent 100%);
}
.pv-badge{
  font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  background:rgba(200,255,0,.12);border:1px solid rgba(200,255,0,.25);
  color:var(--accent);padding:2px 8px;border-radius:3px;
  display:inline-block;margin-bottom:6px;
}
.pv-badge.pv-purple{
  background:var(--purple-dim);border-color:var(--purple-bord);color:var(--purple);
}
.pv-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(18px,1.8vw,28px);letter-spacing:2px;color:#fff;margin-bottom:3px;
}
.pv-sub{font-size:clamp(11px,.82vw,13px);color:rgba(255,255,255,.5);}

/* Expand / play button */
.pv-action{
  position:absolute;top:16px;right:16px;
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.08);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;color:#fff;font-size:16px;
}
.pv-action:hover{background:var(--accent);color:#06070d;border-color:var(--accent);}

/* ── THUMBNAILS ── */
.pv-thumbs{
  display:flex;flex-direction:column;gap:6px;
  overflow-y:auto;padding-right:2px;
}
.pv-thumbs::-webkit-scrollbar{width:3px;}
.pv-thumbs::-webkit-scrollbar-thumb{background:rgba(200,255,0,.3);border-radius:99px;}

.pv-thumb{
  flex-shrink:0;height:clamp(70px,7vw,100px);
  border-radius:10px;overflow:hidden;
  border:1px solid var(--border);
  cursor:pointer;position:relative;
  transition:all .2s;
}
.pv-thumb:hover{border-color:var(--bord2);transform:scale(1.02);}
.pv-thumb.active{
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent),0 0 20px rgba(200,255,0,.15);
}
.pv-thumb.active-purple{
  border-color:var(--purple);
  box-shadow:0 0 0 1px var(--purple),0 0 20px var(--purple-glow);
}
.pv-thumb img{width:100%;height:100%;object-fit:cover;filter:brightness(.75);transition:filter .2s;}
.pv-thumb:hover img,.pv-thumb.active img{filter:brightness(.95);}
.pv-thumb-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(6,7,13,.8),transparent 60%);
}
.pv-thumb-label{
  position:absolute;bottom:5px;left:8px;right:8px;
  font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:1.5px;
  color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pv-thumb-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:26px;height:26px;border-radius:50%;
  background:rgba(167,139,250,.25);border:1px solid var(--purple-bord);
  display:flex;align-items:center;justify-content:center;
  color:var(--purple);font-size:10px;
}
.pv-thumb-placeholder{
  width:100%;height:100%;background:var(--surf2);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:3px;
}
.pv-thumb-placeholder-icon{font-size:16px;opacity:.3;}
.pv-thumb-placeholder-name{font-size:8px;color:var(--dim);letter-spacing:.03em;}

/* "View More" button */
.gallery-more-wrap{text-align:center;margin-top:18px;}
.gallery-more-btn{
  background:var(--surf);border:1px solid var(--border2);
  color:var(--muted);padding:9px 26px;border-radius:8px;
  font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;
  cursor:pointer;transition:all .2s;
}
.gallery-more-btn:hover{border-color:var(--purple-bord);color:var(--purple);}
.gallery-more-btn.hidden{display:none;}

/* ════ VIDEO MODAL ════ */
.vmModal{
  display:none;position:fixed;inset:0;z-index:9990;
  background:rgba(0,0,0,.92);backdrop-filter:blur(14px);
  align-items:center;justify-content:center;padding:20px;
}
.vmModal.open{display:flex;}
.vmModal-inner{width:100%;max-width:900px;}
.vmModal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.vmModal-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(15px,1.3vw,20px);letter-spacing:2px;color:#fff;}
.vmModal-close{background:none;border:1px solid var(--bord2);color:var(--muted);padding:5px 12px;border-radius:6px;font-size:16px;cursor:pointer;transition:all .2s;}
.vmModal-close:hover{border-color:var(--accent);color:var(--accent);}
.vmModal-body{border-radius:12px;overflow:hidden;background:#000;aspect-ratio:16/9;}
.vmModal-body video,.vmModal-body iframe{width:100%;height:100%;border:none;display:block;}

/* ════ PLACEHOLDER (missing file) ════ */
.gallery-placeholder{
  width:100%;aspect-ratio:4/3;background:var(--surf2);
  border:1px dashed rgba(200,255,0,.15);border-radius:var(--r);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;
}
.gph-icon{font-size:24px;opacity:.3;}
.gph-name{font-family:'Outfit',monospace;font-size:11px;color:var(--accent);opacity:.6;}
.gph-hint{font-size:10px;color:var(--dim);}

/* ════ RESPONSIVE ════ */
@media(max-width:700px){
  .portfolio-viewer{grid-template-columns:1fr;grid-template-rows:auto auto;height:auto;}
  .pv-main{grid-row:span 1;height:clamp(240px,60vw,360px);}
  .pv-thumbs{flex-direction:row;height:80px;overflow-x:auto;overflow-y:hidden;}
  .pv-thumb{flex-shrink:0;width:120px;height:80px;}
}

/* ════ PREV / NEXT NAVIGATION ════ */
.pv-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 42px; height: 42px; border-radius: 50%;
  background: rgba(20,23,40,.85); backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.1);
  color: #fff; font-size: 18px; font-weight: 300;
  cursor: pointer; z-index: 10;
  display: flex; align-items: center; justify-content: center;
  transition: all .22s; opacity: .7;
}
.pv-nav:hover {
  background: var(--purple); border-color: var(--purple);
  opacity: 1; transform: translateY(-50%) scale(1.1);
}
.pv-prev { left: 12px; }
.pv-next { right: 12px; }

/* ════ SMOOTH FADE TRANSITION ════ */
.pv-media { transition: opacity .25s ease; }
.pv-media.fading { opacity: 0; }

/* ════ SHOWCASE STAT PANELS ════ */
.showcase-stat {
  background: linear-gradient(135deg, var(--surf) 0%, var(--surf2) 100%);
  border-left: 1px solid var(--border) !important;
}
.showcase-stat-inner {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  height: 100%; gap: 6px;
}
.ss-number {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(36px,3.5vw,60px);
  letter-spacing: 2px; color: var(--accent);
  text-shadow: 0 0 40px rgba(200,255,0,.3);
  line-height: 1;
}
.ss-label {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(13px,1.1vw,17px); letter-spacing: 2px;
  color: var(--white);
}
.ss-sub { font-size: clamp(10px,.72vw,12px); color: var(--muted); letter-spacing: .06em; }
