/* ═══════════════════════════════════════════════════════════════════════════
 * LEASE CALCULATOR — lease-calc.css
 * Namespace: .lsc-* / #lsc-* (Lease Calculator)
 * ═══════════════════════════════════════════════════════════════════════════ */

/* ── LOCAL TOKENS ────────────────────────────────────────────────────────── */
#lsc-main,
#lsc-container {
    --lsc-accent:        #0ea5e9;
    --lsc-accent-dark:   #0369a1;
    --lsc-accent-light:  #e0f2fe;
    --lsc-accent-hover:  #bae6fd;
    --lsc-interest:      #fbbf24;
    --lsc-teal:          #14b8a6;
    --lsc-green:         #22c55e;
    --lsc-warning-text:  #b45309;
    --lsc-warning-bg:    #fffbeb;
    --lsc-warning-brd:   #fde68a;
    --lsc-bg:            #ffffff;
    --lsc-bg-soft:       #f8fafc;
    --lsc-bg-muted:      #f1f5f9;
    --lsc-text-primary:  #0f172a;
    --lsc-text-secondary:#475569;
    --lsc-text-muted:    #94a3b8;
    --lsc-border:        #e2e8f0;
    --lsc-border-soft:   #f1f5f9;
    --lsc-shadow-focus:  0 0 0 4px rgba(14,165,233,0.15);
    --lsc-radius:        10px;
    --lsc-radius-sm:     6px;
    --lsc-transition:    150ms ease;
}

/* ── WRAPPER ─────────────────────────────────────────────────────────────── */
#lsc-main.lsc-wrap {
    width: 100%;
    font-family: inherit;
    color: var(--lsc-text-primary);
}

.lsc-widget-heading {
    font-size: 1.18rem;
    font-weight: 700;
    color: var(--lsc-text-primary);
    margin: 0 0 2px;
    line-height: 1.3;
}

.lsc-widget-sub {
    font-size: 0.81rem;
    color: var(--lsc-text-secondary);
    margin: 0 0 14px;
}

/* ── TABS ────────────────────────────────────────────────────────────────── */
.lsc-tabs {
    display: flex;
    gap: 0;
    border: 1.5px solid var(--lsc-border);
    border-radius: var(--lsc-radius-sm);
    overflow: hidden;
    margin-bottom: 16px;
    width: fit-content;
}

.lsc-tab {
    padding: 7px 18px;
    font-size: 0.8rem;
    font-weight: 600;
    background: var(--lsc-bg-soft);
    color: var(--lsc-text-secondary);
    border: none;
    cursor: pointer;
    transition: background var(--lsc-transition), color var(--lsc-transition);
    line-height: 1;
    white-space: nowrap;
}

.lsc-tab:not(:last-child) {
    border-right: 1.5px solid var(--lsc-border);
}

.lsc-tab--active {
    background: var(--lsc-accent);
    color: #fff;
}

.lsc-tab:not(.lsc-tab--active):hover {
    background: var(--lsc-bg-muted);
    color: var(--lsc-text-primary);
}

.lsc-tab:focus-visible {
    outline: 2px solid var(--lsc-accent);
    outline-offset: -2px;
}

/* ── PANELS ──────────────────────────────────────────────────────────────── */
.lsc-panel--hidden {
    display: none;
}

/* ── BODY: TWO-COLUMN ────────────────────────────────────────────────────── */
.lsc-body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    align-items: start;
}

@media (max-width: 920px) {
    .lsc-body { grid-template-columns: 1fr; }
}

/* ── SECTION LABEL ───────────────────────────────────────────────────────── */
.lsc-section-label {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--lsc-text-muted);
    margin: 0 0 8px;
}

/* ── INPUT GRID ──────────────────────────────────────────────────────────── */
.lsc-input-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.lsc-input-grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 600px) {
    .lsc-input-grid       { grid-template-columns: 1fr; }
    .lsc-input-grid--3    { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 380px) {
    .lsc-input-grid--3    { grid-template-columns: 1fr; }
}

/* ── FIELDS ──────────────────────────────────────────────────────────────── */
.lsc-field {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.lsc-label {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.76rem;
    font-weight: 600;
    color: var(--lsc-text-primary);
    flex-wrap: wrap;
}

.lsc-hint {
    font-size: 0.68rem;
    font-weight: 400;
    color: var(--lsc-text-muted);
    background: var(--lsc-bg-muted);
    padding: 1px 5px;
    border-radius: 99px;
    margin-left: auto;
    white-space: nowrap;
}

.lsc-input-wrap {
    display: flex;
    align-items: center;
    border: 1.5px solid var(--lsc-border);
    border-radius: var(--lsc-radius-sm);
    background: var(--lsc-bg);
    overflow: hidden;
    transition: border-color var(--lsc-transition), box-shadow var(--lsc-transition);
}

.lsc-input-wrap:focus-within {
    border-color: var(--lsc-accent);
    box-shadow: var(--lsc-shadow-focus);
}

.lsc-input-wrap--ro {
    background: var(--lsc-bg-soft);
    opacity: 0.8;
}

.lsc-prefix,
.lsc-suffix {
    padding: 0 7px;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--lsc-text-muted);
    background: var(--lsc-bg-soft);
    border-right: 1.5px solid var(--lsc-border-soft);
    line-height: 34px;
    flex-shrink: 0;
    user-select: none;
}

.lsc-suffix {
    border-right: none;
    border-left: 1.5px solid var(--lsc-border-soft);
}

.lsc-input {
    flex: 1;
    border: none;
    outline: none;
    background: transparent;
    padding: 0 7px;
    height: 34px;
    font-size: 0.86rem;
    font-weight: 500;
    color: var(--lsc-text-primary);
    width: 100%;
    min-width: 0;
    -moz-appearance: textfield;
}

.lsc-input::-webkit-outer-spin-button,
.lsc-input::-webkit-inner-spin-button { -webkit-appearance: none; }

.lsc-input[readonly] { cursor: default; color: var(--lsc-text-muted); }

.lsc-desc {
    font-size: 0.67rem;
    color: var(--lsc-text-muted);
    line-height: 1.4;
}

/* ── BUTTONS ─────────────────────────────────────────────────────────────── */
.lsc-actions {
    display: flex;
    gap: 9px;
    flex-wrap: wrap;
    margin-top: 14px;
}

.lsc-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0 18px;
    height: 38px;
    border-radius: var(--lsc-radius-sm);
    font-size: 0.855rem;
    font-weight: 600;
    cursor: pointer;
    border: 1.5px solid transparent;
    transition: background var(--lsc-transition), color var(--lsc-transition), border-color var(--lsc-transition);
    white-space: nowrap;
}

.lsc-btn--primary {
    background: var(--lsc-accent);
    color: #fff;
    border-color: var(--lsc-accent);
}
.lsc-btn--primary:hover { background: var(--lsc-accent-dark); border-color: var(--lsc-accent-dark); }
.lsc-btn--primary:focus-visible { outline: none; box-shadow: var(--lsc-shadow-focus); }

.lsc-btn--ghost {
    background: var(--lsc-bg-soft);
    color: var(--lsc-text-secondary);
    border-color: var(--lsc-border);
}
.lsc-btn--ghost:hover { background: var(--lsc-bg-muted); color: var(--lsc-text-primary); }

/* ── RESULTS PANEL ───────────────────────────────────────────────────────── */
.lsc-results-panel {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* Summary Grid */
.lsc-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 7px;
}

@media (max-width: 1100px) and (min-width: 921px) {
    .lsc-summary-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 500px) {
    .lsc-summary-grid { grid-template-columns: repeat(2, 1fr); }
}

.lsc-card {
    background: var(--lsc-bg-soft);
    border: 1.5px solid var(--lsc-border);
    border-radius: var(--lsc-radius-sm);
    padding: 9px 11px;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.lsc-card--primary {
    background: var(--lsc-accent-light);
    border-color: var(--lsc-accent);
}

.lsc-card-label {
    font-size: 0.67rem;
    font-weight: 500;
    color: var(--lsc-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.lsc-card-val {
    font-size: 0.98rem;
    font-weight: 700;
    color: var(--lsc-text-primary);
    letter-spacing: -0.02em;
    line-height: 1.2;
}

.lsc-card--primary .lsc-card-val { color: var(--lsc-accent-dark); font-size: 1.08rem; }
.lsc-card-val--interest { color: #b45309; }
.lsc-card-val--total    { color: var(--lsc-accent-dark); }

/* ── MILEAGE ALERT ───────────────────────────────────────────────────────── */
.lsc-mileage-alert {
    display: flex;
    align-items: flex-start;
    gap: 7px;
    background: var(--lsc-warning-bg);
    border: 1.5px solid var(--lsc-warning-brd);
    border-radius: var(--lsc-radius-sm);
    padding: 9px 12px;
}
.lsc-mileage-alert svg { flex-shrink: 0; margin-top: 1px; }
.lsc-mileage-alert p {
    margin: 0;
    font-size: 0.78rem;
    color: var(--lsc-warning-text);
    line-height: 1.5;
}

/* ── CHART AREA ──────────────────────────────────────────────────────────── */
.lsc-chart-area {
    display: grid;
    grid-template-columns: 130px 1fr;
    gap: 12px;
    background: var(--lsc-bg-soft);
    border: 1.5px solid var(--lsc-border);
    border-radius: var(--lsc-radius-sm);
    padding: 11px;
    align-items: start;
}

@media (max-width: 480px) {
    .lsc-chart-area { grid-template-columns: 1fr; }
}

.lsc-chart-title {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--lsc-text-secondary);
    margin: 0 0 7px;
}

/* Donut */
.lsc-donut-col {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.lsc-donut-wrap {
    position: relative;
    width: 110px;
    height: 110px;
}

.lsc-donut-wrap canvas {
    width: 110px !important;
    height: 110px !important;
    display: block;
}

.lsc-donut-center {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.lsc-donut-pct {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--lsc-text-primary);
    line-height: 1;
}

.lsc-donut-sub {
    font-size: 0.58rem;
    color: var(--lsc-text-muted);
    margin-top: 2px;
}

.lsc-legend {
    margin-top: 7px;
    display: flex;
    flex-direction: column;
    gap: 3px;
    width: 100%;
}

.lsc-legend-row {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.67rem;
    color: var(--lsc-text-secondary);
}

.lsc-legend-row b { margin-left: auto; font-weight: 600; color: var(--lsc-text-primary); }

.lsc-dot {
    display: inline-block;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    flex-shrink: 0;
}
.lsc-dot--dep { background: #0ea5e9; }
.lsc-dot--fin { background: #fbbf24; }
.lsc-dot--tax { background: #14b8a6; }
.lsc-dot--fee { background: #94a3b8; }

/* Bar chart */
.lsc-bar-col { min-width: 0; display: flex; flex-direction: column; }
.lsc-bar-wrap { position: relative; height: 118px; }
.lsc-bar-wrap canvas { width: 100% !important; height: 118px !important; display: block; }

/* ── COST SUMMARY TABLE ──────────────────────────────────────────────────── */
.lsc-cost-table-wrap {
    border: 1.5px solid var(--lsc-border);
    border-radius: var(--lsc-radius-sm);
    overflow: hidden;
}

.lsc-cost-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.78rem;
}

.lsc-cost-table th {
    background: var(--lsc-bg-muted);
    padding: 7px 10px;
    text-align: left;
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--lsc-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.lsc-cost-table th:not(:first-child) { text-align: right; }

.lsc-cost-table td {
    padding: 6px 10px;
    border-bottom: 1px solid var(--lsc-border-soft);
    color: var(--lsc-text-secondary);
}

.lsc-cost-table td:not(:first-child) { text-align: right; white-space: nowrap; }
.lsc-cost-table tbody tr:last-child td { border-bottom: none; font-weight: 700; color: var(--lsc-text-primary); background: var(--lsc-bg-soft); }
.lsc-cost-table tbody tr:nth-child(even) td:first-child,
.lsc-cost-table tbody tr:nth-child(even) td { background: var(--lsc-bg-soft); }

/* ══ BUY VS LEASE PANEL ══════════════════════════════════════════════════ */
.lsc-bvl-body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    align-items: start;
}

@media (max-width: 920px) {
    .lsc-bvl-body { grid-template-columns: 1fr; }
}

.lsc-bvl-inputs { display: flex; flex-direction: column; }

.lsc-bvl-results {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* BvL cards */
.lsc-bvl-cards {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 10px;
    align-items: center;
}

.lsc-bvl-card {
    background: var(--lsc-bg-soft);
    border: 1.5px solid var(--lsc-border);
    border-radius: var(--lsc-radius-sm);
    padding: 14px 12px 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 3px;
    transition: border-color var(--lsc-transition);
}

.lsc-bvl-card.lsc-winner {
    border-color: var(--lsc-green);
    background: #f0fdf4;
}

.lsc-bvl-icon { font-size: 1.4rem; line-height: 1; margin-bottom: 2px; }

.lsc-bvl-type {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--lsc-text-muted);
    margin: 0;
}

.lsc-bvl-total {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--lsc-text-primary);
    letter-spacing: -0.02em;
    margin: 2px 0;
}

.lsc-bvl-sub {
    font-size: 0.67rem;
    color: var(--lsc-text-muted);
}

.lsc-bvl-breakdown {
    list-style: none;
    margin: 6px 0 0;
    padding: 0;
    width: 100%;
    text-align: left;
}

.lsc-bvl-breakdown li {
    font-size: 0.68rem;
    color: var(--lsc-text-secondary);
    display: flex;
    justify-content: space-between;
    padding: 2px 0;
    border-bottom: 1px solid var(--lsc-border-soft);
}
.lsc-bvl-breakdown li:last-child { border-bottom: none; }

.lsc-bvl-vs {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--lsc-text-muted);
    text-align: center;
}

/* Verdict */
.lsc-bvl-verdict {
    display: flex;
    align-items: flex-start;
    gap: 7px;
    background: var(--lsc-accent-light);
    border: 1.5px solid var(--lsc-accent);
    border-radius: var(--lsc-radius-sm);
    padding: 9px 12px;
}
.lsc-bvl-verdict svg { flex-shrink: 0; margin-top: 1px; }
.lsc-bvl-verdict p { margin: 0; font-size: 0.79rem; color: var(--lsc-accent-dark); line-height: 1.5; font-weight: 500; }

/* BvL chart */
.lsc-bvl-chart-wrap {
    border: 1.5px solid var(--lsc-border);
    border-radius: var(--lsc-radius-sm);
    background: var(--lsc-bg-soft);
    padding: 10px;
}
.lsc-bvl-chart-wrap canvas { display: block; width: 100% !important; }

/* ── RESPONSIVE TWEAKS ───────────────────────────────────────────────────── */
@media (max-width: 480px) {
    .lsc-widget-heading     { font-size: 1.05rem; }
    .lsc-card-val           { font-size: 0.9rem; }
    .lsc-card--primary .lsc-card-val { font-size: 1rem; }
    .lsc-btn                { flex: 1; justify-content: center; }
    .lsc-bvl-cards          { grid-template-columns: 1fr; }
    .lsc-bvl-vs             { display: none; }
    .lsc-tabs               { width: 100%; }
    .lsc-tab                { flex: 1; text-align: center; }
}
