/*
Theme Name: Vista Hub v3.4
Theme URI: https://www.vhoriginal.com
Author: Vivek Hardaha
Author URI: https://www.vhoriginal.com
Description: Vista Hub v3 — Premium dark, game-dashboard style Hindi content theme for vhoriginal.com. Mobile-first, Devanagari-optimized typography, Google Discover ready, AdSense Auto Ads compatible, LiteSpeed friendly.
Version: 3.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vistahub
*/

/* =============================================================
   VISTA HUB v2  —  vhoriginal.com
   Dark | Game-dashboard | Mobile-first | Hindi (Devanagari)
   Animations live in /css/animations.css
   ============================================================= */

/* ---------- Design tokens ---------- */
:root{
  --bg:        #080808;
  --bg-2:      #0d0d0d;
  --card:      #111111;
  --card-2:    #151515;
  --hover:     #1a1a1a;
  --border:    #1d1d1d;
  --border-2:  #262626;

  --text:      #f2f2f2;
  --body:      #d9d9d9;
  --meta:      #9a9a9a;
  --muted:     #6a6a6a;

  --accent:    #e53935;   /* primary red */
  --accent-2:  #ff5a3c;   /* warm red for gradients */
  --blue:      #00d4ff;   /* electric blue */
  --neon:      #00ff88;   /* neon green */
  --wa:        #25d366;   /* whatsapp */

  --radius:    14px;
  --radius-sm: 10px;
  --maxw:      1240px;

  --sans: 'Hind', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --mono: ui-monospace, 'SF Mono', 'Cascadia Code', 'Roboto Mono', Menlo, Consolas, monospace;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
html,body{ width:100%; max-width:100vw; overflow-x:hidden; }

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-size:18px;
  line-height:1.7;
  word-wrap:break-word;
  overflow-wrap:break-word;
  -webkit-font-smoothing:antialiased;
  position:relative;
}

/* Ambient depth — two faint corner glows fixed behind everything */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background:
    radial-gradient(620px circle at 12% -5%, rgba(229,57,53,.10), transparent 60%),
    radial-gradient(560px circle at 100% 100%, rgba(0,150,255,.07), transparent 55%);
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; height:auto; display:block; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }

::selection{ background:var(--accent); color:#fff; }

/* Custom scrollbar (desktop) */
::-webkit-scrollbar{ width:10px; height:10px; }
::-webkit-scrollbar-track{ background:var(--bg); }
::-webkit-scrollbar-thumb{ background:#262626; border-radius:8px; }
::-webkit-scrollbar-thumb:hover{ background:var(--accent); }

/* ---------- Layout wrapper ---------- */
#site-wrapper{ max-width:var(--maxw); margin:0 auto; padding:18px 16px 48px; }
.single-post-wrap{ max-width:760px; margin:0 auto; }

/* =============================================================
   READING PROGRESS
   ============================================================= */
#reading-progress{
  position:fixed; top:0; left:0;
  width:0; height:3px;
  background:linear-gradient(90deg, var(--accent), var(--accent-2));
  box-shadow:0 0 10px rgba(229,57,53,.7);
  z-index:9999;
}

/* =============================================================
   HEADER
   ============================================================= */
#site-header{
  position:sticky; top:0; z-index:1000;
  background:rgba(8,8,8,.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.header-inner{
  height:58px; max-width:var(--maxw); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 16px;
}
.site-logo{ display:flex; align-items:center; gap:8px; color:#fff; }
.logo-arrow{
  width:0; height:0; flex-shrink:0;
  border-top:9px solid transparent;
  border-bottom:9px solid transparent;
  border-left:15px solid var(--accent);
  filter:drop-shadow(0 0 6px rgba(229,57,53,.55));
}
.logo-text{ font-size:22px; font-weight:700; letter-spacing:.2px; line-height:1; }
.logo-sub{
  font-family:var(--mono); font-size:10px; letter-spacing:.5px;
  color:var(--meta); align-self:flex-end; padding-bottom:2px;
}
.header-buttons{ display:flex; align-items:center; gap:6px; }
.search-btn,.menu-toggle{
  width:40px; height:40px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  color:var(--text); font-size:20px;
  transition:background .2s, color .2s;
}
.search-btn svg{ width:21px; height:21px; }
.search-btn:hover,.menu-toggle:hover{ background:var(--hover); color:var(--accent); }

/* =============================================================
   CATEGORY NAV STRIP (horizontal scroll pills)
   ============================================================= */
#category-nav{
  position:sticky; top:58px; z-index:900;
  background:rgba(10,10,10,.92);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.cat-nav-inner{
  max-width:var(--maxw); margin:0 auto;
  display:flex; gap:8px; padding:10px 16px;
  overflow-x:auto; scrollbar-width:none;
}
.cat-nav-inner::-webkit-scrollbar{ display:none; }
.cat-nav-item{
  flex-shrink:0;
  font-family:var(--mono); font-size:12px; font-weight:600; letter-spacing:.5px;
  padding:7px 14px; border-radius:999px;
  background:var(--card); border:1px solid var(--border-2);
  color:var(--body); white-space:nowrap;
  transition:transform .15s, border-color .2s, color .2s, box-shadow .2s;
}
.cat-nav-item:hover{
  transform:translateY(-2px);
  border-color:var(--accent); color:#fff;
  box-shadow:0 4px 16px rgba(229,57,53,.22);
}

/* =============================================================
   SECTION HEADINGS
   ============================================================= */
.section-heading{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  margin:34px 0 16px;
}
.section-heading h1,.section-heading h2{
  position:relative;
  font-size:1.32rem; font-weight:700; color:#fff;
  padding-left:14px; line-height:1.3;
}
.section-heading h1::before,.section-heading h2::before{
  content:""; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:5px; height:1.05em; border-radius:3px;
  background:linear-gradient(180deg, var(--accent), var(--blue));
  box-shadow:0 0 12px rgba(0,212,255,.35);
}
.view-all{
  flex-shrink:0;
  font-family:var(--mono); font-size:12px; font-weight:600; letter-spacing:.4px;
  color:var(--meta); padding:6px 12px; border-radius:999px;
  border:1px solid var(--border-2);
  transition:color .2s, border-color .2s, background .2s;
}
.view-all:hover{ color:#fff; border-color:var(--accent); background:rgba(229,57,53,.08); }

/* =============================================================
   HERO  (full-width latest post, magazine style)
   ============================================================= */
.hero{
  position:relative; display:block;
  border-radius:var(--radius); overflow:hidden;
  margin-top:6px;
  border:1px solid var(--border);
  background:var(--card);
  min-height:230px;
}
.hero-img{
  width:100%; height:100%; min-height:230px; max-height:440px;
  object-fit:cover; display:block;
  transition:transform .6s ease;
}
.hero:hover .hero-img{ transform:scale(1.04); }
.hero-overlay{
  position:absolute; inset:0;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:22px 20px;
  background:linear-gradient(to top, rgba(0,0,0,.92) 8%, rgba(0,0,0,.55) 45%, rgba(0,0,0,0) 80%);
}
.hero-cat{
  align-self:flex-start;
  font-family:var(--mono); font-size:11px; font-weight:700; letter-spacing:.6px;
  text-transform:uppercase;
  padding:5px 11px; border-radius:999px; margin-bottom:10px;
  background:var(--accent); color:#fff;
  box-shadow:0 4px 14px rgba(229,57,53,.4);
}
.hero-title{
  font-size:1.5rem; font-weight:700; color:#fff; line-height:1.35;
  text-shadow:0 2px 12px rgba(0,0,0,.6);
}
.hero-meta{
  margin-top:10px; display:flex; gap:14px; flex-wrap:wrap;
  font-family:var(--mono); font-size:12px; color:#cfcfcf;
}

/* =============================================================
   POST CARDS GRID
   ============================================================= */
.posts-grid{
  display:grid; gap:14px;
  grid-template-columns:repeat(2,1fr);
}
.post-card{
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.post-card:hover{
  transform:translateY(-4px);
  border-color:var(--accent);
  box-shadow:0 12px 30px rgba(0,0,0,.45), 0 0 0 1px rgba(229,57,53,.25);
}
.post-card a{ display:block; color:inherit; }
.post-thumb-wrap{ position:relative; aspect-ratio:16/9; background:var(--bg-2); overflow:hidden; }
.post-thumb{ width:100%; height:100%; object-fit:cover; transition:transform .35s ease; }
.post-card:hover .post-thumb{ transform:scale(1.05); }
.no-thumb{
  width:100%; height:100%; display:flex; align-items:center; justify-content:center;
  font-size:34px; background:linear-gradient(135deg,#141414,#0c0c0c); color:#333;
}
.card-body{ padding:12px 13px 14px; }
.card-title{
  font-size:.96rem; font-weight:600; color:var(--text); line-height:1.45;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical;
  overflow:hidden;
}
.card-date{ font-family:var(--mono); font-size:11px; color:var(--meta); margin-top:8px; }

/* =============================================================
   CATEGORY GRID (5x4 tiles)
   ============================================================= */
.cat-grid{
  display:grid; gap:11px;
  grid-template-columns:repeat(4,1fr);
}
.cat-grid-item{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:7px;
  padding:16px 6px;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius-sm); text-align:center;
  transition:transform .18s ease, border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.cat-grid-item:hover{
  transform:translateY(-3px);
  border-color:var(--accent);
  background:var(--card-2);
  box-shadow:0 8px 22px rgba(0,0,0,.4);
}
.cat-grid-icon{ font-size:26px; line-height:1; transition:transform .25s ease; }
.cat-grid-item:hover .cat-grid-icon{ transform:translateY(-3px) scale(1.12); }
.cat-grid-label{
  font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.4px;
  color:var(--body);
}
.cat-grid-item:hover .cat-grid-label{ color:#fff; }

/* =============================================================
   ARCHIVE / SEARCH HEADER
   ============================================================= */
.archive-head{
  margin:4px 0 22px; padding:22px 20px;
  background:linear-gradient(135deg, var(--card), var(--bg-2));
  border:1px solid var(--border); border-left:4px solid var(--accent);
  border-radius:var(--radius);
}
.archive-head h1{ font-size:1.5rem; color:#fff; font-weight:700; line-height:1.3; }
.archive-head .archive-desc{ color:var(--meta); margin-top:8px; font-size:.95rem; line-height:1.6; }
.archive-head .archive-count{
  font-family:var(--mono); font-size:12px; color:var(--accent); margin-top:10px; display:inline-block;
}

/* =============================================================
   SINGLE POST
   ============================================================= */
.vho-breadcrumb{
  font-family:var(--mono); font-size:12px; color:var(--meta);
  display:flex; align-items:center; flex-wrap:wrap; gap:6px; margin:6px 0 16px;
}
.vho-breadcrumb a{ color:var(--meta); transition:color .2s; }
.vho-breadcrumb a:hover{ color:var(--accent); }
.vho-breadcrumb .sep{ color:var(--muted); }
.vho-breadcrumb .current{ color:var(--body); }

.post-title-main{
  font-size:1.85rem; font-weight:700; color:#fff; line-height:1.32;
  margin-bottom:14px; letter-spacing:.1px;
}
.post-meta-bar{
  display:flex; flex-wrap:wrap; gap:8px 16px; align-items:center;
  padding-bottom:16px; margin-bottom:18px; border-bottom:1px solid var(--border);
}
.meta-item{ font-family:var(--mono); font-size:12.5px; color:var(--meta); display:inline-flex; align-items:center; gap:5px; }
.meta-item a{ color:var(--accent); }
.meta-item a:hover{ text-decoration:underline; }

.post-feature{ margin-bottom:18px; }
.post-feature img{ width:100%; height:auto; border-radius:var(--radius); border:1px solid var(--border); }

/* TOC */
.toc-wrapper{
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); margin-bottom:22px; overflow:hidden;
}
.toc-header{
  display:flex; align-items:center; justify-content:space-between;
  padding:13px 16px; cursor:pointer; user-select:none;
  font-weight:600; color:#fff;
  border-left:3px solid var(--accent);
}
.toc-header:hover{ background:var(--card-2); }
#toc-arrow{ color:var(--accent); font-size:12px; transition:transform .25s ease; }
.toc-content{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.toc-content.show{ max-height:1200px; }
.toc-list{ list-style:none; padding:6px 16px 16px; }
.toc-list li{ padding:5px 0; }
.toc-list li a{ color:var(--body); font-size:.92rem; transition:color .2s; }
.toc-list li a:hover{ color:var(--accent); }
.toc-list li.toc-h3{ padding-left:18px; }
.toc-list li.toc-h3 a{ color:var(--meta); font-size:.88rem; }

/* Post body / Hindi typography */
.post-body-content{
  font-size:19px; line-height:1.85; color:var(--body);
}
.post-body-content p{ margin:0 0 1.15em; }
.post-body-content h2{ font-size:1.4rem; color:#fff; font-weight:700; margin:1.5em 0 .55em; line-height:1.4; }
.post-body-content h3{ font-size:1.18rem; color:#f3f3f3; font-weight:600; margin:1.3em 0 .5em; }
.post-body-content h2,.post-body-content h3{ scroll-margin-top:120px; }
.post-body-content a{ color:var(--accent); text-decoration:underline; text-underline-offset:2px; }
.post-body-content a:hover{ color:var(--accent-2); }
.post-body-content ul,.post-body-content ol{ margin:0 0 1.15em 1.3em; }
.post-body-content li{ margin-bottom:.5em; }
.post-body-content img{ border-radius:var(--radius); margin:1.2em auto; border:1px solid var(--border); }
.post-body-content blockquote{
  margin:1.3em 0; padding:14px 18px;
  border-left:4px solid var(--accent); background:var(--card);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0; color:var(--text);
}
.post-body-content table{ width:100%; border-collapse:collapse; margin:1.3em 0; font-size:.95rem; }
.post-body-content th,.post-body-content td{ border:1px solid var(--border-2); padding:9px 12px; text-align:left; }
.post-body-content th{ background:var(--card); color:#fff; }
.post-body-content code{ background:var(--card); padding:2px 6px; border-radius:6px; font-family:var(--mono); font-size:.88em; color:var(--neon); }
.post-body-content pre{ background:var(--card); border:1px solid var(--border); border-radius:var(--radius-sm); padding:14px; overflow-x:auto; margin:1.3em 0; }
.post-body-content pre code{ background:none; padding:0; color:var(--body); }
.post-body-content iframe{ max-width:100%; border-radius:var(--radius); margin:1.2em 0; }

/* Auto-ad placeholder spacing (Auto Ads injects here naturally) */
.vh-auto-ad{ margin:22px 0; min-height:1px; text-align:center; clear:both; }

/* Share buttons */
.post-share-end{ display:flex; flex-wrap:wrap; gap:9px; margin:26px 0; }
.ps-btn{
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:600; padding:9px 15px; border-radius:999px;
  border:1px solid var(--border-2); background:var(--card); color:var(--body);
  transition:transform .15s, border-color .2s, color .2s, box-shadow .2s;
}
.ps-btn:hover{ transform:translateY(-2px); color:#fff; box-shadow:0 6px 16px rgba(0,0,0,.4); }
.ps-btn.wa:hover{ border-color:var(--wa); box-shadow:0 6px 16px rgba(37,211,102,.25); }
.ps-btn.fb:hover{ border-color:#1877f2; box-shadow:0 6px 16px rgba(24,119,242,.25); }
.ps-btn.tw:hover{ border-color:#fff; }
.ps-btn.cp:hover{ border-color:var(--accent); box-shadow:0 6px 16px rgba(229,57,53,.25); }

/* Tags */
.post-tags{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; margin:22px 0; }
.post-tags > span{ font-family:var(--mono); font-size:12px; color:var(--meta); }
.post-tags a{
  font-size:12.5px; padding:5px 12px; border-radius:999px;
  background:var(--card); border:1px solid var(--border-2); color:var(--body);
  transition:border-color .2s, color .2s;
}
.post-tags a:hover{ border-color:var(--accent); color:#fff; }

/* Author box */
.vho-author-box{
  display:flex; align-items:center; gap:14px; margin:26px 0;
  padding:18px; background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); border-left:4px solid var(--accent);
}
.vho-author-icon{
  width:52px; height:52px; flex-shrink:0; border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-size:24px;
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
}
.vho-author-label{ font-family:var(--mono); font-size:11px; letter-spacing:.5px; color:var(--meta); text-transform:uppercase; }
.vho-author-name a{ font-size:1.02rem; font-weight:600; color:#fff; }
.vho-author-name a:hover{ color:var(--accent); }

/* Bot signals (SEO footer block) */
.bot-signals{
  margin:22px 0; padding:14px 16px; border:1px dashed var(--border-2);
  border-radius:var(--radius-sm); font-family:var(--mono); font-size:11.5px; color:var(--muted);
}
.bot-signals .signal-row{ display:flex; flex-wrap:wrap; gap:6px 14px; margin-bottom:6px; }
.bot-signals .signal-row:last-child{ margin-bottom:0; }
.bot-signals .signal-label{ color:var(--meta); }
.bot-signals a{ color:var(--accent); }

/* Related posts */
.vho-related-section{ margin-top:34px; padding-top:24px; border-top:1px solid var(--border); }
.vho-related-title{
  font-size:1.28rem; font-weight:700; color:#fff; margin-bottom:16px; position:relative; padding-left:14px;
}
.vho-related-title::before{
  content:""; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:5px; height:1em; border-radius:3px;
  background:linear-gradient(180deg,var(--accent),var(--accent-2)); box-shadow:0 0 12px rgba(229,57,53,.5);
}
.vho-related-grid{ display:grid; gap:13px; grid-template-columns:repeat(2,1fr); }
.vho-related-card{
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
  overflow:hidden; transition:transform .2s, border-color .2s, box-shadow .2s;
}
.vho-related-card:hover{ transform:translateY(-4px); border-color:var(--accent); box-shadow:0 12px 28px rgba(0,0,0,.45); }
.vho-related-img{ width:100%; aspect-ratio:16/9; object-fit:cover; }
.vho-related-info{ padding:11px 12px 13px; }
.vho-related-card-title{
  font-size:.92rem; font-weight:600; color:var(--text); line-height:1.45;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}
.vho-related-date{ font-family:var(--mono); font-size:11px; color:var(--meta); margin-top:7px; }

/* =============================================================
   PAGINATION
   ============================================================= */
.pagination{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:34px 0 10px; }
.pagination .page-numbers{
  min-width:40px; height:40px; padding:0 12px; display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:14px; font-weight:600;
  background:var(--card); border:1px solid var(--border-2); border-radius:10px; color:var(--body);
  transition:border-color .2s, color .2s, background .2s;
}
.pagination .page-numbers:hover{ border-color:var(--accent); color:#fff; }
.pagination .page-numbers.current{ background:var(--accent); border-color:var(--accent); color:#fff; box-shadow:0 4px 14px rgba(229,57,53,.3); }
.pagination .dots{ border:none; background:none; }

/* =============================================================
   MOBILE MENU (slides from right) + overlay
   ============================================================= */
#menu-overlay{
  position:fixed; inset:0; z-index:1100;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
  opacity:0; visibility:hidden; transition:opacity .3s ease, visibility .3s;
}
#menu-overlay.active{ opacity:1; visibility:visible; }

#mobile-menu{
  position:fixed; top:0; right:0; z-index:1200;
  width:min(310px,82vw); height:100%;
  background:var(--bg-2); border-left:1px solid var(--border);
  display:flex; flex-direction:column;
  transform:translateX(100%); transition:transform .32s cubic-bezier(.4,0,.2,1);
  box-shadow:-20px 0 40px rgba(0,0,0,.4);
  overflow-y:auto;
}
#mobile-menu.active{ transform:translateX(0); }
.mobile-menu-header{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px; border-bottom:1px solid var(--border);
}
.mobile-menu-close{ width:38px; height:38px; border-radius:10px; font-size:18px; color:var(--text); transition:background .2s,color .2s; }
.mobile-menu-close:hover{ background:var(--hover); color:var(--accent); }
.mobile-menu-links{ display:flex; flex-direction:column; padding:10px 0; }
.mobile-menu-links a{
  display:flex; align-items:center; gap:13px;
  padding:13px 20px; color:var(--body); font-size:.98rem; font-weight:500;
  border-left:3px solid transparent; transition:background .2s, color .2s, border-color .2s;
}
.mobile-menu-links a:hover{ background:var(--card); color:#fff; border-left-color:var(--accent); }
.menu-icon{ font-size:18px; width:22px; text-align:center; }

/* =============================================================
   SEARCH OVERLAY (fade + scale)
   ============================================================= */
#search-overlay{
  position:fixed; inset:0; z-index:1300;
  display:flex; align-items:flex-start; justify-content:center;
  padding:14vh 18px 0;
  background:rgba(8,8,8,.82);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  opacity:0; visibility:hidden; transition:opacity .25s ease, visibility .25s;
}
#search-overlay.active{ opacity:1; visibility:visible; }
.search-box{ width:100%; max-width:620px; transform:scale(.94); transition:transform .25s ease; }
#search-overlay.active .search-box{ transform:scale(1); }
.search-box form{
  display:flex; align-items:center; gap:8px;
  background:var(--card); border:1px solid var(--border-2);
  border-radius:14px; padding:6px 6px 6px 18px;
  box-shadow:0 20px 50px rgba(0,0,0,.5);
}
.search-box input{
  flex:1; background:none; border:none; outline:none;
  color:#fff; font-size:1.05rem; font-family:var(--sans); padding:12px 0;
}
.search-box input::placeholder{ color:var(--muted); }
.search-close{ width:42px; height:42px; border-radius:10px; font-size:18px; color:var(--meta); transition:background .2s,color .2s; }
.search-close:hover{ background:var(--hover); color:var(--accent); }

/* =============================================================
   BACK TO TOP
   ============================================================= */
#back-to-top{
  position:fixed; bottom:22px; right:18px; z-index:800;
  width:46px; height:46px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-size:20px; color:#fff;
  background:var(--accent); box-shadow:0 6px 20px rgba(229,57,53,.45);
  opacity:0; visibility:hidden; transform:translateY(14px);
  transition:opacity .3s, visibility .3s, transform .3s, background .2s;
}
#back-to-top.show{ opacity:1; visibility:visible; transform:translateY(0); }
#back-to-top:hover{ background:#c62828; }

/* =============================================================
   FOOTER
   ============================================================= */
#site-footer{
  border-top:1px solid var(--border); margin-top:30px;
  padding:30px 16px 36px; background:var(--bg-2);
}
.footer-links{
  list-style:none; display:flex; flex-wrap:wrap; gap:8px 22px; justify-content:center;
  max-width:var(--maxw); margin:0 auto 16px;
}
.footer-links a{ color:var(--meta); font-size:.92rem; transition:color .2s; }
.footer-links a:hover{ color:var(--accent); }
.copyright{ text-align:center; font-family:var(--mono); font-size:12px; color:var(--muted); }

/* =============================================================
   404
   ============================================================= */
.error-404{ text-align:center; padding:70px 20px; }
.error-404 .err-emoji{ font-size:78px; margin-bottom:18px; }
.error-404 h1{ color:#fff; font-size:1.9rem; margin-bottom:14px; }
.error-404 p{ color:var(--meta); margin-bottom:24px; }
.btn-home{
  display:inline-block; padding:12px 28px; border-radius:999px; font-weight:600; color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  box-shadow:0 6px 18px rgba(229,57,53,.35); transition:transform .15s;
}
.btn-home:hover{ transform:translateY(-2px); }

.no-results{ color:var(--meta); text-align:center; padding:48px 0; font-size:1.02rem; }

/* Widgets (if sidebar used) */
.widget{ background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:16px; margin-bottom:18px; }
.widget-title{ font-size:1.05rem; color:#fff; margin-bottom:12px; }

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (min-width:600px){
  .posts-grid{ grid-template-columns:repeat(3,1fr); }
  .vho-related-grid{ grid-template-columns:repeat(2,1fr); }
  .cat-grid{ grid-template-columns:repeat(5,1fr); }
  .hero-title{ font-size:1.75rem; }
  .hero-img{ min-height:300px; }
}
@media (min-width:900px){
  #site-wrapper{ padding:24px 20px 56px; }
  .posts-grid{ grid-template-columns:repeat(4,1fr); }
  .vho-related-grid{ grid-template-columns:repeat(4,1fr); }
  .post-title-main{ font-size:2.15rem; }
  .hero{ margin-top:10px; }
  .hero-overlay{ padding:34px 32px; }
  .hero-title{ font-size:2.1rem; max-width:78%; }
  .section-heading h1,.section-heading h2{ font-size:1.5rem; }
}
@media (max-width:380px){
  body{ font-size:17px; }
  .post-body-content{ font-size:18px; }
  .logo-sub{ display:none; }
}

/* =============================================================
   VISTA HUB v3 — NEW FEATURES
   Ticker · Story scroll · NEW badge · Live search · Random posts
   ============================================================= */

/* ---------- Trending Ticker ---------- */
/* ब्लैक और डार्क ग्रीन प्रीमियम टिकर */
.ticker-bar {
  background: linear-gradient(90deg, #050505, #0a1f12); /* ब्लैक से डार्क ग्रीन */
  border-top: 1px solid #14331e;
  border-bottom: 1px solid #14331e;
  overflow: hidden;
  height: 38px;
  display: flex;
  align-items: center;
  margin-bottom: 6px;
}

/* नीयन ग्रीन लेबल (Neon Green) */
.ticker-label {
  background: #00ff88; /* नीयन हरा */
  color: #050505; /* डार्क ब्लैक टेक्स्ट */
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1px;
  padding: 0 16px;
  height: 100%;
  display: flex;
  align-items: center;
  white-space: nowrap;
  flex-shrink: 0;
  text-transform: uppercase;
  box-shadow: 3px 0 12px rgba(0, 255, 136, 0.2); /* हल्का हरा ग्लो */
  z-index: 2;
}

.ticker-wrap {
  overflow: hidden;
  white-space: nowrap;
  width: 100%;
  display: block;
}

.ticker-inner {
  white-space: nowrap;
  /* layout (flex) + scroll animation handled by css/animations.css → seamless vh-ticker */
}

/* लिंक्स का रंग (हल्का हरा) */
.ticker-item {
  color: #a3e6b9; 
  font-size: 14px;
  font-weight: 500;
  padding: 0 28px;
  text-decoration: none;
  transition: opacity 0.2s, color 0.2s;
}

/* लिंक्स के बीच का डॉट (•) */
.ticker-item::after {
  content: '•';
  margin-left: 28px;
  color: #00ff88;
  opacity: 0.5;
}

.ticker-item:hover {
  color: #ffffff; /* छूने पर सफ़ेद हो जाएगा */
  opacity: 1;
}

/* टिकर का engine अब css/animations.css में है (seamless vh-ticker + hover pause) */


/* ---------- Story Horizontal Scroll ---------- */
.story-section{ margin:20px 0; }
.story-scroll{
  display:flex;
  gap:10px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding-bottom:4px;
}
.story-scroll::-webkit-scrollbar{ display:none; }
.story-card{
  flex-shrink:0;
  width:120px;
  border-radius:14px;
  overflow:hidden;
  position:relative;
  text-decoration:none;
  display:block;
  aspect-ratio:9/16;
  background:#111;
  border:2px solid transparent;
  transition:border-color .2s, transform .2s;
}
.story-card:hover{
  border-color:var(--accent);
  transform:scale(1.04);
}
.story-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.story-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,0) 55%);
  display:flex;
  align-items:flex-end;
  padding:8px;
}
.story-title{
  color:#fff;
  font-size:11px;
  font-weight:600;
  line-height:1.3;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.story-cat-badge{
  position:absolute;
  top:8px;
  left:8px;
  background:var(--accent);
  color:#fff;
  font-size:9px;
  font-weight:700;
  padding:2px 6px;
  border-radius:4px;
  text-transform:uppercase;
}

/* ---------- NEW Badge ---------- */
.new-badge{
  display:inline-flex;
  align-items:center;
  background:linear-gradient(135deg,#e53935,#ff6b6b);
  color:#fff;
  font-size:9px;
  font-weight:800;
  letter-spacing:.5px;
  padding:2px 6px;
  border-radius:4px;
  text-transform:uppercase;
  vertical-align:middle;
  margin-left:4px;
  line-height:1.4;
}

/* ---------- Live Search Results ---------- */
.live-search-results{
  position:absolute;
  top:100%;
  left:0;
  right:0;
  background:#1a1a1a;
  border:1px solid var(--border-2);
  border-top:none;
  border-radius:0 0 12px 12px;
  max-height:320px;
  overflow-y:auto;
  z-index:9999;
  display:none;
}
.live-search-results.active{ display:block; }
.live-search-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  text-decoration:none;
  color:var(--text);
  border-bottom:1px solid var(--border);
  transition:background .15s;
  font-size:13px;
}
.live-search-item:last-child{ border-bottom:none; }
.live-search-item:hover{ background:var(--hover); }
.live-search-thumb{
  width:42px;
  height:28px;
  object-fit:cover;
  border-radius:4px;
  flex-shrink:0;
  background:#222;
}
.live-search-title{ flex:1; line-height:1.4; }
.search-loading, .search-no-results{
  padding:14px;
  text-align:center;
  color:var(--meta);
  font-size:13px;
}
#search-overlay .search-box{ position:relative; }

/* ---------- Back to Top v3 ---------- */
#back-to-top{
  position:fixed;
  bottom:24px;
  right:18px;
  width:46px;
  height:46px;
  background:linear-gradient(135deg,#e53935,#b71c1c);
  color:#fff;
  border:none;
  border-radius:50%;
  font-size:20px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transform:translateY(12px) scale(.85);
  transition:opacity .25s, transform .25s;
  z-index:999;
  box-shadow:0 4px 18px rgba(229,57,53,.45);
}
#back-to-top.show{
  opacity:1;
  transform:translateY(0) scale(1);
}
#back-to-top:hover{
  background:linear-gradient(135deg,#ff6b6b,#e53935);
  box-shadow:0 6px 24px rgba(229,57,53,.6);
  transform:translateY(-2px) scale(1.05);
}

/* ============================================================
   PHASE 2  —  Category (1 BIG + 4 small) · Blue accent · Widgets
   Tweak freely: red = var(--accent) · blue = var(--blue) (#00d4ff)
   ============================================================ */

/* secondary blue on "View All" hover */
.view-all:hover{ color:#fff; border-color:var(--blue); background:rgba(0,212,255,.10); }

/* ---------- BIG featured card (first post of a category) ---------- */
.cat-featured{
  display:block; position:relative; text-decoration:none;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden; margin-bottom:14px;
  transition:border-color .2s, transform .2s, box-shadow .25s;
}
.cat-featured:hover{ border-color:var(--blue); box-shadow:0 0 22px rgba(0,212,255,.18); }
.cat-featured-thumb{ width:100%; aspect-ratio:16/9; overflow:hidden; background:#111; }
.cat-featured-img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .45s ease; }
.cat-featured:hover .cat-featured-img{ transform:scale(1.05); }
.cat-featured-body{ padding:14px 16px 18px; }
.cat-featured-badge{
  display:inline-block; font-size:11px; font-weight:800; letter-spacing:.5px; color:#fff;
  background:linear-gradient(90deg, var(--accent), var(--blue));
  padding:4px 13px; border-radius:20px; margin-bottom:10px;
}
.cat-featured-title{ font-size:1.28rem; line-height:1.4; font-weight:700; color:var(--text); }
.cat-featured-meta{ margin-top:8px; font-size:.82rem; color:var(--meta); font-family:var(--mono); }

/* ---------- 4 small cards ---------- */
.cat-small-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-bottom:28px;
}
.cat-small-card{
  display:block; text-decoration:none; background:var(--card);
  border:1px solid var(--border); border-radius:var(--radius-sm); overflow:hidden;
  transition:border-color .2s, transform .2s;
}
.cat-small-card:hover{ border-color:var(--blue); transform:translateY(-3px); }
.cat-small-thumb{ width:100%; aspect-ratio:16/9; overflow:hidden; background:#111; }
.cat-small-img{ width:100%; height:100%; object-fit:cover; display:block; }
.cat-small-title{
  font-size:.9rem; line-height:1.4; font-weight:600; color:var(--text);
  padding:9px 10px 12px;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}

/* desktop: featured goes horizontal, small cards in one row of 4 */
@media (min-width:768px){
  .cat-featured{ display:flex; align-items:stretch; }
  .cat-featured-thumb{ width:46%; aspect-ratio:auto; min-height:240px; }
  .cat-featured-body{ flex:1; display:flex; flex-direction:column; justify-content:center; padding:24px 28px; }
  .cat-featured-title{ font-size:1.7rem; }
  .cat-small-grid{ grid-template-columns:repeat(4,1fr); }
}

/* ---------- Widget (gadget) areas ---------- */
.vh-widget-area{ margin:20px 0; }
.vh-widget-area .widget{
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px; margin-bottom:14px;
}
.vh-widget-area .widget-title{
  font-size:1rem; font-weight:700; color:var(--text); margin:0 0 10px;
  padding-left:10px; border-left:3px solid var(--blue);
}

/* category icon tiles: blue glow on hover (secondary accent) */
.cat-grid-item:hover{ border-color:var(--blue); box-shadow:0 0 16px rgba(0,212,255,.15); }

/* ============================================================
   v3.4 — UNIFIED OVERLAY CARDS  (image + title + desc inside)
   One card everywhere: home grid, category, related, archive, search
   ============================================================ */
.ovl-card{ position:relative; }
.ovl-card > a{
  display:block; position:relative; aspect-ratio:16/9;
  border-radius:16px; overflow:hidden; background:var(--card);
  border:1px solid var(--border);
}
.ovl-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ovl-img.no-thumb{ display:grid; place-items:center; font-size:2.4rem; color:#2a2a2a; background:var(--bg-2); }
.ovl-scrim{
  position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(to top, rgba(0,0,0,.9) 0%, rgba(0,0,0,.46) 42%, rgba(0,0,0,0) 72%);
}
.ovl-in{ position:absolute; left:0; right:0; bottom:0; padding:14px 16px; }
.ovl-cat{
  display:inline-block; background:var(--c,var(--accent)); color:#fff;
  font-weight:700; font-size:.66rem; letter-spacing:.08em; text-transform:uppercase;
  padding:6px 13px; border-radius:999px; margin-bottom:10px; line-height:1;
}
.ovl-title{
  margin:0; color:#fff; font-weight:700; line-height:1.28;
  font-size:clamp(1.02rem,4.6vw,1.34rem);
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.ovl-new{
  display:inline-block; vertical-align:middle; background:var(--accent); color:#fff;
  font-size:.6rem; font-weight:700; letter-spacing:.05em;
  padding:2px 7px; border-radius:5px; margin-left:6px;
}
.ovl-desc{
  margin:7px 0 0; color:#e7e7e7; font-size:clamp(.82rem,3.4vw,.95rem); line-height:1.5;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.ovl-card > a:focus-visible{ outline:2px solid var(--blue); outline-offset:2px; }

/* Big cards — one per row on phones (no small cards) */
.posts-grid{ grid-template-columns:1fr !important; gap:16px; }
@media (min-width:768px){  .posts-grid{ grid-template-columns:repeat(2,1fr) !important; } }
@media (min-width:1100px){ .posts-grid{ grid-template-columns:repeat(3,1fr) !important; } }

/* Hero: colored category pill + description (date/time removed) */
.hero-cat{ background:var(--c,var(--accent)) !important; }
.hero-desc{
  margin:10px 0 0; color:#ececec; line-height:1.5; max-width:92%;
  font-size:clamp(.9rem,3.6vw,1rem);
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
