/* portfolio.css – ZION WU PURE RED v3.1 */
/* FULLSCREEN FIXED | h5 NEVER BLOCKS | LIVE ON CLICK */

* { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:'Poppins',sans-serif; background:#000; color:#ddd; line-height:1.6; overflow-x:hidden; }

hr { border:0; height:1px; background:linear-gradient(to right,transparent,#FF0000,transparent); margin:30px 0; }

/* --- HEADER / HERO SECTION --- */
.header { background:#000; text-align:center; padding:90px 20px 50px; }
.header h1 { font-size:58px; color:#FF0000; text-shadow:0 0 20px #FF0000; letter-spacing:2px; }
.header .prayer { max-width:700px; margin:30px auto; font-size:18px; color:#fff; font-style:italic; line-height:1.8; }
.header video { width:90%; max-width:900px; border:4px solid #FF0000; border-radius:15px; box-shadow:0 0 40px #FF0000; margin-top:20px; }

/* --- NAVBAR / STICKY NAVIGATION --- */
.navbar { background:#FF0000; padding:15px 0; text-align:center; position:sticky; top:0; z-index:1000; box-shadow:0 4px 20px #FF0000; }
.navbar ul { display:flex; justify-content:center; flex-wrap:wrap; gap:15px; list-style:none; }
.navbar a { color:#fff; padding:12px 28px; font-weight:600; border-radius:8px; transition:0.3s; position:relative; }
.navbar a:hover { background:#fff; color:#FF0000; }
.navbar a.live-link { animation:pulse 2s infinite; font-weight:900; }
.navbar a.live-link::after { content:" LIVE"; position:absolute; top:-8px; right:-12px; background:#fff; color:#FF0000; font-size:10px; padding:3px 8px; border-radius:4px; animation:pulse 1.5s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.6} }

/* --- CAROUSEL / TAB SYSTEM --- */
.carousel-buttons { display:flex; justify-content:center; flex-wrap:wrap; gap:12px; padding:20px; background:#111; border-radius:15px; margin:40px auto; max-width:1000px; box-shadow:0 0 20px #FF0000; }
.carousel-btn { background: lightgray; color: black
  ; border:2px solid #FF0000; padding:14px 24px; border-radius:10px; font-weight:700; cursor:pointer; transition:0.3s; min-width:130px; }
.carousel-btn:hover, .carousel-btn.active { background:#FF0000; color:#000; transform:translateY(-3px); box-shadow:0 0 25px #FF0000; }

.carousel-content { max-width:1200px; margin:0 auto 60px; padding:0 20px; }
.carousel-section { display:none; opacity:0; transition:opacity .5s; }
.carousel-section.active { display:block; opacity:1; animation:fade .6s; }
@keyframes fade { from{opacity:0; transform:translateY(20px)} to{opacity:1; transform:none} }

/* --- GENERAL SECTION/LAYOUT --- */
.row { display:flex; flex-wrap:wrap; gap:30px; margin:60px auto; padding:0 20px; max-width:1200px; }
.main { flex:2; background:#111; padding:30px; border-radius:15px; box-shadow:0 0 25px #FF0000; }
.main h2 { color:#FF0000; font-size:32px; margin-bottom:20px; }

/* --- MEDIA GALLERY (Horizontal Scroll) --- */
.media-gallery { display:flex; overflow-x:auto; gap:18px; padding:10px 0 20px; scroll-snap-type:x mandatory; }
.media-gallery::-webkit-scrollbar { height:10px; }
.media-gallery::-webkit-scrollbar-thumb { background:#FF0000; border-radius:10px; }
.media-item-wrapper { flex:0 0 280px; height:220px; position:relative; border-radius:12px; overflow:hidden; box-shadow:0 0 15px #FF0000; cursor:zoom-in; }
.media-gallery video, .media-gallery img { width:100%; height:160px; object-fit:cover; transition:0.4s; }
.media-gallery video:hover, .media-gallery img:hover { transform:scale(1.08); }

/* h5 TITLE — VISIBLE BUT DOES NOT BLOCK CLICKS */
.media-gallery h5 {
  position:absolute; top:8px; left:8px;
  background:rgba(0,0,0,0.8); color:#fff;
  padding:5px 10px; border-radius:6px;
  font-size:13px; z-index:1;
  max-width:85%; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis;
  pointer-events:none !important;   /* THIS FIXES IT */
  user-select:none;
}
.media-description {
  position:absolute; bottom:0; left:0; width:100%;
  padding:8px; background:linear-gradient(transparent,#000);
  color:#ccc; font-size:11px; pointer-events:none;
}

/* --- LIVE STREAM AND CHAT AREA --- */
.main-stream-area { display:flex; flex-wrap:wrap; gap:25px; margin:30px 0; }
.webcam-video-box { flex:3; min-width:300px; position:relative; background:#000; border-radius:15px; overflow:hidden; box-shadow:0 0 30px #FF0000; padding-top:56.25%; }
#live-stream { position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover; border:3px solid #FF0000; cursor:zoom-in; }
.live-badge { position:absolute; top:15px; left:15px; background:#FF0000; color:#fff; padding:8px 16px; border-radius:8px; font-weight:900; box-shadow:0 0 20px #FF0000; animation:pulse 1.5s infinite; pointer-events:none; }

.chat-box { flex:1; min-width:300px; background:#111; border-radius:15px; overflow:hidden; display:flex; flex-direction:column; box-shadow:0 0 25px #FF0000; height:520px; }
.chat-box-header { background:#FF0000; color:#000; padding:15px; text-align:center; font-weight:900; font-size:18px; }
.chat-messages { flex:1; padding:15px; overflow-y:auto; background:#0a0a0a; }
.chat-messages p { margin:10px 0; padding:10px 14px; background:#222; border-radius:12px; font-size:14px; }
#chat-input { padding:15px; background:#222; border:none; color:#fff; resize:none; height:70px; font-size:15px; }
#send-chat { background:#FF0000; color:#000; border:none; padding:14px; font-weight:900; cursor:pointer; }
#send-chat:hover { background:#fff; }
.donate-btn { display:block; background:#FF0000; color:#fff; text-align:center; padding:16px; font-weight:900; text-decoration:none; border-radius:0 0 15px 15px; }
.donate-btn:hover { background:#fff; color:#FF0000; }

/* --- ARCHIVED VIDEO GRID --- */
.video-card-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px; margin-top:40px; }
.video-card { background:#111; border-radius:15px; overflow:hidden; box-shadow:0 0 20px #FF0000; cursor:zoom-in; }
.video-card video { width:100%; height:160px; object-fit:cover; }

/* --- FOOTER --- */
.footer { background:#111; color:#FF0000; text-align:center; padding:40px 20px; border-top:2px solid #FF0000; box-shadow:0 -5px 20px #FF0000; }

/* --- FLOATING LIVE BUTTON --- */
.floating-live { position:fixed; bottom:20px; right:20px; background:#FF0000; color:#fff; padding:16px 24px; border-radius:50px; font-weight:900; box-shadow:0 0 30px #FF0000; z-index:999; text-decoration:none; animation:pulse 2s infinite; }

/* --- FULLSCREEN OVERLAY (FOR ZOOMED MEDIA) --- */
.fullscreen-overlay {
  position:fixed; top:0; left:0; width:100vw; height:100vh;
  background:#000; z-index:9999; display:flex; align-items:center; justify-content:center;
  cursor:zoom-out; opacity:0; pointer-events:none; transition:opacity .3s;
}
.fullscreen-overlay.active { opacity:1; pointer-events:all; }
.fullscreen-overlay video,
.fullscreen-overlay img {
  max-width:95vw; max-height:95vh; object-fit:contain;
  border:6px solid #FF0000; box-shadow:0 0 60px #FF0000; border-radius:12px;
}
.fullscreen-overlay .close-btn {
  position:absolute; top:20px; right:20px; color:#FF0000; font-weight:900;
  font-size:24px; cursor:pointer; background:#fff; padding:10px 18px;
  border-radius:50%; z-index:10; box-shadow:0 0 20px #000;
}

/* --- MOBILE RESPONSIVENESS --- */
@media (max-width:900px) {
  .header h1 { font-size:42px; }
  .main-stream-area { flex-direction:column; }
  .chat-box { height:450px; }
  .carousel-btn { width:48%; }
}