.lc-wrap *, .lc-wrap *::before, .lc-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }
.lc-wrap { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; font-size: 15px; color: #1e293b; max-width: 1000px; margin: 0 auto; background: #fff; border: 1px solid #e2e8f0; border-radius: 16px; overflow: hidden; }
.lc-header { padding: 24px 24px 20px; border-bottom: 1px solid #e2e8f0; background: #f8fafc; }
.lc-title { font-size: 22px; font-weight: 700; color: #1e3a5f; margin-bottom: 4px; }
.lc-subtitle { font-size: 13.5px; color: #64748b; }
.lc-body { display: flex; flex-direction: column; }
@media (min-width: 720px) { .lc-body { flex-direction: row; align-items: flex-start; } .lc-inputs { width: 55%; border-right: 1px solid #e2e8f0; } .lc-results { width: 45%; position: sticky; top: 0; } }
.lc-inputs, .lc-results { padding: 20px; }
.lc-inputs { display: flex; flex-direction: column; gap: 18px; }
.lc-results { display: flex; flex-direction: column; gap: 16px; background: #f8fafc; }
.lc-field { display: flex; flex-direction: column; gap: 8px; }
.lc-label-row { display: flex; justify-content: space-between; align-items: center; gap: 6px; flex-wrap: wrap; }
.lc-label { font-size: 13px; font-weight: 600; color: #334155; }
.lc-val-badge { font-size: 13px; font-weight: 700; color: #185FA5; background: #E6F1FB; padding: 2px 10px; border-radius: 20px; }
.lc-val-hint { font-size: 11.5px; color: #94a3b8; }
.lc-slider { width: 100%; height: 5px; accent-color: #185FA5; }
.lc-input-prefix-wrap, .lc-input-suffix-wrap { display: flex; align-items: center; border: 1.5px solid #cbd5e1; border-radius: 8px; overflow: hidden; background: #f8fafc; }
.lc-input-prefix-wrap:focus-within, .lc-input-suffix-wrap:focus-within { border-color: #185FA5; background: #fff; }
.lc-prefix, .lc-suffix { padding: 0 10px; height: 42px; display: flex; align-items: center; font-size: 14px; font-weight: 600; color: #64748b; background: #f1f5f9; }
.lc-prefix { border-right: 1px solid #e2e8f0; }
.lc-suffix { border-left: 1px solid #e2e8f0; }
.lc-input { flex: 1; border: none; background: transparent; padding: 0 12px; height: 42px; font-size: 14px; color: #1e293b; outline: none; min-width: 0; -moz-appearance: textfield; }
.lc-input::-webkit-outer-spin-button, .lc-input::-webkit-inner-spin-button { -webkit-appearance: none; }
.lc-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.lc-btn-group { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.lc-term-btn { padding: 10px 0; border: 1.5px solid #cbd5e1; border-radius: 8px; font-size: 13.5px; font-weight: 600; cursor: pointer; background: #f8fafc; color: #475569; }
.lc-term-btn.active { background: #185FA5; border-color: #185FA5; color: #fff; }
.lc-divider { display: flex; align-items: center; gap: 10px; color: #94a3b8; font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }
.lc-divider::before, .lc-divider::after { content: ''; flex: 1; height: 1px; background: #e2e8f0; }
.lc-payment-card { background: #185FA5; border-radius: 12px; padding: 22px 20px; text-align: center; color: #fff; }
.lc-payment-label { font-size: 13px; font-weight: 600; opacity: .8; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 6px; }
.lc-payment-amount { font-size: 42px; font-weight: 800; line-height: 1; }
.lc-payment-sub { font-size: 12px; opacity: .75; margin-top: 6px; }
.lc-breakdown, .lc-insight { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px; padding: 16px; }
.lc-breakdown-title, .lc-stat-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: #94a3b8; margin-bottom: 12px; }
.lc-breakdown-row { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.lc-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.lc-bk-label { flex: 1; font-size: 13px; color: #475569; }
.lc-bk-amount { font-size: 13px; font-weight: 600; color: #1e293b; }
.lc-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.lc-stat { background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; padding: 12px 14px; }
.lc-stat-val, .lc-insight { font-size: 14px; line-height: 1.55; color: #1e3a5f; }
.lc-stat-val { font-weight: 700; }
.lc-amort-btn { width: 100%; padding: 12px; border: 1.5px solid #185FA5; border-radius: 10px; background: transparent; color: #185FA5; font-size: 14px; font-weight: 600; cursor: pointer; }
.lc-amort-btn:hover { background: #185FA5; color: #fff; }
.lc-amort-section { border-top: 1px solid #e2e8f0; padding: 20px; }
.lc-amort-header { margin-bottom: 16px; }
.lc-amort-title { font-size: 16px; font-weight: 700; color: #1e3a5f; }
.lc-amort-table-wrap { overflow-x: auto; border-radius: 10px; border: 1px solid #e2e8f0; }
.lc-amort-table { width: 100%; border-collapse: collapse; min-width: 520px; font-size: 13px; }
.lc-amort-table th { background: #1e3a5f; color: #fff; padding: 10px 14px; text-align: right; font-size: 12px; }
.lc-amort-table th:first-child, .lc-amort-table td:first-child { text-align: left; }
.lc-amort-table td { padding: 10px 14px; text-align: right; border-bottom: 1px solid #f1f5f9; }
.lc-amort-table tr:nth-child(even) td { background: #f8fafc; }
@media (max-width: 480px) { .lc-header { padding: 18px 16px 14px; } .lc-inputs, .lc-results { padding: 16px; } .lc-title { font-size: 19px; } .lc-payment-amount { font-size: 34px; } }
