/* ==========================================================================
   Compound Interest Calculator — scoped styles
   Extends main.css; uses the same CSS custom properties.
   ========================================================================== */

/* ── Tab navigation ───────────────────────────────────────────────────────── */
.ci-tabs {
    display: flex;
    gap: 0;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--space-6);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.ci-tabs::-webkit-scrollbar { display: none; }

.ci-tab {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-5);
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-2);
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    cursor: pointer;
    white-space: nowrap;
    transition: color var(--transition-fast), border-color var(--transition-fast);
}
.ci-tab:hover { color: var(--color-text-1); }
.ci-tab--active {
    color: var(--color-accent);
    border-bottom-color: var(--color-accent);
}
.ci-tab__icon { font-size: 1rem; }

/* ── Panel ────────────────────────────────────────────────────────────────── */
.ci-panel--hidden { display: none; }

.ci-panel__intro {
    font-size: var(--text-sm);
    color: var(--color-text-2);
    margin-bottom: var(--space-5);
    padding: var(--space-3) var(--space-4);
    background: var(--color-surface-2);
    border-radius: var(--radius-md);
    border-left: 3px solid var(--color-accent);
}

/* ── Form grid ────────────────────────────────────────────────────────────── */
.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 220px), 1fr));
    gap: 0 var(--space-4);
}
.form-group--full { grid-column: 1 / -1; }
.ci-hidden-js { display: none; }

/* ── Radio group ──────────────────────────────────────────────────────────── */
.ci-radio-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
}
.ci-radio {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
}
.ci-radio__input {
    accent-color: var(--color-accent);
    width: 16px;
    height: 16px;
    cursor: pointer;
}
.ci-radio__label {
    font-size: var(--text-sm);
    color: var(--color-text-1);
}

/* ── Compare panel ────────────────────────────────────────────────────────── */
.ci-compare-shared {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 0 var(--space-4);
    padding-bottom: var(--space-5);
    margin-bottom: var(--space-5);
    border-bottom: 1px dashed var(--color-border);
}

.ci-scenarios {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
}

@media (max-width: 600px) {
    .ci-scenarios { grid-template-columns: 1fr; }
}

.ci-scenario-col {
    background: var(--color-surface-2);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
}

.ci-scenario-header {
    margin-bottom: var(--space-4);
}

.ci-scenario-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-weight-bold);
    letter-spacing: 0.05em;
    text-transform: uppercase;
}
.ci-scenario-badge--a { background: rgba(88,166,255,0.2); color: #58a6ff; }
.ci-scenario-badge--b { background: rgba(240,160,48,0.2); color: #f0a030; }
.ci-scenario-badge--c { background: rgba(63,185,80,0.2);  color: #3fb950; }

/* ── Compare results ──────────────────────────────────────────────────────── */
.ci-compare-results {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
    margin-top: var(--space-4);
}

@media (max-width: 600px) {
    .ci-compare-results { grid-template-columns: 1fr; }
}

.ci-compare-card {
    position: relative;
    background: var(--color-surface-2);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    transition: border-color var(--transition-fast);
}

.ci-compare-card--winner {
    border-color: var(--color-accent);
    background: linear-gradient(160deg, var(--color-surface-2) 60%, rgba(240,160,48,0.06));
}

.ci-winner-badge {
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-accent);
    color: var(--color-bg);
    font-size: var(--text-xs);
    font-weight: var(--font-weight-bold);
    padding: 2px var(--space-3);
    border-radius: var(--radius-full);
    white-space: nowrap;
    letter-spacing: 0.04em;
}

.ci-compare-meta {
    font-size: var(--text-xs);
    color: var(--color-text-3);
    margin: var(--space-2) 0 var(--space-3);
}

.ci-compare-final {
    font-size: var(--text-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-1);
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
    margin-bottom: var(--space-2);
    max-width:152px;
}

.ci-compare-detail {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-xs);
    color: var(--color-text-3);
    padding-top: var(--space-2);
    border-top: 1px solid var(--color-border);
}

.ci-compare-diff {
    margin-top: var(--space-2);
    font-size: var(--text-xs);
    color: var(--color-error);
}
