/* shared.css — Global styles for FPI India website */
/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap');

/* ── DARK THEME ── */
:root,[data-theme="dark"]{
  --bg:#07090f; --s1:#0e1219; --s2:#141b26; --b:#1c2a3a;
  --acc:#2dd4bf; --grn:#22c55e; --red:#ef4444; --yel:#f59e0b; --blu:#3b82f6;
  --txt:#e2e8f0; --sub:#94a3b8; --mut:#64748b;
  --shadow:0 4px 24px rgba(0,0,0,.5);
  --font:'DM Sans',sans-serif; --mono:'DM Mono',monospace;
  --cg:#1c2a3a; --ct:#64748b; --cl:#e2e8f0;
  --nav-bg:#0a0e18; --nav-border:#1c2a3a;
}
/* ── LIGHT THEME ── */
[data-theme="light"]{
  --bg:#f0f4f8; --s1:#ffffff; --s2:#f8fafc; --b:#e2e8f0;
  --acc:#0891b2; --grn:#16a34a; --red:#dc2626; --yel:#d97706; --blu:#2563eb;
  --txt:#0f172a; --sub:#475569; --mut:#94a3b8;
  --shadow:0 4px 24px rgba(0,0,0,.08);
  --cg:#e2e8f0; --ct:#94a3b8; --cl:#1e293b;
  --nav-bg:#ffffff; --nav-border:#e2e8f0;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--txt);font-family:var(--font);min-height:100vh;
  transition:background .25s,color .25s}

/* ── NAVIGATION ── */
#sitenav{
  position:sticky;top:0;z-index:500;
  background:var(--nav-bg);border-bottom:1px solid var(--nav-border);
  backdrop-filter:blur(12px);
}
.nav-inner{
  max-width:1400px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;height:58px;
}
.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-brand-icon{
  width:34px;height:34px;border-radius:8px;
  background:linear-gradient(135deg,#0891b2,#0e7490);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;box-shadow:0 0 14px #0891b230;flex-shrink:0;
}
.nav-brand-text{font-size:15px;font-weight:800;color:var(--txt);letter-spacing:-.3px}
.nav-brand-text em{font-style:normal;color:var(--acc)}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-link{
  padding:7px 14px;border-radius:8px;font-size:13px;font-weight:600;
  color:var(--mut);text-decoration:none;transition:.15s;white-space:nowrap;
}
.nav-link:hover{color:var(--txt);background:var(--s2)}
.nav-link.active{color:var(--acc);background:var(--s2)}
.nav-link.nav-donate{
  background:linear-gradient(135deg,#f59e0b,#ef4444);
  color:#fff!important;margin-left:6px;font-size:12px;
}
.nav-link.nav-donate:hover{opacity:.9;transform:scale(1.03)}
.nav-right{display:flex;align-items:center;gap:8px}
.btn-theme{
  width:36px;height:36px;border-radius:50%;border:1px solid var(--b);
  background:var(--s2);cursor:pointer;font-size:16px;
  display:flex;align-items:center;justify-content:center;transition:.2s;
}
.btn-theme:hover{border-color:var(--acc);transform:rotate(15deg)}

/* Mobile nav hamburger */
.nav-burger{
  display:none;background:none;border:none;cursor:pointer;
  width:36px;height:36px;flex-direction:column;align-items:center;
  justify-content:center;gap:5px;
}
.nav-burger span{
  width:22px;height:2px;border-radius:2px;
  background:var(--txt);transition:.2s;display:block;
}
/* ── DROPDOWN MENUS ─────────────────────────────────────────────── */
.nav-dropdown{
  position:relative;display:inline-flex;align-items:center;
}
.nav-dropbtn{
  background:none;border:none;cursor:pointer;font-family:inherit;
  display:flex;align-items:center;gap:5px;
}
.nav-arrow{
  font-size:10px;opacity:.6;transition:transform .2s;display:inline-block;
}
.nav-dropdown:hover .nav-arrow{ transform:rotate(180deg); }
.nav-submenu{
  display:none;position:absolute;top:calc(100% + 6px);left:0;
  background:var(--nav-bg);border:1px solid var(--b);border-radius:12px;
  padding:6px;min-width:205px;z-index:600;
  box-shadow:0 8px 32px rgba(0,0,0,.25);
  backdrop-filter:blur(16px);
  animation:ddFadeIn .15s ease;
}
.nav-submenu.open{ display:block; }
@keyframes ddFadeIn{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:translateY(0)}
}
.nav-sublink{
  display:flex;align-items:center;gap:8px;
  padding:9px 13px;border-radius:8px;font-size:13px;font-weight:600;
  color:var(--sub);text-decoration:none;transition:.13s;white-space:nowrap;cursor:pointer;
}
.nav-sublink:hover{ color:var(--txt);background:var(--s2); }
.nav-sublink.active{ color:var(--acc);background:rgba(45,212,191,.1); }
.nav-sublink-soon{ opacity:.5;cursor:default; }
.nav-sublink-soon:hover{ background:none;color:var(--sub); }
.soon-badge{
  font-size:9px;font-weight:700;padding:1px 5px;border-radius:4px;
  background:rgba(245,158,11,.2);color:#f59e0b;
  border:1px solid rgba(245,158,11,.3);
  margin-left:auto;letter-spacing:.3px;text-transform:uppercase;
}
/* Dropdown button highlighted when its group is the active page */
.nav-dropdown.active > .nav-dropbtn{ color:var(--acc);background:var(--s2); }

@media(max-width:700px){
  .nav-links{
    display:none;position:fixed;top:58px;left:0;right:0;
    background:var(--nav-bg);border-bottom:1px solid var(--b);
    flex-direction:column;padding:12px;gap:4px;
    max-height:calc(100vh - 58px);overflow-y:auto;
  }
  .nav-links.open{display:flex}
  .nav-link,.nav-dropbtn{padding:12px 14px;border-radius:10px;width:100%;justify-content:space-between;}
  .nav-burger{display:flex}
  /* Mobile: dropdowns expand inline (accordion style) */
  .nav-dropdown{flex-direction:column;width:100%;align-items:stretch;}

  .nav-submenu{
    display:flex;flex-direction:column;position:static;box-shadow:none;border:none;animation:none;
    background:var(--s2);border-radius:10px;padding:4px 0 4px 10px;
    margin-top:2px;min-width:unset;
  }  
  
  .nav-sublink{padding:10px 13px;border-radius:8px;}

  /* Flat nav-links (S&P 500, NSE News etc.) full width on mobile */
  .nav-link{ width:100%; }
}

/* ── ANNOUNCEMENT BAR ── */
.announcement-bar{
  background:linear-gradient(135deg,#0891b2,#06b6d4);
  color:#fff;padding:10px 20px;position:relative;
  animation:slideDown 0.4s ease;
}
.announcement-content{
  max-width:1400px;margin:0 auto;display:flex;align-items:center;
  justify-content:center;gap:10px;font-size:13px;line-height:1.5;
  flex-wrap:wrap;
}
.announcement-icon{font-size:18px;flex-shrink:0}
.announcement-text{font-weight:500;text-align:center}
.announcement-close{
  background:rgba(255,255,255,0.2);border:none;color:#fff;
  width:24px;height:24px;border-radius:50%;cursor:pointer;
  font-size:18px;line-height:1;transition:0.2s;
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
}
.announcement-close:hover{background:rgba(255,255,255,0.3)}
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
@media(max-width:640px){
  .announcement-bar{padding:8px 16px}
  .announcement-content{font-size:12px;gap:8px}
  .announcement-text{padding-right:30px}
}

/* ── PAGE WRAPPER ── */
.page{max-width:1400px;margin:0 auto;padding:24px 18px}
@media(max-width:640px){.page{padding:14px 12px}}

/* ── AD SLOTS ── */
.ad-slot{
  background:var(--s2);border:1px dashed var(--b);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  color:var(--mut);font-size:11px;font-family:var(--mono);
  text-align:center;overflow:hidden;
}
.ad-banner{width:100%;height:90px;margin:16px 0}
.ad-rectangle{width:300px;height:250px}
.ad-sidebar{width:160px;height:600px}
@media(max-width:700px){.ad-sidebar{display:none}}

/* ── DONATE SECTION ── */
.donate-bar{
  background:linear-gradient(135deg,#451a0322,#7f1d1d22);
  border:1px solid #f59e0b44;border-radius:14px;
  padding:18px 22px;margin:20px 0;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
}
.donate-bar p{flex:1;font-size:13px;color:var(--sub);min-width:200px}
.donate-bar p strong{color:var(--txt);display:block;margin-bottom:3px;font-size:14px}
.donate-btns{display:flex;gap:8px;flex-wrap:wrap}
.btn-coffee{
  display:flex;align-items:center;gap:7px;
  padding:9px 18px;border-radius:10px;font-weight:700;
  font-size:13px;text-decoration:none;transition:.15s;cursor:pointer;border:none;
}
.btn-coffee:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-coffee.primary{background:#FFDD00;color:#000}
.btn-coffee.upi{background:var(--s1);color:var(--txt);border:1px solid var(--b)}

/* ── FOOTER ── */
footer{
  background:var(--s1);border-top:1px solid var(--b);
  margin-top:48px;padding:32px 20px 20px;
}
.footer-inner{max-width:1400px;margin:0 auto}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;margin-bottom:24px;
}
@media(max-width:640px){.footer-grid{grid-template-columns:1fr}}
.footer-brand p{font-size:12px;color:var(--mut);line-height:1.7;margin-top:8px;max-width:320px}
.footer-col h4{font-size:12px;font-weight:700;text-transform:uppercase;
  letter-spacing:.8px;color:var(--mut);margin-bottom:12px;font-family:var(--mono)}
.footer-col a{display:block;font-size:13px;color:var(--sub);text-decoration:none;
  margin-bottom:8px;transition:.15s}
.footer-col a:hover{color:var(--acc)}
.footer-bottom{
  border-top:1px solid var(--b);padding-top:16px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
}
.footer-bottom p{font-size:12px;color:var(--mut)}
.footer-bottom a{color:var(--mut);text-decoration:none}
.footer-bottom a:hover{color:var(--acc)}

/* ── SHARED CARD ── */
.card{background:var(--s1);border:1px solid var(--b);border-radius:14px;padding:22px 24px}
.card-sm{background:var(--s1);border:1px solid var(--b);border-radius:12px;padding:16px 18px}

/* ── SECTION TITLE ── */
.sec-head{display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:8px;margin-bottom:16px}
.sec-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}
.sec-dot{width:7px;height:7px;border-radius:50%;background:var(--acc);box-shadow:0 0 6px var(--acc)}
.sec-sub{font-size:11px;color:var(--mut);font-family:var(--mono)}

/* ── TABS ── */
.tabs{display:flex;gap:8px;padding:6px;background:var(--s1);border-radius:12px;
  border:1px solid var(--b);width:fit-content;margin-bottom:20px;flex-wrap:wrap}
.tab{padding:10px 22px;border-radius:8px;font-size:14px;font-weight:700;
  cursor:pointer;color:var(--sub);transition:all .2s;border:1px solid transparent;
  background:none;font-family:var(--font);letter-spacing:.2px;
  display:inline-flex;align-items:center;gap:6px}
.tab:hover{color:var(--txt);background:var(--s2);border-color:var(--b)}
.tab.on{background:var(--s2);color:var(--acc);
  border-color:var(--acc);
  box-shadow:0 0 10px rgba(45,212,191,.25),0 0 2px rgba(45,212,191,.4);}

/* Tab icon animations */
.tab-icon{font-size:15px;display:inline-block;transition:transform .2s}
.tab:hover .tab-icon{transform:scale(1.2)}
.tab.on .tab-icon{animation:tabIconPop .3s ease}

@keyframes tabIconPop{0%{transform:scale(1)}50%{transform:scale(1.35)}100%{transform:scale(1)}}

/* Fire icon — flicker on active */
.tab.on .tab-fire{animation:tabFire .6s ease infinite alternate}
@keyframes tabFire{0%{transform:scale(1) rotate(-3deg)}100%{transform:scale(1.15) rotate(3deg)}}

/* Bounce icon */
.tab.on .tab-bounce{animation:tabBounce .5s ease infinite alternate}
@keyframes tabBounce{0%{transform:translateY(0)}100%{transform:translateY(-3px)}}

/* Spin icon — slow rotation on active */
.tab.on .tab-spin{animation:tabSpin 2s linear infinite}
@keyframes tabSpin{to{transform:rotate(360deg)}}

/* Pulse icon */
.tab.on .tab-pulse{animation:tabPulse 1s ease infinite}
@keyframes tabPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}

/* ── PILLS ── */
.pill{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:600;
  letter-spacing:.4px;font-family:var(--mono);border:1px solid;white-space:nowrap}
.pill-live{background:#14532d22;color:var(--grn);border-color:#16a34a44}
.pill-date{background:var(--s2);color:var(--acc);border-color:var(--b)}
.pill-warn{background:#451a0322;color:var(--yel);border-color:#78350f44}

/* ── KPI CARDS ── */
.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:12px;margin-bottom:20px}
.kpi{background:var(--s1);border:1px solid var(--b);border-radius:12px;
  padding:16px 18px;position:relative;overflow:hidden;transition:transform .15s}
.kpi:hover{transform:translateY(-2px)}
.kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;border-radius:12px 12px 0 0}
.kpi.k-g::before{background:var(--grn)} .kpi.k-r::before{background:var(--red)}
.kpi.k-a::before{background:var(--acc)} .kpi.k-y::before{background:var(--yel)}
.kpi-lbl{font-size:10px;text-transform:uppercase;letter-spacing:.9px;color:var(--mut);
  font-family:var(--mono);margin-bottom:8px}
.kpi-val{font-size:24px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}
.kpi-val.pos{color:var(--grn)} .kpi-val.neg{color:var(--red)}
.kpi-val.acc{color:var(--acc)} .kpi-val.yel{color:var(--yel)}
.kpi-sub{font-size:10px;color:var(--mut);margin-top:5px;font-family:var(--mono)}

/* ── HEAT MAP ── */
.hm{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}
.hm-cell{border-radius:10px;padding:12px 10px;cursor:pointer;
  transition:transform .12s,box-shadow .12s;border:1px solid transparent}
.hm-cell:hover{transform:scale(1.04);box-shadow:0 6px 18px #00000055}
.hm-nm{font-size:10px;font-weight:700;letter-spacing:.3px;margin-bottom:5px;opacity:.85;line-height:1.3}
.hm-val{font-size:17px;font-weight:800;font-variant-numeric:tabular-nums}
.hm-sub{font-size:9px;opacity:.6;margin-top:2px;font-family:var(--mono)}

/* ── TABLE ── */
.rt{width:100%;border-collapse:collapse}
.rt th{padding:9px 12px;text-align:left;font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.7px;color:var(--mut);
  font-family:var(--mono);border-bottom:1px solid var(--b)}
.rt td{padding:10px 12px;border-bottom:1px solid var(--b);font-size:13px;
  transition:background .1s}
.rt tr:last-child td{border:0}
.rt tr:hover td{background:var(--s2)}
.bar-bg{height:5px;border-radius:3px;background:var(--b);
  display:inline-block;vertical-align:middle;width:60px;margin-left:8px}
.bar-fill{height:5px;border-radius:3px;display:block}
.tag-badge{display:inline-block;padding:2px 9px;border-radius:8px;font-size:10px;font-weight:700}

/* ── LOADING / SPINNER ── */
.spin{width:40px;height:40px;border:3px solid var(--b);
  border-top-color:var(--acc);border-radius:50%;animation:sp 1s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.loading-center{display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:14px;padding:60px}
.loading-center p{font-size:13px;color:var(--mut);font-family:var(--mono)}

/* ── FALLBACK NOTICE ── */
.fallback-notice{
  background:#451a0322;border:1px solid #78350f55;border-radius:10px;
  padding:11px 16px;margin-bottom:16px;font-size:12px;color:var(--yel);font-family:var(--mono);
  display:none;
}
.fallback-notice.show{display:block}

/* ── DATE PICKER DROPDOWN ── */
.date-picker{position:relative;display:inline-block}
.date-picker-btn{
  display:flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:10px;cursor:pointer;
  background:var(--s1);border:1px solid var(--b);
  color:var(--txt);font-size:13px;font-weight:600;
  transition:.15s;white-space:nowrap;
}
.date-picker-btn:hover{border-color:var(--acc)}
.date-picker-btn svg{width:14px;height:14px;stroke:var(--mut);transition:.2s}
.date-picker-btn.open svg{transform:rotate(180deg);stroke:var(--acc)}
.date-dropdown{
  position:absolute;top:calc(100% + 6px);left:0;z-index:300;
  background:var(--s1);border:1px solid var(--b);border-radius:12px;
  box-shadow:var(--shadow);min-width:260px;overflow:hidden;
  display:none;
}
.date-dropdown.open{display:block}
.date-dropdown-head{
  padding:10px 14px;background:var(--s2);border-bottom:1px solid var(--b);
  font-size:11px;font-weight:700;color:var(--mut);font-family:var(--mono);
  text-transform:uppercase;letter-spacing:.6px;
}
.date-year-group{border-bottom:1px solid var(--b)}
.date-year-label{
  padding:8px 14px;font-size:12px;font-weight:700;color:var(--acc);
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  background:var(--s2);font-family:var(--mono);
}
.date-year-label:hover{background:var(--b)}
.date-year-items{display:none;flex-wrap:wrap;gap:0}
.date-year-items.open{display:flex}
.date-item{
  padding:9px 14px;font-size:12px;cursor:pointer;color:var(--txt);
  width:50%;border-bottom:1px solid var(--b);font-family:var(--mono);
  transition:.1s;
}
.date-item:nth-child(odd){border-right:1px solid var(--b)}
.date-item:hover{background:var(--s2);color:var(--acc)}
.date-item.active{background:var(--acc);color:#000;font-weight:700}

/* ── SAFE AREA ── */
.page{
  padding-bottom:max(24px,env(safe-area-inset-bottom));
  padding-left:max(18px,env(safe-area-inset-left));
  padding-right:max(18px,env(safe-area-inset-right));
}
@media(max-width:640px){
  .page{padding:12px max(12px,env(safe-area-inset-left))}
  .kpi-row{grid-template-columns:repeat(2,1fr);gap:8px}
  .kpi-val{font-size:18px}
  .hm{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px}
  .rt th,.rt td{padding:8px 8px;font-size:11px}
  .card{padding:14px 12px}
  .donate-bar{padding:14px}
  .tabs{gap:4px}
  .tab{padding:8px 13px;font-size:12px}
}
/* Share Button - Popup Style */
.share-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  background: linear-gradient(135deg, var(--acc), #06b6d4);
  color: #000;
  border: none;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
}
.share-trigger:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(14, 165, 233, 0.4);
}

.share-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0,0,0,0.7);
  z-index: 9999;
  backdrop-filter: blur(4px);
  animation: fadeIn 0.2s ease;
}
.share-modal.show {
  display: flex;
  align-items: center;
  justify-content: center;
}
.share-popup {
  background: var(--s1);
  border: 1px solid var(--b);
  border-radius: 16px;
  padding: 28px;
  max-width: 400px;
  width: 90%;
  animation: slideUp 0.3s ease;
}
.share-popup h3 {
  font-size: 18px;
  margin-bottom: 20px;
  color: var(--txt);
}
.share-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}
.share-option {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 16px 10px;
  background: var(--s2);
  border: 1px solid var(--b);
  border-radius: 12px;
  text-decoration: none;
  color: var(--txt);
  font-size: 12px;
  font-weight: 600;
  transition: all 0.2s;
  cursor: pointer;
}
.share-option:hover {
  background: var(--s3);
  border-color: var(--acc);
  transform: translateY(-2px);
}
.share-icon {
  width: 32px;
  height: 32px;
}
.share-close {
  width: 100%;
  padding: 12px;
  background: var(--s2);
  border: 1px solid var(--b);
  border-radius: 8px;
  color: var(--sub);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}
.share-close:hover {
  background: var(--acc);
  color: #000;
  border-color: var(--acc);
}
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes slideUp {
  from { transform: translateY(30px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
