/* ═══════════════════════════════════════════
   nps.css — NPS Calculator specific styles
   Requires: calc-global.css
   ─────────────────────────────────────────
   Contains ONLY styles that do not exist in
   calc-global.css. Follows fd.css patterns.
═══════════════════════════════════════════ */


/* ── NPS-specific CSS variables ── */
:root {
    --nps-blue:        #2563EB;
    --nps-blue-soft:   #DBEAFE;
    --nps-indigo:      #4338CA;
    --nps-indigo-soft: #E0E7FF;
}


/* ═══════════════════════════════════════════
   NPS-ONLY COLOUR UTILITIES
═══════════════════════════════════════════ */

.c-nps  { color: var(--nps-blue); }
.c-nps2 { color: var(--nps-indigo); }

/* Hero stat amber alias (same as FD) */
.hs-value.amber { color: #FDE68A; }


/* ═══════════════════════════════════════════
   RETURN RATE NOTE  (below return rate input)
═══════════════════════════════════════════ */

.nps-return-note {
    margin-top: 6px;
    background: var(--nps-blue-soft);
    border: 1px solid #BFDBFE;
    border-radius: 8px;
    padding: .35rem .7rem;
    font-size: .69rem;
    color: #1E40AF;
    font-weight: 500;
}


/* ═══════════════════════════════════════════
   RETIREMENT READINESS BANNER
   Inside .emi-hero — colour shifts by score.
═══════════════════════════════════════════ */

.nps-readiness-banner {
    margin-top: 10px;
    border-radius: 12px;
    padding: .55rem .85rem;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .78rem;
    font-weight: 600;
    background: rgba(16,185,129,.12);
    border: 1px solid rgba(16,185,129,.22);
}
.nps-readiness-banner i   { color: #6EE7B7; }
.nps-readiness-banner.warn {
    background: rgba(245,158,11,.12);
    border-color: rgba(245,158,11,.22);
}
.nps-readiness-banner.warn i { color: #FDE68A; }
.nps-readiness-banner.danger {
    background: rgba(220,38,38,.12);
    border-color: rgba(220,38,38,.22);
}
.nps-readiness-banner.danger i { color: #FCA5A5; }


/* ═══════════════════════════════════════════
   TAX SAVINGS BOX
   Blue-tinted variant of tds-box.
═══════════════════════════════════════════ */

.nps-tax-box {
    background: var(--nps-blue-soft);
    border: 1.5px solid #BFDBFE;
    border-radius: var(--r-md);
    padding: .85rem 1rem;
    margin-bottom: 1.2rem;
}

.nps-tax-hd {
    font-size: .7rem;
    font-weight: 700;
    color: #1E40AF;
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-bottom: .65rem;
    display: flex;
    align-items: center;
    gap: .4rem;
}
.nps-tax-hd i { color: var(--nps-blue); }

/* Reuse .tds-grid / .tds-item from global fd context */
.nps-tax-box .tds-item {
    background: var(--white);
    border-radius: 10px;
    padding: .55rem .7rem;
    border: 1px solid #BFDBFE;
    text-align: center;
}
.nps-tax-box .tds-lbl { font-size: .65rem; color: #1E40AF; font-weight: 500; margin-bottom: 3px; }
.nps-tax-box .tds-val { font-size: .88rem; font-weight: 800; color: #1D4ED8; }
.nps-tax-box .tds-val.nps-val { color: var(--nps-blue); }
.nps-tax-box .tds-val.green   { color: var(--emerald); }

.nps-tax-note {
    font-size: .69rem;
    color: #1E40AF;
    margin-top: .55rem;
    padding: .35rem .6rem;
    background: rgba(37,99,235,.06);
    border-radius: 8px;
}


/* ═══════════════════════════════════════════
   EMPTY FIELD PROMPT  (same pattern as fd.css)
═══════════════════════════════════════════ */

.field-empty-prompt {
    font-size: .7rem;
    color: var(--danger);
    margin-top: 5px;
    display: none;
    align-items: center;
    gap: 4px;
    background: var(--danger-soft);
    border: 1px solid #FECACA;
    border-radius: 8px;
    padding: .3rem .6rem;
}
.field-empty-prompt.show { display: flex; }


/* ═══════════════════════════════════════════
   TABLE — contribution/invested column colours
═══════════════════════════════════════════ */

td.td-inv  { color: var(--nps-blue);  font-weight: 600; }
td.td-ret  { color: #F59E0B;          font-weight: 600; }
td.td-corp { color: #C4A55A;          font-weight: 700; }
td.td-age  { color: var(--slate);     font-weight: 500; }


/* ═══════════════════════════════════════════
   INSIGHT CARD — BLUE VARIANT
   Global defines amber, green, purple.
   NPS adds blue for tax/investment insights.
═══════════════════════════════════════════ */

.insight-card.blue-nps {
    border-left-color: var(--nps-blue);
}


/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */

@media (max-width: 700px) {
    .nps-tax-box .tds-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
    .nps-tax-box .tds-grid { grid-template-columns: 1fr; }
}