/* Mortgage Borrowing Calculator Visual Styling - Matches mortgage-calculator.css basis */

:root {
    --primary-color: #091030;
    --accent-color: #ecc362;
    --light-bg: #f8f9fa;
    --white: #fff;
    --border-color: #dee2e6;
    --text-dark: #333;
    --grey: #dadbde;
}

body {
    font-family: "Inter", "Raleway", "Roboto", Arial, sans-serif;
    background: var(--grey);
}

.hero-section {
    background: linear-gradient(135deg, var(--primary-color) 0%, rgba(9,16,48,0.8) 100%);
    color: var(--white);
    padding: 4rem 0 2rem 0;
}
.hero-section h1 {
    color: var(--white);
    font-weight: 700;
}
.hero-section .lead { color: rgba(255,255,255,0.92); }

.calculator-section {
    background: var(--grey);
    padding: 4rem 0;
}

.form-card {
    background: var(--white);
    border-radius: 15px;
    box-shadow: 0 0.5rem 1rem rgba(9,16,48,0.08);
    padding: 2rem;
}
    .form-card .card-header {
        background-color: var(--grid-color);
        color: var(--white);
        border-radius: 10px;
        margin-bottom: 2rem;
        padding: 1.25rem 1.5rem;
    }

.form-card .card-header h3 { color: var(--white); font-weight: 600; }

.form-label { color: var(--primary-color); font-weight: 600; margin-bottom: .65rem; }

.form-control {
    border: 2px solid var(--border-color);
    border-radius: 8px;
    padding: 0.75rem 1rem;
    background: var(--white);
    font-size: 1rem;
    color: var(--primary-color);
    transition: border-color 0.3s, box-shadow 0.3s;
}
.form-control:focus {
    border-color: var(--accent-color);
    box-shadow: 0 0 0 0.2rem rgba(236,195,98,0.25);
}

.input-group-text {
    /*background: var( background: var(--grid-color);*/
    background-color: var(--grid-color);
    border-color: var(--accent-color);
    color: white;
    font-weight: 600;
}

.results-card {
    background: var(--white);
    border-radius: 15px;
    box-shadow: 0 0.5rem 1rem rgba(9,16,48,0.08);
    overflow: hidden;
    min-height: 50%;
    position: sticky;
    top: 2rem;
}
    .results-card .card-header {
        background-color: var(--grid-color);
        color: var(--white);
        padding: 1.5rem;
    }
.results-card h3 { color: var(--white); margin: 0; font-weight: 600; }
.results-card .card-body { padding: 2rem; }

.results-table .table-header th {
    background: var(--grid-color);
    color: var(--white);
    font-weight: 600;
    text-transform: uppercase;
}

.results-table .amount-highlight {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--accent-color);
}

.summary-section {
    background: linear-gradient(120deg, #faf9f8 75%, #fff 100%);
    border-radius: 10px;
    padding: 1.2rem;
}
.summary-label { color: #6c757d; font-size: 0.87rem; font-weight: 500; text-transform: uppercase; letter-spacing: .4px; }
.summary-value { color: var(--primary-color); font-size: 1.05rem; font-weight: 700; }

.alert-warning {
    background: rgba(236,195,98, 0.12);
    border-left: 4px solid var(--accent-color);
}

@media (max-width:991.98px) {
    .results-card { position: static; margin-top: 2rem; }
    .hero-section { padding: 2rem 0 1.5rem 0; }
    .calculator-section { padding: 2rem 0; }
    .form-card { padding: 1.25rem; }
}

@media (max-width: 768px) {
    h1.display-4 { font-size: 1.75rem !important; }
    .form-card { padding: 1rem; }
    .results-card { margin-top: 1.5rem; }
    .form-label { font-size: 0.9rem; }
    .form-control { font-size: 0.95rem; padding: 0.6rem 0.8rem; }
    .input-group-text { font-size: 0.9rem; }
    .table-row td { padding: 0.75rem 0.5rem; font-size: 0.9rem; }
    .summary-section { padding: 1rem; }
    .summary-label { font-size: 0.75rem; }
    .summary-value { font-size: 0.95rem; }
    .amount-highlight { font-size: 1.1rem; }
    .btn-primary { padding: 0.5rem 1.5rem; font-size: 0.9rem; }
}

@media (max-width: 576px) {
    .hero-section { padding: 1rem 0 0.75rem 0; }
    h1.display-4 { font-size: 1.3rem !important; }
    .calculator-section { padding: 1rem 0; }
    .form-card, .results-card, .results-card .card-body { padding: 0.75rem; }
    .form-card .card-header, .results-card .card-header { padding: 1rem; margin-bottom: 1rem; }
    .form-label { font-size: 0.85rem; margin-bottom: 0.4rem; }
    .form-control { font-size: 1rem; padding: 0.5rem 0.7rem; }
    .input-group-text { font-size: 0.8rem; padding: 0.5rem; }
    .table-responsive { font-size: 0.8rem; }
    .table-row td { padding: 0.5rem 0.3rem; }
    .table-header th { padding: 0.75rem 0.5rem; font-size: 0.75rem; }
    .summary-section { padding: 0.75rem; margin-top: 1rem; }
    .summary-label { font-size: 0.7rem; }
    .summary-value { font-size: 0.9rem; }
    .amount-highlight { font-size: 1rem; }
    .alert-warning { padding: 0.75rem; font-size: 0.8rem; }
    .btn-primary { padding: 0.5rem 1rem; font-size: 0.85rem; width: 100%; margin-top: 1rem; }
}
