/* =========================================================
   Gift Nifty — Live Hero + FAQ (modern design)
   Deactivate the plugin to fully revert.
   ========================================================= */

.gn-hero {
    --up: #16c784;
    --down: #f6465d;
    position: relative;
    max-width: 720px;
    margin: 0 auto 1.75rem;
    padding: 22px 24px;
    border-radius: 20px;
    color: #e8edf6;
    background:
        radial-gradient(120% 140% at 0% 0%, rgba(22,199,132,.18), transparent 45%),
        radial-gradient(120% 140% at 100% 0%, rgba(99,102,241,.20), transparent 45%),
        linear-gradient(180deg, #0d1424 0%, #0a0f1c 100%);
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 20px 50px -20px rgba(8,12,24,.8), inset 0 1px 0 rgba(255,255,255,.04);
    overflow: hidden;
    -webkit-font-smoothing: antialiased;
}
.gn-hero::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(22,199,132,.06));
    pointer-events: none;
}
.gn-hero.is-down::after { background: linear-gradient(180deg, transparent 60%, rgba(246,70,93,.07)); }

.gn-hero__top {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px; margin-bottom: 14px;
}
.gn-hero__name {
    display: flex; align-items: center; gap: 9px;
    font-weight: 800; letter-spacing: .04em; font-size: 15px;
}
.gn-hero__sub {
    font-weight: 500; letter-spacing: .02em;
    font-size: 11.5px; color: #8a97ad; margin-left: 4px;
}
.gn-live-dot {
    width: 9px; height: 9px; border-radius: 50%; background: var(--up);
    box-shadow: 0 0 0 0 rgba(22,199,132,.7);
    animation: gnPulse 1.8s infinite;
}
@keyframes gnPulse {
    0%   { box-shadow: 0 0 0 0 rgba(22,199,132,.6); }
    70%  { box-shadow: 0 0 0 9px rgba(22,199,132,0); }
    100% { box-shadow: 0 0 0 0 rgba(22,199,132,0); }
}

.gn-status {
    font-size: 12px; font-weight: 700; letter-spacing: .02em;
    padding: 5px 11px; border-radius: 999px;
    background: rgba(255,255,255,.06); color: #aab6c8;
    border: 1px solid rgba(255,255,255,.08);
}
.gn-status.is-open   { background: rgba(22,199,132,.14); color: #4ce0a8; border-color: rgba(22,199,132,.3); }
.gn-status.is-closed { background: rgba(246,70,93,.12); color: #ff8d9c; border-color: rgba(246,70,93,.28); }

.gn-hero__price-row {
    display: flex; align-items: baseline; flex-wrap: wrap; gap: 12px 18px;
}
.gn-hero__price {
    font-size: clamp(2.6rem, 7vw, 3.6rem);
    font-weight: 800; line-height: 1; letter-spacing: -.02em;
    font-variant-numeric: tabular-nums;
    background: linear-gradient(180deg, #ffffff, #c8d2e4);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
}
.gn-hero__chg {
    display: inline-flex; align-items: center; gap: 7px;
    font-size: clamp(1rem, 3vw, 1.25rem); font-weight: 700;
    padding: 6px 12px; border-radius: 12px;
    font-variant-numeric: tabular-nums;
}
.gn-hero__chg.is-up   { color: #16c784; background: rgba(22,199,132,.12); }
.gn-hero__chg.is-down { color: #f6465d; background: rgba(246,70,93,.12); }
.gn-hero__chg.is-flat { color: #aab6c8; background: rgba(255,255,255,.06); }
.gn-hero__pct { opacity: .85; font-weight: 600; }
.gn-arrow { font-size: .8em; }

.gn-hero__stats {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
    margin: 18px 0 14px;
}
.gn-hero__stats > div {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.06);
    border-radius: 12px; padding: 10px 12px;
    display: flex; flex-direction: column; gap: 3px;
}
.gn-hero__stats span { font-size: 11px; color: #8a97ad; letter-spacing: .03em; text-transform: uppercase; }
.gn-hero__stats b { font-size: 16px; font-weight: 700; font-variant-numeric: tabular-nums; color: #e8edf6; }
.gn-hero__stats b.is-up   { color: #16c784; }
.gn-hero__stats b.is-down { color: #f6465d; }

/* Live-update flash on the price */
@keyframes gnFlashUp   { 0% { color: #4ce0a8; } 100% { -webkit-text-fill-color: transparent; } }
@keyframes gnFlashDown { 0% { color: #ff8d9c; } 100% { -webkit-text-fill-color: transparent; } }
.gn-hero__price.gn-flash-up   { animation: gnFlashUp .7s ease-out; }
.gn-hero__price.gn-flash-down { animation: gnFlashDown .7s ease-out; }

.gn-hero__answer {
    margin: 4px 0 8px; font-size: 14.5px; line-height: 1.55; color: #c4cedd;
}
.gn-hero__updated { font-size: 12px; color: #7d8aa0; }

@media (max-width: 560px) {
    .gn-hero { padding: 18px 16px; border-radius: 16px; }
    .gn-hero__stats { grid-template-columns: repeat(2, 1fr); }
}

/* ---------------- FAQ accordion ---------------- */
.gn-faq { max-width: 760px; margin: 1.5rem auto; }
.gn-faq__title { font-size: 1.4rem; font-weight: 800; margin-bottom: 14px; letter-spacing: -.01em; }
.gn-faq__item {
    border: 1px solid var(--gn-line, #e6eaf0);
    border-radius: 12px; margin-bottom: 10px; background: #fff;
    overflow: hidden; transition: box-shadow .2s ease;
}
.gn-faq__item[open] { box-shadow: 0 8px 24px -14px rgba(16,24,40,.35); }
.gn-faq__item summary {
    cursor: pointer; list-style: none; padding: 15px 44px 15px 16px;
    font-weight: 650; font-size: 15.5px; color: #0f172a; position: relative;
}
.gn-faq__item summary::-webkit-details-marker { display: none; }
.gn-faq__item summary::after {
    content: "+"; position: absolute; right: 16px; top: 50%;
    transform: translateY(-50%); font-size: 22px; font-weight: 400;
    color: #15a34a; transition: transform .2s ease;
}
.gn-faq__item[open] summary::after { content: "−"; }
.gn-faq__a { padding: 0 16px 16px; color: #475569; line-height: 1.6; font-size: 14.5px; }

/* ============ Phase C: Implied Open, Global Cues, Gap Calc ============ */
.gn-tiny-disclaimer { margin: 12px 0 0; font-size: 11px; line-height: 1.5; color: #7d8aa0; }

/* Implied Nifty Open card (reuses .gn-hero surface) */
.gn-implied__band {
    display: inline-flex; align-items: baseline; gap: 10px; flex-wrap: wrap;
    font-size: clamp(1.5rem, 5vw, 2.1rem); font-weight: 800; margin: 6px 0 4px;
    padding: 8px 14px; border-radius: 12px;
}
.gn-implied__pts { font-size: .62em; font-weight: 700; opacity: .9; }

/* Global cues panel */
.gn-global__grp {
    text-transform: uppercase; font-size: 11px; letter-spacing: .08em;
    color: #8a97ad; margin: 14px 0 6px; font-weight: 700;
}
.gn-global__grp:first-of-type { margin-top: 6px; }
.gn-global__row {
    display: grid; grid-template-columns: 1fr auto auto; gap: 12px; align-items: center;
    padding: 9px 12px; border-radius: 10px; margin-bottom: 4px;
    background: rgba(255,255,255,.04); font-variant-numeric: tabular-nums;
}
.gn-global__name { font-weight: 600; color: #e8edf6; font-size: 14px; }
.gn-global__last { font-weight: 700; color: #e8edf6; }
.gn-global__chg { font-weight: 700; font-size: 13.5px; text-align: right; min-width: 64px; }
.gn-global__row.is-up   .gn-global__chg { color: #16c784; }
.gn-global__row.is-down .gn-global__chg { color: #f6465d; }
.gn-global__row.is-flat .gn-global__chg { color: #aab6c8; }

/* Gap calculator output bands reuse .gn-tool styles from giftnifty-tools;
   provide fallback colors in case that plugin is inactive. */
.gn-gapcalc .gn-tool__row.is-up   b { color: #15a34a; }
.gn-gapcalc .gn-tool__row.is-down b { color: #dc2626; }

/* ============ Dashboard layout ============ */
.gn-dash { max-width: 1100px; margin: 0 auto; }
.gn-dash__grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items: start; }
.gn-dash__h { font-size: 1.15rem; font-weight: 800; margin: 6px 0 10px; letter-spacing: -.01em; color: #0f172a; }
/* In the dashboard, let cards fill their grid cell instead of the 720px centered cap */
.gn-dash .gn-hero, .gn-dash .gn-tool { max-width: none; margin-left: 0; margin-right: 0; }
.gn-dash__card {
    background: #fff; border: 1px solid #e6eaf0; border-radius: 16px; padding: 14px 16px;
    box-shadow: 0 1px 3px rgba(16,24,40,.06), 0 12px 32px -16px rgba(16,24,40,.22); margin-bottom: 1.5rem;
}
@media (max-width: 820px) {
    .gn-dash__grid2 { grid-template-columns: 1fr; gap: 0; }
}

/* Homepage-injected dashboard wrapper (after header, full-width band) */
.gn-dash-home { padding: 24px 16px 8px; }
.gn-dash-home .gn-dash { max-width: 1100px; }
