/*
Theme Name: NewsNowIndia24
Theme URI: https://newsnowindia24.example.com
Author: NewsNowIndia24 Team
Author URI: https://newsnowindia24.example.com
Description: A fast, clean, SEO-optimized Hindi News & Magazine WordPress theme built for premium technology & news portals. 100% Gutenberg compatible, PostX ready, Rank Math ready, LiteSpeed Cache ready. Features dark/light mode, mega menu, AJAX search, breaking news ticker, schema.org NewsArticle markup, and more.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: newsnowindia24
Tags: news, magazine, blog, two-columns, right-sidebar, custom-menu, featured-images, full-width-template, translation-ready, block-styles, wide-blocks, dark-mode
*/

/* =====================================================
   0. DESIGN TOKENS
===================================================== */
:root{
  --nni-primary:#d60000;
  --nni-primary-dark:#a50000;
  --nni-secondary:#111111;
  --nni-accent:#FFD400;
  --nni-bg:#FFFFFF;
  --nni-surface:#f7f7f8;
  --nni-border:#e7e7ea;
  --nni-text:#1a1a1a;
  --nni-text-muted:#5c5c66;
  --nni-radius:10px;
  --nni-shadow:0 2px 10px rgba(17,17,17,.06);
  --nni-shadow-hover:0 10px 24px rgba(17,17,17,.12);
  --nni-font-heading:'Poppins',sans-serif;
  --nni-font-body:'Roboto',sans-serif;
  --nni-header-h:64px;
  --nni-ticker-h:40px;
  --nni-transition:.25s ease;
}

[data-theme="dark"]{
  --nni-bg:#0f1012;
  --nni-surface:#1a1b1e;
  --nni-border:#2a2b2f;
  --nni-text:#f2f2f2;
  --nni-text-muted:#a8a8b3;
  --nni-secondary:#f2f2f2;
  --nni-shadow:0 2px 10px rgba(0,0,0,.4);
  --nni-shadow-hover:0 10px 24px rgba(0,0,0,.55);
}

/* =====================================================
   1. RESET & BASE
===================================================== */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--nni-font-body);
  background:var(--nni-bg);
  color:var(--nni-text);
  font-size:16px;
  line-height:1.65;
  transition:background var(--nni-transition),color var(--nni-transition);
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;margin:0;padding:0;}
h1,h2,h3,h4,h5,h6{font-family:var(--nni-font-heading);color:var(--nni-secondary);line-height:1.25;margin:0 0 .5em;font-weight:600;}
p{margin:0 0 1em;}
button{font-family:inherit;cursor:pointer;}
.screen-reader-text{position:absolute;left:-9999px;}
.skip-link{position:absolute;top:-100px;left:0;background:var(--nni-primary);color:#fff;padding:10px 16px;z-index:9999;transition:top .2s;}
.skip-link:focus{top:0;}

.container{max-width:1240px;margin:0 auto;padding:0 20px;}
.nni-visually-hidden{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--nni-primary);color:#fff;
  padding:10px 18px;border:none;border-radius:var(--nni-radius);
  font-weight:600;font-size:.9rem;transition:transform var(--nni-transition),background var(--nni-transition),box-shadow var(--nni-transition);
}
.btn:hover{background:var(--nni-primary-dark);transform:translateY(-2px);box-shadow:var(--nni-shadow-hover);}
.btn-outline{background:transparent;border:2px solid var(--nni-primary);color:var(--nni-primary);}
.btn-outline:hover{background:var(--nni-primary);color:#fff;}

/* Badge */
.nni-badge{
  display:inline-block;background:var(--nni-primary);color:#fff;
  font-size:.68rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;
  padding:4px 10px;border-radius:6px;
}
.nni-badge.nni-badge-accent{background:var(--nni-accent);color:#111;}

/* Card */
.nni-card{
  background:var(--nni-bg);border:1px solid var(--nni-border);
  border-radius:var(--nni-radius);overflow:hidden;box-shadow:var(--nni-shadow);
  transition:transform var(--nni-transition),box-shadow var(--nni-transition);
  display:flex;flex-direction:column;height:100%;
}
.nni-card:hover{transform:translateY(-4px);box-shadow:var(--nni-shadow-hover);}
.nni-card__thumb{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--nni-surface);}
.nni-card__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.nni-card:hover .nni-card__thumb img{transform:scale(1.06);}
.nni-card__badge{position:absolute;top:10px;left:10px;}
.nni-card__body{padding:16px;display:flex;flex-direction:column;gap:8px;flex:1;}
.nni-card__title{font-size:1.05rem;margin:0;}
.nni-card__title a:hover{color:var(--nni-primary);}
.nni-card__meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.78rem;color:var(--nni-text-muted);margin-top:auto;}
.nni-card__meta span{display:inline-flex;align-items:center;gap:4px;}

/* =====================================================
   2. TOP BAR / HEADER
===================================================== */
.nni-topbar{background:var(--nni-secondary);color:#fff;font-size:.8rem;}
.nni-topbar .container{display:flex;align-items:center;justify-content:space-between;padding-top:6px;padding-bottom:6px;}
.nni-topbar__date{opacity:.85;}
.nni-topbar__social a{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.08);margin-left:6px;transition:background var(--nni-transition);}
.nni-topbar__social a:hover{background:var(--nni-primary);}

.nni-header{
  position:sticky;top:0;z-index:999;background:var(--nni-bg);
  border-bottom:1px solid var(--nni-border);
  transition:box-shadow var(--nni-transition),background var(--nni-transition);
}
.nni-header.is-stuck{box-shadow:0 4px 16px rgba(0,0,0,.08);}
.nni-header__inner{display:flex;align-items:center;gap:24px;height:var(--nni-header-h);}
.nni-logo{font-family:var(--nni-font-heading);font-weight:800;font-size:1.5rem;color:var(--nni-secondary);white-space:nowrap;}
.nni-logo span{color:var(--nni-primary);}
.nni-logo img{max-height:44px;}

.nni-main-nav{flex:1;display:flex;}
.nni-main-nav>ul{display:flex;gap:4px;align-items:center;flex-wrap:wrap;}
.nni-main-nav>ul>li{position:relative;}
.nni-main-nav>ul>li>a{display:block;padding:10px 12px;font-weight:600;font-size:.92rem;border-radius:6px;transition:color var(--nni-transition),background var(--nni-transition);}
.nni-main-nav>ul>li>a:hover,.nni-main-nav>ul>li.current-menu-item>a{color:var(--nni-primary);background:var(--nni-surface);}

/* Mega menu */
.nni-main-nav li.menu-item-has-children>a::after{content:'▾';font-size:.6rem;margin-left:4px;}
.nni-mega{
  position:absolute;top:100%;left:0;background:var(--nni-bg);border:1px solid var(--nni-border);
  box-shadow:var(--nni-shadow-hover);border-radius:var(--nni-radius);
  min-width:220px;padding:12px;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity var(--nni-transition),transform var(--nni-transition),visibility var(--nni-transition);
  z-index:50;
}
.nni-main-nav li.menu-item-has-children.mega-menu .nni-mega{display:grid;grid-template-columns:repeat(3,1fr);min-width:560px;gap:6px;}
.nni-main-nav li.menu-item-has-children:hover>.nni-mega,
.nni-main-nav li.menu-item-has-children:focus-within>.nni-mega{opacity:1;visibility:visible;transform:translateY(0);}
.nni-mega li a{display:block;padding:8px 10px;border-radius:6px;font-size:.88rem;}
.nni-mega li a:hover{background:var(--nni-surface);color:var(--nni-primary);}

.nni-header__actions{display:flex;align-items:center;gap:10px;}
.nni-icon-btn{
  width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;background:var(--nni-surface);border:1px solid var(--nni-border);
  transition:background var(--nni-transition),transform var(--nni-transition);
}
.nni-icon-btn:hover{background:var(--nni-primary);color:#fff;transform:translateY(-2px);}
.nni-icon-btn svg{width:18px;height:18px;}

.nni-theme-toggle .icon-moon{display:none;}
[data-theme="dark"] .nni-theme-toggle .icon-sun{display:none;}
[data-theme="dark"] .nni-theme-toggle .icon-moon{display:inline-flex;}

.nni-menu-toggle{display:none;}

/* Breaking news ticker */
.nni-ticker{background:var(--nni-primary);color:#fff;height:var(--nni-ticker-h);overflow:hidden;}
.nni-ticker .container{display:flex;align-items:center;height:100%;gap:14px;}
.nni-ticker__label{background:var(--nni-secondary);padding:4px 12px;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;flex-shrink:0;}
.nni-ticker__viewport{overflow:hidden;flex:1;position:relative;height:100%;}
.nni-ticker__track{display:flex;gap:60px;position:absolute;white-space:nowrap;align-items:center;height:100%;will-change:transform;}
.nni-ticker__track a{font-size:.85rem;font-weight:500;}
.nni-ticker__track a:hover{text-decoration:underline;}

/* Search overlay (Ajax search) */
.nni-search-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;
  display:flex;align-items:flex-start;justify-content:center;padding-top:8vh;
  opacity:0;visibility:hidden;transition:opacity var(--nni-transition),visibility var(--nni-transition);
}
.nni-search-overlay.is-active{opacity:1;visibility:visible;}
.nni-search-box{background:var(--nni-bg);width:min(640px,92vw);border-radius:var(--nni-radius);padding:20px;box-shadow:var(--nni-shadow-hover);}
.nni-search-box form{display:flex;gap:8px;}
.nni-search-box input[type="search"]{flex:1;padding:12px 14px;border:2px solid var(--nni-border);border-radius:8px;font-size:1rem;background:var(--nni-bg);color:var(--nni-text);}
.nni-search-box input[type="search"]:focus{outline:none;border-color:var(--nni-primary);}
.nni-search-close{align-self:flex-end;margin-bottom:10px;background:none;border:none;font-size:1.4rem;color:var(--nni-text);}
.nni-search-results{margin-top:14px;max-height:50vh;overflow-y:auto;}
.nni-search-results a.nni-search-result{display:flex;gap:10px;padding:8px;border-radius:8px;align-items:center;}
.nni-search-results a.nni-search-result:hover{background:var(--nni-surface);}
.nni-search-results img{width:56px;height:56px;object-fit:cover;border-radius:6px;flex-shrink:0;}
.nni-search-empty,.nni-search-loading{padding:10px;color:var(--nni-text-muted);font-size:.9rem;}

/* =====================================================
   3. HERO
===================================================== */
.nni-hero{padding:28px 0;}
.nni-hero__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;}
.nni-hero__main{position:relative;border-radius:var(--nni-radius);overflow:hidden;min-height:440px;display:flex;align-items:flex-end;box-shadow:var(--nni-shadow);}
.nni-hero__main img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.nni-hero__main::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.15) 60%,transparent 100%);z-index:1;}
.nni-hero__content{position:relative;z-index:2;padding:26px;color:#fff;}
.nni-hero__content h1,.nni-hero__content h2{color:#fff;font-size:1.7rem;margin-bottom:10px;}
.nni-hero__content a:hover{color:var(--nni-accent);}
.nni-hero__meta{display:flex;gap:14px;font-size:.8rem;opacity:.9;flex-wrap:wrap;}

.nni-hero__cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.nni-hero__card{position:relative;border-radius:var(--nni-radius);overflow:hidden;min-height:210px;box-shadow:var(--nni-shadow);}
.nni-hero__card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.nni-hero__card:hover img{transform:scale(1.08);}
.nni-hero__card::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.8),transparent 70%);}
.nni-hero__card-content{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:14px;color:#fff;}
.nni-hero__card-content h3{color:#fff;font-size:.95rem;margin:6px 0 0;}

/* =====================================================
   4. SECTION HEADER
===================================================== */
.nni-section{padding:36px 0;}
.nni-section__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;border-bottom:3px solid var(--nni-secondary);padding-bottom:10px;}
.nni-section__head h2{font-size:1.4rem;margin:0;position:relative;padding-left:14px;}
.nni-section__head h2::before{content:'';position:absolute;left:0;top:4px;bottom:4px;width:5px;background:var(--nni-primary);border-radius:4px;}
.nni-section__head a.view-all{font-size:.85rem;font-weight:700;color:var(--nni-primary);white-space:nowrap;}
.nni-section__head a.view-all:hover{text-decoration:underline;}

.nni-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.nni-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.nni-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}

/* =====================================================
   5. LAYOUT: main + sidebar
===================================================== */
.nni-layout{display:grid;grid-template-columns:1fr 340px;gap:32px;align-items:start;}
.nni-main-col{min-width:0;}
.nni-sidebar{position:sticky;top:calc(var(--nni-header-h) + 16px);display:flex;flex-direction:column;gap:26px;}
.nni-widget{background:var(--nni-surface);border:1px solid var(--nni-border);border-radius:var(--nni-radius);padding:18px;}
.nni-widget h3{font-size:1.05rem;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--nni-border);position:relative;}
.nni-widget h3::after{content:'';position:absolute;left:0;bottom:-2px;width:40px;height:2px;background:var(--nni-primary);}
.nni-widget-list{display:flex;flex-direction:column;gap:12px;}
.nni-widget-list li{display:flex;gap:10px;align-items:flex-start;}
.nni-widget-list .num{font-family:var(--nni-font-heading);font-weight:800;font-size:1.3rem;color:var(--nni-primary);opacity:.5;width:26px;flex-shrink:0;}
.nni-widget-list img{width:64px;height:64px;object-fit:cover;border-radius:8px;flex-shrink:0;}
.nni-widget-list .title{font-size:.88rem;font-weight:600;line-height:1.35;}
.nni-widget-list .title a:hover{color:var(--nni-primary);}
.nni-widget-list .meta{font-size:.72rem;color:var(--nni-text-muted);margin-top:3px;}

.nni-newsletter input[type="email"]{width:100%;padding:10px 12px;border:1px solid var(--nni-border);border-radius:8px;margin-bottom:10px;background:var(--nni-bg);color:var(--nni-text);}
.nni-newsletter .btn{width:100%;justify-content:center;}
.nni-newsletter p.small{font-size:.75rem;color:var(--nni-text-muted);margin-top:8px;}

/* Ads */
.nni-ad{display:flex;align-items:center;justify-content:center;background:var(--nni-surface);border:1px dashed var(--nni-border);border-radius:8px;color:var(--nni-text-muted);font-size:.75rem;overflow:hidden;margin:0 auto;}
.nni-ad-728x90{max-width:728px;min-height:90px;}
.nni-ad-300x250{max-width:300px;min-height:250px;}
.nni-ad-300x600{max-width:300px;min-height:600px;}
.nni-ad-responsive{width:100%;min-height:100px;}

/* =====================================================
   6. SINGLE POST
===================================================== */
.nni-breadcrumbs{font-size:.8rem;color:var(--nni-text-muted);margin:16px 0;}
.nni-breadcrumbs a:hover{color:var(--nni-primary);}
.nni-breadcrumbs span[aria-hidden]{margin:0 6px;}

.nni-progress{position:fixed;top:0;left:0;height:3px;background:var(--nni-primary);z-index:1001;width:0%;transition:width .1s linear;}

.nni-single-header{margin-bottom:20px;}
.nni-single-header h1{font-size:2rem;margin-bottom:14px;}
.nni-single-meta{display:flex;flex-wrap:wrap;gap:16px;align-items:center;font-size:.85rem;color:var(--nni-text-muted);}
.nni-single-meta .nni-author{display:flex;align-items:center;gap:8px;}
.nni-single-meta img.avatar{width:34px;height:34px;border-radius:50%;}
.nni-single-thumb{border-radius:var(--nni-radius);overflow:hidden;margin:18px 0;box-shadow:var(--nni-shadow);}

.nni-share{display:flex;flex-direction:column;gap:10px;position:sticky;top:calc(var(--nni-header-h) + 20px);}
.nni-share a{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--nni-surface);border:1px solid var(--nni-border);transition:all var(--nni-transition);}
.nni-share a:hover{background:var(--nni-primary);color:#fff;transform:scale(1.08);}
.nni-share-mobile{display:none;gap:10px;margin:18px 0;}
.nni-share-mobile a{flex:1;text-align:center;padding:10px;border-radius:8px;background:var(--nni-surface);border:1px solid var(--nni-border);}

.nni-article-wrap{display:grid;grid-template-columns:56px 1fr;gap:20px;}
.nni-article-body{max-width:100%;font-size:1.05rem;line-height:1.85;}
.nni-article-body p{margin-bottom:1.3em;}
.nni-article-body h2{font-size:1.5rem;margin-top:1.6em;}
.nni-article-body h3{font-size:1.25rem;margin-top:1.4em;}
.nni-article-body img{border-radius:var(--nni-radius);margin:1.2em 0;}
.nni-article-body blockquote{border-left:4px solid var(--nni-primary);background:var(--nni-surface);padding:16px 20px;border-radius:0 8px 8px 0;font-style:italic;margin:1.5em 0;}
.nni-article-body a{color:var(--nni-primary);text-decoration:underline;}
.nni-article-body ul,.nni-article-body ol{margin:0 0 1.3em 1.4em;}
.nni-article-body figcaption{font-size:.8rem;color:var(--nni-text-muted);text-align:center;margin-top:6px;}
.nni-article-body table{width:100%;border-collapse:collapse;margin:1.3em 0;}
.nni-article-body table td,.nni-article-body table th{border:1px solid var(--nni-border);padding:8px 10px;}

.nni-toc{background:var(--nni-surface);border:1px solid var(--nni-border);border-radius:var(--nni-radius);padding:18px 20px;margin:20px 0;}
.nni-toc summary{font-family:var(--nni-font-heading);font-weight:700;cursor:pointer;font-size:1rem;}
.nni-toc ol{margin:12px 0 0 20px;}
.nni-toc a{font-size:.9rem;}
.nni-toc a:hover{color:var(--nni-primary);}

.nni-tags{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0;}
.nni-tags a{background:var(--nni-surface);border:1px solid var(--nni-border);padding:6px 12px;border-radius:20px;font-size:.8rem;}
.nni-tags a:hover{background:var(--nni-primary);color:#fff;border-color:var(--nni-primary);}

.nni-author-box{display:flex;gap:16px;background:var(--nni-surface);border:1px solid var(--nni-border);border-radius:var(--nni-radius);padding:20px;margin:26px 0;}
.nni-author-box img{width:74px;height:74px;border-radius:50%;flex-shrink:0;}
.nni-author-box h4{margin-bottom:6px;}
.nni-author-box p{font-size:.9rem;color:var(--nni-text-muted);margin-bottom:8px;}
.nni-author-box .socials a{margin-right:10px;font-size:.8rem;color:var(--nni-primary);}

.nni-post-nav{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:30px 0;}
.nni-post-nav .nav-item{background:var(--nni-surface);border:1px solid var(--nni-border);border-radius:var(--nni-radius);padding:16px;transition:box-shadow var(--nni-transition);}
.nni-post-nav .nav-item:hover{box-shadow:var(--nni-shadow-hover);}
.nni-post-nav .label{font-size:.72rem;text-transform:uppercase;color:var(--nni-primary);font-weight:700;}
.nni-post-nav .next{text-align:right;}

.nni-related{margin-top:36px;}
.nni-comments{margin-top:36px;}
.comment-form input,.comment-form textarea{width:100%;padding:10px 12px;border:1px solid var(--nni-border);border-radius:8px;background:var(--nni-bg);color:var(--nni-text);margin-bottom:12px;}
.comment-list{list-style:none;margin:0;padding:0;}
.comment-list .comment{border-bottom:1px solid var(--nni-border);padding:16px 0;}
.comment-list .comment-author img{border-radius:50%;margin-right:10px;}

/* =====================================================
   7. FOOTER
===================================================== */
.nni-footer{background:var(--nni-secondary);color:#d8d8d8;margin-top:50px;padding-top:50px;}
.nni-footer h4{color:#fff;font-size:1.05rem;margin-bottom:16px;}
.nni-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.1);}
.nni-footer-grid ul li{margin-bottom:10px;}
.nni-footer-grid a:hover{color:var(--nni-accent);}
.nni-footer .logo{font-family:var(--nni-font-heading);font-weight:800;font-size:1.4rem;color:#fff;margin-bottom:12px;}
.nni-footer .logo span{color:var(--nni-primary);}
.nni-footer-social{display:flex;gap:10px;margin-top:14px;}
.nni-footer-social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;}
.nni-footer-social a:hover{background:var(--nni-primary);}
.nni-footer-bottom{display:flex;justify-content:space-between;padding:18px 0;font-size:.82rem;flex-wrap:wrap;gap:10px;}
.nni-footer-bottom ul{display:flex;gap:16px;flex-wrap:wrap;}

/* =====================================================
   8. UTILS / ACCESSIBILITY / DARK MODE image dim
===================================================== */
[data-theme="dark"] img{filter:brightness(.92);}
:focus-visible{outline:3px solid var(--nni-primary);outline-offset:2px;}
.nni-loadmore-wrap{text-align:center;margin:30px 0;}
.nni-spinner{width:28px;height:28px;border:3px solid var(--nni-border);border-top-color:var(--nni-primary);border-radius:50%;animation:nni-spin 1s linear infinite;margin:0 auto;}
@keyframes nni-spin{to{transform:rotate(360deg);}}
.nni-video-badge{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.7);color:#fff;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;}

/* lazy load blur-up */
img.lazy{filter:blur(8px);transition:filter .4s ease;background:var(--nni-surface);}
img.lazy.loaded{filter:blur(0);}
