#cfiTool {
    color: #2d2a26;
}

#cfiTool .cfi-lead {
    margin: 10px 0 18px;
    color: #2d2a26;
    line-height: 1.7;
}

#cfiTool .cfi-main-layout {
    display: grid;
    grid-template-columns: 340px minmax(0, 1fr);
    gap: 20px;
    align-items: start;
}

#cfiTool .cfi-input-col {
    position: sticky;
    top: 20px;
    display: grid;
    gap: 14px;
}

#cfiTool .cfi-input-section,
#cfiTool .cfi-chart-section,
#cfiTool .cfi-table-section,
#cfiTool .cfi-result-highlight,
#cfiTool .cfi-support-card {
    background: #fff;
    border: 1px solid #ddd7cb;
    border-radius: 12px;
    box-sizing: border-box;
}

#cfiTool .cfi-input-section {
    padding: 14px;
    display: grid;
    gap: 12px;
}

#cfiTool .cfi-input-title,
#cfiTool .cfi-panel-title {
    font-size: 15px;
    font-weight: 700;
    color: #2d2a26;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin: 0;
}

#cfiTool .cfi-input-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

#cfiTool .cfi-input-group {
    display: grid;
    gap: 6px;
}

#cfiTool .cfi-input-group label {
    font-size: 12px;
    font-weight: 600;
    color: #5f5a56;
}

#cfiTool .cfi-help-text,
#cfiTool .cfi-section-lead,
#cfiTool .cfi-chart-fallback {
    margin: 0;
    font-size: 12px;
    line-height: 1.6;
    color: #6b665f;
}

#cfiTool .cfi-amount-input,
#cfiTool .cfi-number-input,
#cfiTool .cfi-select {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    border: 1px solid #ddd7cb;
    border-radius: 10px;
    background: #fffdf8;
    color: #2d2a26;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

#cfiTool .cfi-amount-input,
#cfiTool .cfi-select {
    padding: 10px 12px;
    font-size: 14px;
}

#cfiTool .cfi-number-input {
    padding: 10px 12px;
    font-size: 14px;
}

#cfiTool .cfi-amount-input {
    text-align: right;
    font-weight: 600;
}

#cfiTool .cfi-number-input:focus,
#cfiTool .cfi-amount-input:focus,
#cfiTool .cfi-select:focus,
#cfiTool .cfi-period-input:focus {
    outline: none;
    border-color: #d4af37;
    background: #fff;
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.2);
}

#cfiTool .cfi-note-box {
    border: 1px dashed #d4af37;
    border-radius: 10px;
    padding: 10px 12px;
    background: #fff8ea;
}

#cfiTool .cfi-note-box strong {
    display: block;
    margin-bottom: 6px;
    font-size: 13px;
}

#cfiTool .cfi-note-box p {
    margin: 0;
    font-size: 12px;
    line-height: 1.6;
    color: #5f5a56;
}

#cfiTool .cfi-flow-table-wrap,
#cfiTool .cfi-table-wrap {
    overflow-x: auto;
    max-width: 100%;
}

#cfiTool .cfi-flow-table,
#cfiTool .cfi-table {
    width: 100%;
    border-collapse: collapse;
}

#cfiTool .cfi-flow-table th,
#cfiTool .cfi-flow-table td,
#cfiTool .cfi-table th,
#cfiTool .cfi-table td {
    border: 1px solid #ebe5d9;
    padding: 8px 10px;
    font-size: 13px;
    color: #2d2a26;
    text-align: left;
    vertical-align: top;
}

#cfiTool .cfi-flow-table th,
#cfiTool .cfi-table th {
    background: #f7f0e2;
    font-weight: 700;
}

#cfiTool .cfi-period-label {
    white-space: nowrap;
    font-weight: 600;
    color: #5f5a56;
}

#cfiTool .cfi-period-input {
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
    border: 1px solid #ddd7cb;
    border-radius: 8px;
    padding: 8px 10px;
    text-align: right;
    font-size: 13px;
    font-weight: 600;
    background: #fff;
}

#cfiTool .cfi-action-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

#cfiTool .cfi-btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 6px;
    border: 1px solid #ddd7cb;
    border-radius: 10px;
    padding: 10px 12px;
    background: #fffdf8;
    color: #2d2a26;
    font-size: 13px;
    cursor: pointer;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

#cfiTool .cfi-btn:hover {
    border-color: #d4af37;
    background: #f7f0e2;
}

#cfiTool .cfi-btn:focus-visible {
    outline: none;
    border-color: #d4af37;
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.2);
}

#cfiTool .cfi-btn-primary {
    background: linear-gradient(135deg, #e5c55d 0%, #d4af37 100%);
    border-color: #caa128;
    font-weight: 700;
}

#cfiTool .cfi-btn-primary:hover {
    background: linear-gradient(135deg, #e0bd4d 0%, #cb9f1d 100%);
}

#cfiTool .cfi-result-col,
#cfiTool .cfi-result-stack {
    min-width: 0;
}

#cfiTool .cfi-result-stack {
    display: grid;
    gap: 12px;
}

#cfiTool .cfi-result-highlight {
    padding: 18px;
    background: linear-gradient(135deg, #fff8ea 0%, #fff 55%, #f8f5ef 100%);
    border-color: #d4af37;
    box-shadow: 0 12px 28px rgba(212, 175, 55, 0.12);
}

#cfiTool .cfi-highlight-overline {
    font-size: 12px;
    font-weight: 700;
    color: #8d6e1e;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

#cfiTool .cfi-highlight-label {
    margin-top: 6px;
    font-size: 14px;
    color: #5f5a56;
}

#cfiTool .cfi-highlight-value {
    margin-top: 4px;
    font-size: 38px;
    line-height: 1.1;
    font-weight: 800;
    color: #2d2a26;
}

#cfiTool .cfi-decision-text {
    margin: 10px 0 0;
    font-size: 14px;
    line-height: 1.65;
    color: #2d2a26;
}

#cfiTool .cfi-rate-chip-row {
    margin-top: 12px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

#cfiTool .cfi-rate-chip {
    border: 1px solid rgba(212, 175, 55, 0.5);
    background: rgba(255, 255, 255, 0.75);
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 12px;
    color: #5f5a56;
}

#cfiTool .cfi-rate-chip strong {
    color: #2d2a26;
    margin-left: 4px;
}

#cfiTool .cfi-support-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
}

#cfiTool .cfi-support-card {
    padding: 12px;
}

#cfiTool .cfi-support-label {
    font-size: 12px;
    color: #5f5a56;
    margin-bottom: 6px;
}

#cfiTool .cfi-support-value {
    font-size: 20px;
    font-weight: 700;
    color: #2d2a26;
    word-break: keep-all;
}

#cfiTool .cfi-chart-section,
#cfiTool .cfi-table-section {
    padding: 14px;
}

#cfiTool .cfi-panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

#cfiTool .cfi-chart-wrap {
    position: relative;
    height: 260px;
}

#cfiTool .cfi-table-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    min-width: 0;
}

#cfiTool .cfi-table-wrap-wide .cfi-table {
    min-width: 760px;
}

#cfiTool .cfi-pass-text {
    color: #287751;
}

#cfiTool .cfi-neutral-text {
    color: #8b5a16;
}

#cfiTool .cfi-fail-text {
    color: #aa3d2b;
}

#cfiTool .cfi-disclaimer {
    margin-top: 12px;
    border: 1px dashed #d4af37;
    border-radius: 10px;
    padding: 10px 12px;
    background: #fff8ea;
    display: flex;
    gap: 8px;
    align-items: flex-start;
    font-size: 13px;
    line-height: 1.6;
}

#cfiTool .cfi-disclaimer p {
    margin: 0;
}

@media (max-width: 1280px) {
    #cfiTool .cfi-support-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1023px) {
    #cfiTool .cfi-main-layout {
        grid-template-columns: 1fr;
    }

    #cfiTool .cfi-input-col {
        position: static;
    }

    #cfiTool .cfi-table-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    #cfiTool .cfi-input-grid,
    #cfiTool .cfi-support-grid {
        grid-template-columns: 1fr 1fr;
    }

    #cfiTool .cfi-highlight-value {
        font-size: 32px;
    }
}

@media (max-width: 560px) {
    #cfiTool .cfi-input-grid,
    #cfiTool .cfi-action-row,
    #cfiTool .cfi-support-grid {
        grid-template-columns: 1fr;
    }

    #cfiTool .cfi-support-value {
        font-size: 18px;
    }
}

