/*
Theme Name: Gift Nifty Live
Theme URI: https://giftnifty.org
Author: Gift Nifty Team
Author URI: https://giftnifty.org
Description: Modern WordPress theme for live Gift Nifty & NSE market data with amCharts 5 charts.
Version: 9.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: giftniftylive
Tags: finance, trading, markets, nifty, stock market
*/

/* ── Reset ─────────────────────────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto}

/* ── Desktop Dropdown Nav ──────────────────────────────────────────────── */
.gn-nav{list-style:none;display:flex;align-items:center;gap:2px}
.gn-nav li{position:relative}
.gn-nav > li > a{display:block;padding:8px 16px;font-size:15px;font-weight:600;letter-spacing:.03em;color:#cbd5e1;border-radius:8px;transition:all .25s}
.gn-nav > li > a:hover,
.gn-nav > li.current-menu-item > a,
.gn-nav > li.current-menu-ancestor > a{color:#fff;background:rgba(255,255,255,.08)}
/* Dropdown arrow for parent items */
.gn-nav > li.menu-item-has-children > a::after{content:'';display:inline-block;width:0;height:0;margin-left:6px;vertical-align:2px;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid currentColor;transition:transform .2s}
.gn-nav > li.menu-item-has-children:hover > a::after{transform:rotate(180deg)}
/* Dropdown panel */
.gn-nav .sub-menu{list-style:none;position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);min-width:220px;background:#018790;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:8px;box-shadow:0 25px 60px -12px rgba(0,0,0,.5);opacity:0;visibility:hidden;transition:all .25s ease;z-index:100}
.gn-nav .sub-menu::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:12px;height:12px;background:#018790;border-left:1px solid rgba(255,255,255,.1);border-top:1px solid rgba(255,255,255,.1);transform:translateX(-50%) rotate(45deg)}
.gn-nav li:hover > .sub-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.gn-nav .sub-menu li a{display:block;padding:9px 14px;font-size:15px;font-weight:500;color:#fff;border-radius:8px;transition:all .2s;white-space:nowrap}
.gn-nav .sub-menu li a:hover{color:#fff;background:rgba(56,189,248,.12)}
.gn-nav .sub-menu li.current-menu-item a{color:#38bdf8;background:#00B7B5}
/* Nested sub-menu (level 3) */
.gn-nav .sub-menu .sub-menu{top:0;left:100%;transform:translateX(8px) translateY(0)}
.gn-nav .sub-menu .sub-menu::before{display:none}
.gn-nav .sub-menu li:hover > .sub-menu{transform:translateX(0) translateY(0)}

/* ── Mobile Nav ────────────────────────────────────────────────────────── */
.gn-nav-mobile{list-style:none}
.gn-nav-mobile li a{display:block;padding:10px 14px;font-size:14px;font-weight:500;color:#cbd5e1;border-radius:8px;transition:all .2s}
.gn-nav-mobile li a:hover{color:#fff;background:rgba(255,255,255,.08)}
.gn-nav-mobile li.current-menu-item > a{color:#38bdf8}
.gn-nav-mobile .sub-menu{list-style:none;padding-left:16px;margin-top:2px}
.gn-nav-mobile .sub-menu li a{font-size:13px;color:#64748b;padding:8px 14px}
.gn-nav-mobile .sub-menu li a:hover{color:#38bdf8}

/* ── Price Animations ──────────────────────────────────────────────────── */
@keyframes priceFlash{0%,100%{background-color:transparent}50%{background-color:rgba(37,99,235,.12)}}
.update-flash{animation:priceFlash .5s ease-in-out}
#main-price,#price-change,#price-change-percent,#banner-price{transition:all .3s ease}

/* ── Chart Containers ──────────────────────────────────────────────────── */
#intraday_chart,#historical_chart{background:#fff;border-radius:8px;min-height:400px}

/* ── Blog Card Styles ──────────────────────────────────────────────────── */
.blog-card{background:#fff;border-radius:16px;overflow:hidden;border:1px solid #e2e8f0;box-shadow:0 1px 3px rgba(0,0,0,.06);transition:all .3s ease}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -12px rgba(0,0,0,.12);border-color:#cbd5e1}
.blog-card .card-thumb{aspect-ratio:16/10;overflow:hidden;background:#f1f5f9}
.blog-card .card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.blog-card:hover .card-thumb img{transform:scale(1.05)}
.blog-card .card-body{padding:24px}
.blog-card .card-cat{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#0284c7;background:#e0f2fe;padding:4px 10px;border-radius:6px;margin-bottom:12px}
.blog-card .card-title{font-size:18px;font-weight:700;line-height:1.4;color:#0f172a;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-card .card-title:hover{color:#0284c7}
.blog-card .card-excerpt{font-size:14px;color:#64748b;line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:16px}
.blog-card .card-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:#94a3b8}
.blog-card .card-meta .avatar{width:28px;height:28px;border-radius:50%;background:#e2e8f0}

/* ── Single Post Styles ────────────────────────────────────────────────── */
.single-hero{position:relative;border-radius:20px;overflow:hidden;margin-bottom:40px;aspect-ratio:21/9;background:#1e293b}
.single-hero img{width:100%;height:100%;object-fit:cover;opacity:.7}
.single-hero-overlay{position:absolute;inset:0;background:linear-gradient(transparent 30%,rgba(15,23,42,.85));display:flex;flex-direction:column;justify-content:flex-end;padding:40px}
.single-content{font-size:17px;line-height:1.85;color:#334155}
.single-content h2{font-size:26px;font-weight:700;color:#0f172a;margin:40px 0 16px}
.single-content h3{font-size:21px;font-weight:700;color:#0f172a;margin:32px 0 12px}
.single-content p{margin-bottom:20px}
.single-content a{color:#0284c7;text-decoration:underline;text-underline-offset:3px}
.single-content a:hover{color:#0369a1}
.single-content ul,.single-content ol{margin:0 0 20px 24px}
.single-content li{margin-bottom:8px}
.single-content blockquote{border-left:4px solid #38bdf8;background:#f0f9ff;padding:20px 24px;border-radius:0 12px 12px 0;margin:24px 0;font-style:italic;color:#475569}
.single-content img{border-radius:12px;margin:24px 0}
.single-content pre{background:#1e293b;color:#e2e8f0;padding:20px;border-radius:12px;overflow-x:auto;margin:24px 0;font-size:14px}
.single-content code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-size:14px}
.single-content pre code{background:transparent;padding:0}

/* ── Indices Dashboard Cards ───────────────────────────────────────────── */
.index-card{background:#fff;border-radius:16px;padding:24px;border:1px solid #e2e8f0;transition:all .3s ease;position:relative;overflow:hidden}
.index-card:hover{transform:translateY(-3px);box-shadow:0 16px 40px -8px rgba(0,0,0,.1);border-color:#cbd5e1}
.index-card .idx-name{font-size:15px;font-weight:700;color:#0f172a;margin-bottom:4px}
.index-card .idx-price{font-size:28px;font-weight:800;color:#1e293b;margin-bottom:6px}
.index-card .idx-change{font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:8px}
.index-card .idx-up{color:#059669;background:#d1fae5}
.index-card .idx-down{color:#dc2626;background:#fee2e2}
.index-card .idx-chart{position:absolute;bottom:0;right:0;width:120px;height:50px;opacity:.15}

/* ── Misc ──────────────────────────────────────────────────────────────── */
.loading{opacity:.6;pointer-events:none}
.spinner{border:3px solid #f3f3f3;border-top:3px solid #0ea5e9;border-radius:50%;width:20px;height:20px;animation:spin 1s linear infinite;display:inline-block}
@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:#f1f1f1}
::-webkit-scrollbar-thumb{background:#94a3b8;border-radius:5px}
::-webkit-scrollbar-thumb:hover{background:#64748b}
@media print{header,footer,.no-print{display:none}}

/* ── WordPress Core Alignment ──────────────────────────────────────────── */
.wp-block-image{margin:24px 0}
.alignwide{max-width:100%}
.alignfull{width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw}

/* ── Responsive Overrides ──────────────────────────────────────────────── */

/* Chart height responsive via !important override for Tailwind arbitrary */
@media(min-width:768px){
  .md\:\!h-\[500px\]{height:500px!important}
}
@media(min-width:1024px){
  .lg\:\!h-\[600px\]{height:600px!important}
}

/* Mobile: tighter hero image */
@media(max-width:639px){
  .single-hero{aspect-ratio:16/10;border-radius:12px}
  .single-hero-overlay{padding:20px}
  .single-content{font-size:15px;line-height:1.75}
  .single-content h2{font-size:20px;margin:28px 0 12px}
  .single-content h3{font-size:18px;margin:24px 0 10px}
  .single-content blockquote{padding:14px 16px;margin:16px 0}
  .single-content pre{padding:14px;font-size:12px;border-radius:8px}
  .blog-card .card-body{padding:16px}
  .blog-card .card-title{font-size:16px}
  .blog-card .card-excerpt{font-size:13px;-webkit-line-clamp:2}
  .index-card{padding:18px}
  .index-card .idx-price{font-size:22px}
  .index-card .idx-name{font-size:13px}
  .gn-nav .sub-menu{min-width:180px}
}

/* Tablet adjustments */
@media(min-width:640px) and (max-width:1023px){
  .single-hero{aspect-ratio:21/10}
  .single-content{font-size:16px}
  .index-card .idx-price{font-size:24px}
}

/* Prevent horizontal overflow */
html,body{overflow-x:hidden;max-width:100vw}
img,video,iframe,embed,object{max-width:100%}

/* WP pagination responsive */
.page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border-radius:8px;font-size:13px;font-weight:600;border:1px solid #e2e8f0;background:#fff;color:#475569;transition:all .2s}
.page-numbers:hover{border-color:#7dd3fc;background:#f0f9ff;color:#0284c7}
.page-numbers.current{background:#0284c7;color:#fff;border-color:#0284c7}
.page-numbers.dots{border:none;background:none}
ul.page-numbers{list-style:none;display:flex;gap:4px;flex-wrap:wrap;justify-content:center}
ul.page-numbers li{display:inline-flex}

/* WP Nav menu cleanup */
.gn-nav,.gn-nav .sub-menu,.gn-nav-mobile,.gn-nav-mobile .sub-menu{padding-left:0}

