/**
 * Smart Savings Calculator — style.css
 * vault-child/include/smart-savings-calculator/style.css
 *
 * Brand: primary #0B74B9 · secondary #00243C · accent #F27226
 *        headline #000 · body #565656 · light #F5F9FB · border #E3ECF3
 */

/* ── Reset ─────────────────────────────────────────────────────────────────── */
.ssc-wrap *, .ssc-wrap *::before, .ssc-wrap *::after {
    box-sizing: border-box; margin: 0; padding: 0;
}

/* ── Shell ─────────────────────────────────────────────────────────────────── */
.ssc-wrap {
    font-family: 'Inter', sans-serif;
    background: #fff;
    border: 1px solid #E3ECF3;
    border-radius: 16px;
    overflow: hidden;
    max-width: 860px;
    margin: 0 auto;
}

/* ── Header ────────────────────────────────────────────────────────────────── */
.ssc-header {
    padding: 28px 32px 22px;
    border-bottom: 1px solid #E3ECF3;
}
.ssc-eyebrow {
    font-size: 11px; font-weight: 700;
    letter-spacing: .12em; text-transform: uppercase;
    color: #F27226; margin-bottom: 6px;
}
.ssc-title  { font-size: 22px; font-weight: 700; color: #000; line-height: 1.25; margin: 0 0 4px; }
.ssc-subtitle { font-size: 13px; color: #565656; }

/* ── Form ──────────────────────────────────────────────────────────────────── */
.ssc-form-area { padding: 24px 32px; border-bottom: 1px solid #E3ECF3; }

.ssc-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.ssc-field { display: flex; flex-direction: column; gap: 7px; }
.ssc-field--full { grid-column: 1 / -1; }

.ssc-label {
    font-size: 11px; font-weight: 600;
    text-transform: uppercase; letter-spacing: .08em; color: #565656;
    display: flex; align-items: center; gap: 4px;
}
.ssc-label-hint { font-weight: 400; text-transform: none; letter-spacing: 0; color: #aaa; font-size: 10px; }

/* Controls */
.ssc-ctrl {
    width: 100%; padding: 10px 14px;
    border: 1.5px solid #E3ECF3; border-radius: 8px;
    font-size: 13px; font-family: 'Inter', sans-serif;
    color: #000; background: #fff;
    transition: border-color .18s, box-shadow .18s;
    -webkit-appearance: none; appearance: none;
}
.ssc-ctrl:focus {
    outline: none; border-color: #0B74B9;
    box-shadow: 0 0 0 3px rgba(11,116,185,.12);
}

/* Rs. prefix input */
.ssc-prefix-wrap { position: relative; }
.ssc-prefix {
    position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
    font-size: 12px; font-weight: 600; color: #565656; pointer-events: none;
}
.ssc-prefix-wrap .ssc-ctrl { padding-left: 42px; }

/* Years suffix input */
.ssc-suffix-wrap { position: relative; }
.ssc-suffix {
    position: absolute; right: 14px; top: 50%; transform: translateY(-50%);
    font-size: 12px; font-weight: 600; color: #565656; pointer-events: none;
}
.ssc-suffix-wrap .ssc-ctrl { padding-right: 52px; }

/* Button */
.ssc-btn {
    width: 100%; margin-top: 18px;
    background: #F27226; color: #fff;
    border: none; border-radius: 8px; padding: 13px;
    font-size: 14px; font-family: 'Inter', sans-serif; font-weight: 700;
    cursor: pointer; letter-spacing: .02em;
    transition: background .18s, transform .1s;
}
.ssc-btn:hover    { background: #d9621b; }
.ssc-btn:active   { transform: scale(.99); }
.ssc-btn:disabled { opacity: .6; cursor: not-allowed; }

/* Error */
.ssc-error {
    background: #FEF2F2; border: 1px solid #FECACA;
    border-radius: 8px; padding: 10px 14px;
    font-size: 12px; color: #DC2626;
    margin-top: 12px; display: none;
}

/* ── Results ───────────────────────────────────────────────────────────────── */
.ssc-results     { display: none; }
.ssc-results--on { display: block; }

/* KPI row */
.ssc-kpi-row {
    display: grid; grid-template-columns: repeat(3,1fr);
    gap: 1px; background: #E3ECF3;
    border-top: 1px solid #E3ECF3; border-bottom: 1px solid #E3ECF3;
}
.ssc-kpi { background: #fff; padding: 20px 24px; }
.ssc-kpi--main { background: #F5F9FB; }
.ssc-kpi-label {
    font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .09em;
    color: #565656; margin-bottom: 8px;
}
.ssc-kpi-val { font-size: 24px; font-weight: 700; color: #000; line-height: 1; }
.ssc-kpi-sub { font-size: 10px; color: #aaa; margin-top: 5px; }

/* Colour utilities */
.ssc-blue   { color: #0B74B9; }
.ssc-orange { color: #F27226; }
.ssc-neutral { color: #000; }

/* ── Body: chart + details side by side ────────────────────────────────────── */
.ssc-body {
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: 0;
    border-bottom: 1px solid #E3ECF3;
}

.ssc-chart-col {
    padding: 24px 20px 20px;
    border-right: 1px solid #E3ECF3;
    display: flex; flex-direction: column; align-items: center; gap: 14px;
}
#ssc-chart { width: 100%; min-height: 240px; }

.ssc-chart-legend {
    display: flex; gap: 16px; align-items: center;
    font-size: 11px; color: #565656;
}
.ssc-legend-dot {
    display: inline-block; width: 10px; height: 10px;
    border-radius: 50%; margin-right: 4px;
}
.ssc-legend-blue   { background: #0B74B9; }
.ssc-legend-orange { background: #F27226; }

/* Detail column */
.ssc-detail-col { padding: 0 32px; }

.ssc-detail-rows { padding: 4px 0; }
.ssc-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 12px 0; border-bottom: 1px solid #F5F9FB;
}
.ssc-row:last-child { border-bottom: none; }
.ssc-row--total .ssc-rl { font-weight: 600; color: #000; }
.ssc-rl { font-size: 12px; color: #565656; }
.ssc-rr { font-size: 13px; font-weight: 700; color: #0B74B9; }

/* Disclaimer */
.ssc-disclaimer {
    background: #F5F9FB; padding: 14px 32px;
    font-size: 10px; color: #aaa; line-height: 1.65;
    border-top: 1px solid #E3ECF3;
}

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
    .ssc-header,
    .ssc-form-area,
    .ssc-detail-col,
    .ssc-chart-col,
    .ssc-disclaimer { padding-left: 18px; padding-right: 18px; }

    .ssc-form-grid { grid-template-columns: 1fr; }
    .ssc-field--full { grid-column: 1; }

    .ssc-kpi-row { grid-template-columns: 1fr; }
    .ssc-kpi-val { font-size: 20px; }
    .ssc-title   { font-size: 18px; }

    .ssc-body { grid-template-columns: 1fr; }
    .ssc-chart-col { border-right: none; border-bottom: 1px solid #E3ECF3; }
}
