/* =======================================================================
   Solar Installation Cost Calculator – App-specific styles
   Global element spacing comes from /css/40-typography.css.
   Component spacing comes from /css/30-components.css.
   All colours are declared as variables in /css/10-variables.css.
   This file covers only patterns unique to this app.
   ======================================================================= */


/* ===================================================================== */
/*  CONTAINER                                                             */
/* ===================================================================== */

.solar-calc-container {
    padding-top:    var(--space-lg);
    padding-bottom: var(--space-lg);
}


/* ===================================================================== */
/*  FORM GROUP INSIDE CARD — last child has no bottom margin              */
/* ===================================================================== */

.solar-form-group--last {
    margin-bottom: 0;
}


/* ===================================================================== */
/*  RADIO CARD STACK                                                      */
/* ===================================================================== */

.solar-radio-stack {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}


/* ===================================================================== */
/*  BATTERY SIZE SELECTOR                                                 */
/* ===================================================================== */

.solar-battery-selector {
    display: none;
    margin-top: var(--space-md);
    padding: var(--space-md);
    background: var(--kw-blue-tint);
    border-radius: var(--radius-md);
}

.solar-battery-selector.visible { display: block; }


/* ===================================================================== */
/*  RESULTS CARD  (cost breakdown)                                        */
/* ===================================================================== */

.solar-breakdown { margin-bottom: var(--space-sm); }

.solar-breakdown-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 0;
    font-size: 0.9rem;
    color: var(--grey);
}

.solar-breakdown-item span:last-child {
    color: var(--near-black);
    font-weight: 500;
}

.solar-result-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px solid var(--grey-border);
}

.solar-result-row:last-child { border-bottom: none; }

.solar-result-label {
    font-size: 0.95rem;
    color: var(--grey);
    display: flex;
    align-items: center;
    gap: 6px;
}

.solar-result-value {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--near-black);
}

.solar-result-highlight {
    margin-top: var(--space-sm);
    padding-top: var(--space-md);
    border-top: 2px solid var(--kw-green);
    border-bottom: none;
    background: var(--kw-green-tint);
    border-radius: var(--radius-md);
    padding: var(--space-sm) var(--space-md);
    margin-left: calc(-1 * var(--space-md));
    margin-right: calc(-1 * var(--space-md));
}

.solar-result-highlight .solar-result-label {
    color: var(--kw-green-darkened);
    font-weight: 600;
    font-size: 1.05rem;
}

.solar-result-final {
    font-size: 1.5rem;
    color: var(--kw-green);
}


/* ===================================================================== */
/*  CTA SECTION (inside results card)                                     */
/* ===================================================================== */

.solar-cta-section {
    text-align: center;
    margin-top: var(--space-lg);
    padding-top: var(--space-lg);
    border-top: 1px solid var(--grey-border);
}

.solar-cta-subtitle {
    margin: 12px 0 0 0;
    font-size: 0.9rem;
    color: var(--grey);
}


/* ===================================================================== */
/*  DISCLAIMER                                                            */
/* ===================================================================== */

.solar-disclaimer {
    margin: var(--space-lg) 0 0 0;
    padding-top: var(--space-md);
    border-top: 1px solid var(--grey-border);
    font-size: 0.8rem;
    color: var(--grey);
    text-align: center;
}


/* ===================================================================== */
/*  INFORMATION / PROSE SECTION                                           */
/* ===================================================================== */

.solar-info-section {
    margin-top: var(--space-xl);
}


/* ===================================================================== */
/*  RESPONSIVE                                                            */
/* ===================================================================== */

@media (max-width: 600px) {
    .solar-result-row        { flex-wrap: wrap; gap: var(--space-xs); padding: 10px 0; }
    .solar-result-label      { font-size: 0.9rem; flex: 1 1 100%; }
    .solar-result-value      { font-size: 1rem; flex: 1 1 100%; text-align: right; }
    .solar-result-highlight .solar-result-label { font-size: 1rem; }
    .solar-result-final      { font-size: 1.3rem; }
    .solar-breakdown-item    { font-size: 0.85rem; flex-wrap: wrap; gap: 2px; }
    .solar-breakdown-item span:first-child  { flex: 1 1 100%; }
    .solar-breakdown-item span:last-child   { text-align: right; flex: 1 1 100%; }
    .kw-option--row          { padding: 12px; }
    .kw-option__title        { flex-wrap: wrap; align-items: center; gap: 6px; }
    .solar-cta-section .kw-btn { width: 100%; }
    .solar-cta-subtitle      { font-size: 0.85rem; }
    .solar-result-highlight  { margin-left: calc(-1 * var(--card-padding-sm)); margin-right: calc(-1 * var(--card-padding-sm)); }
}

@media (max-width: 360px) {
    .kw-option--row  { padding: 10px; gap: var(--space-sm); }
    .kw-option__title { font-size: 0.9rem; }
    .kw-option__desc  { font-size: 0.8rem; }
}
