:root {
    --color-blue: #117aff;
}

* {
    box-sizing: border-box;
    font-family: Arial, sans-serif;
}

body {
    margin: 0;
    min-height: 100vh;
    background: url('/_site/assets/images/calculadora-background.png') center center / cover no-repeat;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    color: var(--color-dark);
    position: relative;
    overflow: hidden;

    background: radial-gradient(circle at top left, var(--color-primary-08), var(--color-primary-02) 28%),
        radial-gradient(circle at bottom right, var(--color-primary-08), var(--color-primary-02) 24%),
        linear-gradient(32deg, var(--color-primary-96) 0%, var(--color-primary-88) 100%),
        url(/_site/assets/images/calculadora-background.png) no-repeat center center / cover;
}

@media (max-width: 991px) {
    body {
        background: var(--color-white);

        padding: 0;

        justify-content: flex-start;

        min-height: unset;
    }
}

/* body::before {
    content: '';
    position: fixed;
    inset: 0;
    background: linear-gradient(180deg, var(--color-primary-80) 0%, var(--color-primary-accessible-96) 100%);
    pointer-events: none;
    opacity: .5;
} */

.calculator {
    width: 100%;
    max-width: 520px;
    background: var(--color-white);
    border-radius: 2.5rem;
    padding: 2.25rem;
    box-shadow: 0 20px 60px var(--color-dark-08);
    border: 1px solid var(--color-dark-16);
    position: relative;
    z-index: 1;
}

@media (max-width: 991px) {
    .calculator {
        padding: 2rem 2.5rem;

        border: 0;
        box-shadow: none;
    }
} 

.brand {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;

    margin-bottom: 1rem;
}

body.is-result .brand {
    justify-content: center;
}

.brand svg {
    width: min(150px, 60vw);
    height: auto;
    display: block;
}

.brand-badge {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: 0 1rem;
    border-radius: 999px;
    background: var(--color-primary-16);
    color: var(--color-primary-accessible);
    font-size: .78rem;
    font-weight: 700;
    white-space: nowrap;
    height: 2.25rem;

    padding-top: 1px;
}

.progress {
    height: 10px;
    background: var(--color-dark-08);
    border-radius: 999px;
    overflow: hidden;
    margin-bottom: 16px;

    display: none;
}

.progress-bar {
    height: 100%;
    width: 0%;
    background: var(--color-primary-accessible);
    transition: width .35s ease;
}

.step-progress {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 2.5rem;
    font-size: .82rem;
    color: var(--color-dark-64);
    font-weight: 700;
}

.step-dots {
    display: flex;
    gap: .4rem;
    flex-wrap: wrap;
}

.step-dots span {
    width: .55rem;
    height: .55rem;
    border-radius: 999px;
    background: var(--color-dark-16);
    transition: transform .25s ease, background .25s ease, width .25s ease;
}

.step-dots span.active {
    width: 1.4rem;
    background: var(--color-primary);
}

h1 {
    font-size: 26px;
    margin: 0 0 .25rem;
}

p {
    color: var(--color-dark-64);
    line-height: 1.5;
}

label {
    display: block;
    margin-top: 1.5rem;
    margin-bottom: .5rem;
    font-weight: bold;
}

input {
    width: 100%;
    padding: 15px;
    font-size: 18px;
    border: 1px solid var(--color-dark-16);
    border-radius: 1.25rem;
    color: var(--color-dark);
    background: var(--color-white);
    outline: none;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

input:disabled,
select:disabled {
    background: var(--color-dark-04);
    color: var(--color-dark-48);
    cursor: not-allowed;
}

.input-basic,
.input-money {
    position: relative;
}

.input-basic i,
.input-money i {
    position: absolute;
    left: 1.125rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-primary-accessible);
    font-size: 1.25rem;
    pointer-events: none;
}

.input-basic input,
.input-basic select,
.input-money input {
    padding-left: 3.25rem;
}

select {
    width: 100%;
    padding: 15px;
    font-size: 18px;
    border: 1px solid var(--color-dark-16);
    border-radius: 1.25rem;
    color: var(--color-dark);
    background: var(--color-white);
    outline: none;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
    appearance: none;
}

select:focus {
    border-color: var(--color-primary-accessible);
    box-shadow: 0 0 0 4px var(--color-primary-08);
}

.input-select::after {
    content: '\ea5f';
    font-family: "tabler-icons";
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-dark-64);
    pointer-events: none;
    font-size: 1.1rem;
}

.profile-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1.25rem;
}

.profile-item label {
    margin-top: 0;
    font-size: .95rem;
}

.profile-item-wide {
    grid-column: 1 / -1;
}

.city-search-wrap {
    position: relative;
    z-index: 3;
}

.city-suggestions {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + .25rem);
    display: none;
    gap: 0;
    max-height: 14rem;
    overflow-y: auto;
    padding: .35rem 0;
    border-radius: 1.25rem;
    background: var(--color-white);
    border: 1px solid var(--color-dark-16);
    box-shadow: 0 18px 40px var(--color-dark-16);
    z-index: 20;
}

.city-suggestion {
    width: 100%;
    padding: .8rem 1rem;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--color-dark);
    text-align: left;
    font-size: .95rem;
    font-weight: 500;
    cursor: pointer;
    box-shadow: none;
}

.city-suggestion:hover {
    background: var(--color-primary-08);
    box-shadow: none;
}

.debt-grid {
    display: grid;
    gap: 1rem;
    margin-top: 1.25rem;
}

.debt-item label {
    margin-top: 0;
    font-size: .95rem;
}

.input-helper {
    margin-top: .45rem;
    color: var(--color-dark-64);
    font-size: .86rem;
    line-height: 1.35;
}

.debt-help {
    margin-top: 1rem;
    padding: .85rem 1rem;
    border-radius: 1.25rem;
    background: var(--color-primary-04);
    color: var(--color-dark-64);
    font-size: .9rem;
}

.flow-review {
    display: grid;
    gap: .75rem;
    margin-top: 1.25rem;
    padding: 1.75rem;
    border-radius: 1rem;
    border: 1px solid var(--color-dark-16);
    background: var(--color-dark-04);
}

.flow-review p {
    margin: 0;
}

.flow-amount {
    color: var(--color-primary-accessible);
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
}

.flow-review-positive {
    background: var(--color-primary-04);
    background: transparent;
    /* border-color: var(--color-primary-16); */
}

.flow-review-negative {
    background: var(--color-red-04);
    background: transparent;
    /* border-color: var(--color-red-16); */
}

.flow-review-negative .flow-amount {
    color: var(--color-red);
}

.flow-options {
    display: grid;
    gap: .75rem;
}

.evolution-options {
    margin-top: 1.25rem;
}

.flow-option {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    margin: 0;
    padding: .9rem 1rem;
    border-radius: 1.25rem;
    border: 1px solid var(--color-dark-16);
    background: var(--color-white);
    cursor: pointer;
}

.flow-option:has(input:checked) {
    border-color: var(--color-primary-accessible);
    background: var(--color-primary-04);
    background: transparent;
}

.flow-option:has(input:focus-visible) {
    box-shadow: 0 0 0 4px var(--color-primary-08);
}

.flow-option input {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: 0;
    opacity: 0;
    pointer-events: none;
}

.flow-option span {
    position: relative;
    min-height: 1.5rem;
    padding-left: 2.25rem;
}

.flow-option span::before,
.flow-option span::after {
    position: absolute;
}

.flow-option span::before {
    content: '';
    left: 0;
    top: 0;
    width: 1.35rem;
    height: 1.35rem;
    border-radius: 999px;
    border: 1px solid var(--color-dark-24);
    background: var(--color-white);
}

.flow-option input:checked + span::before {
    border-color: var(--color-primary-accessible);
    background: var(--color-primary-accessible);
}

.flow-option span::after {
    content: '\ea5e';
    left: 0;
    top: 0;
    width: 1.35rem;
    height: 1.35rem;
    color: var(--color-white);
    font-family: "tabler-icons";
    font-size: 1rem;
    font-style: normal;
    font-weight: 400;
    line-height: 1.35rem;
    text-align: center;
    opacity: 0;
}

.flow-option input:checked + span::after {
    opacity: 1;
}

.flow-option strong,
.flow-option small {
    display: block;
}

.flow-option strong {
    color: var(--color-dark);

    margin-top: -2px;
}

.flow-option small {
    margin-top: .2rem;
    color: var(--color-dark-64);
    font-size: .86rem;
    line-height: 1.35;
    font-weight: 500;
}

input:focus {
    border-color: var(--color-primary-accessible);
    box-shadow: 0 0 0 4px var(--color-primary-08);
}

.buttons {
    display: flex;
    gap: 12px;
    margin-top: 1.5rem;
}

button {
    flex: 1;
    padding: 1rem 2rem;
    border: none;
    border-radius: .85rem;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}

.next {
    background: var(--color-primary-accessible);
    color: var(--color-white);
}

.back {
    background: var(--color-dark-08);
    color: var(--color-dark);
}

.partial-result {
    margin-top: 20px;
    padding: 16px;
    border-radius: 1.25rem;
    background: var(--color-dark-04);
    border: 1px solid var(--color-dark-16);
    display: none;
    line-height: 1.5;
}

.form-alert {
    display: none;
    margin-top: 1rem;
    padding: .9rem 1rem;
    border-radius: 1.25rem;
    background: var(--color-red-04);
    border: 1px solid var(--color-red-16);
    color: var(--color-red);
    font-weight: 600;
    line-height: 1.45;
}

.score {
    font-size: 64px;
    font-weight: bold;
    margin: 20px 0 8px;
    color: var(--color-primary-accessible);
}

.status {
    font-size: 22px;
    font-weight: bold;
    margin-bottom: 12px;
}

.summary {
    margin-top: 24px;
    text-align: left;
    background: var(--color-dark-04);
    padding: 18px;
    border-radius: 1.25rem;
    font-size: 15px;
}

.summary div {
    margin-bottom: 10px;
}

.report-card {
    margin-top: .5rem;
    text-align: left;
}

.report-masthead,
.report-meta,
.report-verdict,
.indicator-row,
.analysis-item,
.report-footer {
    display: flex;
}

.report-section {
    margin-top: 2.5rem;
}

.report-section.first {
    display: flex;
    flex-direction: column;
    align-items: center;

    margin-top: 4rem;
}

.report-section.first.report-overview {
    display: grid;
    grid-template-columns: minmax(17rem, .9fr) minmax(0, 1.85fr);
    align-items: stretch;
    gap: 1.5rem;
    margin-top: 3rem;
}

.report-result-card,
.report-health-map {
    border: 1px solid var(--color-dark-16);
    border-radius: 24px;
    background: var(--color-white);
    box-shadow: 0 1rem 2.5rem rgba(15, 23, 42, .06);
}

.report-result-card {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 1.75rem;
    text-align: center;
}

.report-result-card .report-section-label {
    margin-bottom: 1rem;
}

.report-result-card .report-score {
    font-size: 5rem;
}

.report-health-map {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 1.75rem;
}

.health-map-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    margin-bottom: 2.7rem;
}

.health-map-head h3 {
    margin: 0;
    color: var(--color-dark);
    font-size: 1.45rem;
    line-height: 1.15;
}

.health-map-status {
    flex: 0 0 auto;
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.2;
}

.health-map-status-crit {
    color: var(--color-red);
}

.health-map-status-warn {
    color: var(--color-yellow);
}

.health-map-status-good {
    color: var(--color-primary-accessible);
}

.health-map-status-solid {
    color: var(--color-primary-accessible);
}

.report-section-label {
    margin: 0 0 .75rem;
    color: var(--color-dark-64);
    font-size: .85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.report-masthead,
.report-meta,
.report-footer {
    align-items: flex-start;
    justify-content: center;
    text-align: center;
    gap: 1rem;
}

.report-masthead {
    margin-top: 5rem;
}

.report-eyebrow {
    margin: 0 0 .5rem;
    color: var(--color-primary-accessible);
    font-size: .85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.report-masthead h2,
.analysis-copy h3 {
    margin: 0;
}

.report-masthead h2 {
    font-size: 2.5rem;
    line-height: 1.15;
}

.report-register,
.report-meta,
.report-footer {
    color: var(--color-dark-64);
    font-size: .9rem;
}

.report-meta {
    margin-top: 1.25rem;
    padding: 1rem 1.1rem;
    border-radius: 1.25rem;
    background: var(--color-dark-04);
    border: 1px solid var(--color-dark-16);
    flex-wrap: wrap;

    gap: 2rem;

    justify-content: flex-start;
}

.report-meta strong,
.report-register strong {
    color: var(--color-dark);
}

.report-meta-tags {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: .75rem;
    margin-top: 1rem;
}

.report-meta-tag {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    min-height: 2.35rem;
    padding: .55rem .85rem;
    border-radius: 999px;
    border: 1px solid var(--color-dark-16);
    background: var(--color-white);
    color: var(--color-dark);
    line-height: 1.1;
}

.report-meta-tag small {
    color: var(--color-dark-64);
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .08em;
    line-height: 1.5;
    text-transform: uppercase;
}

.report-meta-tag strong {
    font-size: .85rem;
    line-height: 1;
    font-weight: 800;
}

.report-flow-alert {
    display: grid;
    gap: .35rem;
    margin-top: 1.25rem;
    padding: 1rem 1.1rem;
    border-radius: 1.25rem;
    border: 1px solid var(--color-dark-16);
    line-height: 1.45;
}

.report-flow-alert strong {
    color: var(--color-dark);
}

.report-flow-alert span {
    color: var(--color-dark-80);
}

.report-flow-alert-warn {
    background: var(--color-yellow-16);
    border-color: var(--color-yellow-16);
}

.report-flow-alert-crit {
    background: var(--color-red-04);
    border-color: var(--color-red-16);
}

.report-verdict {
    align-items: center;
    justify-content: space-between;
    flex-direction: column;
    gap: 1rem;
}

.report-score {
    display: inline-flex;
    align-items: baseline;
    gap: .35rem;
    font-size: 4rem;
    font-weight: 800;
    line-height: .95;
    color: var(--color-primary-accessible);
}

.report-score sup {
    font-size: 1rem;
    color: var(--color-dark);
}

.report-score-crit {
    color: var(--color-red);
}

.report-score-warn {
    color: var(--color-yellow);
}

.report-score-good {
    color: var(--color-primary-accessible);
}

.report-score-solid {
    color: var(--color-primary-accessible);
}

.report-status {
    display: inline-flex;
    align-items: center;
    padding: 0 1.25rem;
    border-radius: 999px;
    font-size: .95rem;
    font-weight: 600;

    height: 2.5rem;
}

.report-status-crit {
    background: var(--color-red-08);
    color: var(--color-red);
}

.report-status-warn {
    background: var(--color-yellow-16);
    color: var(--color-yellow);
}

.report-status-good {
    background: var(--color-primary-16);
    color: var(--color-primary-accessible);
}

.report-status-solid {
    background: var(--color-primary-accessible-08);
    color: var(--color-primary-accessible);
}

.scale-wrap {
    margin-top: 1.1rem;
    padding: 1.5rem 1.5rem 1rem;
    border-radius: 1.25rem;
    background: var(--color-dark-04);
    border: 1px solid var(--color-dark-16);

    width: 100%;
}

.report-health-map .scale-wrap {
    margin-top: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.scale-top {
    padding: 0 .1rem;
}

.scale-ticks,
.scale-tick-lines {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.scale-ticks {
    margin-bottom: .55rem;

    display: flex;
    justify-content: space-between;
}

.scale-ticks span {
    color: var(--color-dark-64);
    font-size: .85rem;
    font-weight: 700;
    line-height: 1;
}

.scale-ticks span:first-child {
    text-align: left;
}

.scale-ticks span:not(:first-child):not(:last-child),
.scale-tick-lines span:not(:first-child):not(:last-child) {
    text-align: center;
}

.scale-ticks span:last-child {
    text-align: right;
}

.scale-meter {
    position: relative;
    padding-top: 1.8rem;
}

.report-health-map .scale-meter {
    padding-top: 1.45rem;
}

.scale-tick-lines {
    position: absolute;
    inset: 1.25rem 0 auto;
    pointer-events: none;
}

.report-health-map .scale-tick-lines {
    display: none;
}

.scale-tick-lines span {
    position: relative;
    height: .7rem;
}

.scale-tick-lines span::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    width: 2px;
    height: .7rem;
    background: var(--color-dark-32);
    transform: translateX(-50%);
}

.scale-tick-lines span:first-child::before {
    left: 0;
    transform: none;
}

.scale-tick-lines span:last-child::before {
    left: auto;
    right: 0;
    transform: none;
}

.scale-track {
    display: flex;
    width: 100%;
    height: 1.1rem;
    overflow: hidden;
    border-radius: .4rem;
    background: var(--color-dark-08);
}

.scale-zone {
    display: block;
    height: 100%;
}

.scale-zone-crit {
    width: 40%;
    background: var(--color-red);
}

.scale-zone-warn {
    width: 30%;
    background: var(--color-yellow);
}

.scale-zone-good {
    width: 30%;
    background: var(--color-primary-accessible);
}

.scale-labels {
    display: flex;
    margin-top: .45rem;
    color: var(--color-dark-80);
    font-size: .8rem;
    font-weight: 700;
    gap: .5rem;
}

.scale-label {
    text-align: center;
}

.scale-label-crit {
    width: 40%;
}

.scale-label-warn,
.scale-label-good {
    width: 30%;
}

.scale-marker {
    position: absolute;
    top: -0.35rem;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    z-index: 1;
}

.scale-marker-tag {
    min-width: 4.375rem;
    padding: .3rem .75rem;
    border-radius: .4rem;
    background: var(--color-dark);
    color: var(--color-white);
    font-size: .95rem;
    font-weight: 700;
    line-height: 1.1;
    text-align: center;
}

.scale-marker-pointer {
    width: 0;
    height: 0;
    border-left: .4rem solid transparent;
    border-right: .4rem solid transparent;
    border-top: .5rem solid var(--color-dark);
}

.ind-bar-track {
    fill: var(--color-dark-08);
}

.indicator-row {
    align-items: center;
    gap: 1rem;
    padding: 1rem 0;
    border-top: 1px solid var(--color-dark-16);
}

.indicator-row:first-of-type {
    border-top: 0;
    padding-top: 0.25rem;
}

.indicator-main {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    gap: .75rem;
}

.severity-dot {
    width: .8rem;
    height: .8rem;
    border-radius: 999px;
    flex-shrink: 0;
    background: var(--color-red);
}

.severity-dot.warn,
.analysis-bar.warn,
.ind-bar-fill.warn {
    background: var(--color-yellow);
}

.severity-dot.good,
.analysis-bar.good,
.ind-bar-fill.good {
    background: var(--color-primary-accessible);
}

.indicator-copy {
    flex: 1;
    min-width: 0;
}

.indicator-name,
.indicator-value {
    font-weight: 700;
}

.indicator-name {
    margin-bottom: .45rem;
}

.ind-bar-track {
    width: 100%;
    height: .55rem;
    border-radius: 999px;
    overflow: hidden;
    background: var(--color-dark-08);
}

.ind-bar-fill {
    height: 100%;
    border-radius: inherit;
    background: var(--color-red);
}

.indicator-reference {
    position: relative;
    display: grid;
    gap: .35rem;
    margin-top: .7rem;
    padding-top: 1.35rem;
}

.indicator-reference-marker {
    position: absolute;
    top: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    transform: translateX(-50%);
    z-index: 1;
}

.indicator-reference-marker span {
    max-width: 8rem;
    padding: .22rem .5rem;
    border-radius: .4rem;
    background: var(--color-dark);
    color: var(--color-white);
    font-size: .72rem;
    font-weight: 800;
    line-height: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.indicator-reference-marker b {
    width: 0;
    height: 0;
    border-left: .28rem solid transparent;
    border-right: .28rem solid transparent;
    border-top: .36rem solid var(--color-dark);
}

.indicator-reference-line {
    height: .18rem;
    border-radius: 999px;
    background: var(--color-dark-08);
}

.indicator-reference-ticks {
    position: relative;
    min-height: 1rem;
}

.indicator-reference-ticks span {
    position: absolute;
    top: 0;
    color: var(--color-dark-64);
    font-size: .72rem;
    font-weight: 800;
    line-height: 1;
    transform: translateX(-50%);
    white-space: nowrap;
}

.indicator-reference-ticks span:first-child {
    transform: translateX(0);
}

.indicator-reference-ticks span:last-child {
    transform: translateX(-100%);
}

.indicator-reference p {
    margin: .1rem 0 0;
    color: var(--color-dark-64);
    font-size: .72rem;
    font-weight: 600;
    line-height: 1.25;
}

.indicator-value {
    white-space: nowrap;
}

.indicator-value {
    display: grid;
    gap: .15rem;
    font-size: 1.05rem;
    text-align: right;

    align-self: end;
    line-height: 1;
}

.indicator-value small {
    color: var(--color-dark-64);
    font-size: .72rem;
    font-weight: 600;
}

.executive-summary,
.data-check,
.money-map,
.patrimony-map,
.pillar-card,
.priority-box,
.reflection-panel {
    border-radius: 1.25rem;
    border: 1px solid var(--color-dark-16);
    background: var(--color-dark-04);
}

.executive-summary,
.data-check,
.priority-box {
    padding: 1rem;
}

.executive-summary-head p,
.data-check p,
.priority-box p {
    margin: 0;
}

.executive-summary {
    display: grid;
    gap: 1rem;
    background: var(--color-white);

    border: 0;
    padding: 0;
}

.executive-summary-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.executive-summary-head p {
    color: var(--color-dark-64);
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.4;
}

.executive-status {
    display: inline-flex;
    align-items: center;
    flex: 0 0 auto;
    min-height: 2.25rem;
    padding: 0 .9rem;
    border-radius: 999px;
    font-size: .85rem;
    font-weight: 700;
    white-space: nowrap;
}

.executive-points {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.executive-card {
    display: flex;
    flex-direction: column;
    gap: .75rem;
    padding: 1.5rem;
    border-radius: 1.25rem;
    background: var(--color-white);
    border: 1px solid var(--color-dark-16);
}

.executive-card-head {
    display: flex;
    align-items: center;
    gap: .8rem;
}

.executive-card-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: .75rem;
    background: var(--color-red-08);
    color: var(--color-red);
    font-size: 1.25rem;
    line-height: 1;
    flex: 0 0 auto;
}

.executive-card-prioridade .executive-card-icon {
    background: var(--color-yellow-16);
    color: var(--color-yellow);
}

.executive-card-acao .executive-card-icon {
    background: var(--color-primary-16);
    color: var(--color-primary-accessible);
}

.executive-card-label {
    color: var(--color-dark-64);
    font-size: .85rem;
    font-weight: 900;
    text-transform: uppercase;
}

.executive-card strong {
    color: var(--color-dark);
    font-size: 1.25rem;
    line-height: 1.15;
}

.executive-card p {
    margin: 0;
    color: var(--color-dark-64);
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.45;
}

.data-check {
    display: flex;
    align-items: flex-start;
    gap: .85rem;
}

.data-check-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.6rem;
    height: 2.6rem;
    border-radius: 999px;
    background: var(--color-red-08);
    color: var(--color-red);
    font-size: 1.45rem;
    line-height: 1;
    flex: 0 0 auto;
}

.data-check-copy {
    display: grid;
    gap: .35rem;
    min-width: 0;
}

.data-check-good {
    background: var(--color-primary-04);
    border-color: var(--color-primary-16);
}

.data-check-good .data-check-icon {
    background: var(--color-primary-16);
    color: var(--color-primary-accessible);
}

.data-check-warn {
    background: var(--color-yellow-16);
    border-color: var(--color-yellow-16);
}

.data-check-warn .data-check-icon {
    background: var(--color-white-48);
    color: var(--color-yellow);
}

.data-check-crit {
    background: var(--color-red-04);
    border-color: var(--color-red-16);
}

.money-map {
    display: grid;
    gap: 1.35rem;
    padding: 1.75rem;
    border-top: 1px solid var(--color-dark-16);
    background: transparent;
}

.money-map-summary {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.5rem;
}

.money-map-summary h3 {
    margin: 0;
    color: var(--color-dark);
    font-size: 1.65rem;
    line-height: 1.1;
}

.money-map-summary p {
    margin: .5rem 0 0;
    color: var(--color-dark-64);
    font-size: 1rem;
    font-weight: 800;
}

.money-map-balance {
    display: grid;
    gap: .2rem;
    text-align: right;
}

.money-map-balance strong {
    color: var(--color-primary-accessible);
    font-size: 2.5rem;
    line-height: .95;
}

.money-map-deficit .money-map-balance strong {
    color: var(--color-red);
}

.money-map-balance span {
    color: var(--color-dark-64);
    font-size: .95rem;
    font-weight: 800;
}

.money-map-cards {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.money-map-stat {
    display: grid;
    gap: .5rem;
    padding: 1.05rem 1.15rem;
    border: 1px solid var(--color-dark-16);
    border-radius: 1rem;
}

.money-map-stat span {
    color: var(--color-dark-64);
    font-size: .82rem;
    font-weight: 900;
    letter-spacing: .09em;
    text-transform: uppercase;
}

.money-map-stat strong {
    color: var(--color-dark);
    font-size: 1.55rem;
    line-height: 1;
}

.money-map-stat-renda strong {
    color: var(--color-primary-accessible);
}

.money-map-stat-dividas strong {
    color: var(--color-red);
}

.money-map-stat-guardado strong {
    color: var(--color-blue);
}

.money-map-bars {
    display: grid;
    gap: .85rem;
}

.money-map-bar-row {
    display: grid;
    grid-template-columns: minmax(5rem, .1fr) minmax(0, 1fr) minmax(8rem, auto);
    align-items: center;
    gap: 1rem;
}

.money-map-bar-row strong {
    color: var(--color-dark);
    font-size: 1rem;
}

.money-map-bar-row small {
    color: var(--color-dark);
    font-size: 1rem;
    font-weight: 800;
    text-align: right;
    white-space: nowrap;
}

.money-map-bar-track {
    height: .9rem;
    overflow: hidden;
    border-radius: 999px;
    background: var(--color-dark-08);
}

.money-map-bar-track span {
    display: block;
    height: 100%;
    min-width: .35rem;
    border-radius: inherit;
    background: var(--color-yellow);
}

.money-map-bar-row-dividas .money-map-bar-track span {
    background: var(--color-red);
}

.money-map-bar-row-guardado .money-map-bar-track span {
    background: var(--color-blue);
}

.money-map-callout {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    padding: 1rem;
    border-radius: 1rem;
    background: var(--color-yellow-16);
    color: var(--color-dark);
    font-size: 1.05rem;
    font-weight: 800;
    line-height: 1.45;
}

.money-map-callout-icon {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 1.45rem;
    border-radius: 999px;
    background: var(--color-white-48);
    color: inherit;
    font-size: 1.25rem;
}

.money-map-callout-copy {
    flex: 1 1 auto;
    min-width: 0;
}

.money-map-deficit .money-map-callout {
    background: var(--color-red-04);
    color: var(--color-red);
    border: 1px solid var(--color-red-16);
}

.money-map-fechado .money-map-callout {
    background: var(--color-primary-08);
    color: var(--color-primary-accessible);
}

.patrimony-map {
    display: grid;
    gap: 1rem;
    padding: 0;
    background: var(--color-white);
    border: 0;
}

.patrimony-equation-block {
    display: grid;
    gap: 1rem;
    padding: 1.75rem;
    border-radius: 1.25rem;
    border: 1px solid var(--color-dark-16);
    background: var(--color-white);
}

.patrimony-map-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.5rem;
}

.patrimony-map-head h3 {
    margin: 0;
    color: var(--color-dark);
    font-size: 1.5rem;
    line-height: 1.15;
}

.patrimony-map-head p {
    margin: .5rem 0 0;
    color: var(--color-dark-64);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.4;
}

.patrimony-evolution {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0 .9rem;
    border-radius: 999px;
    background: var(--color-yellow-16);
    color: var(--color-yellow);
    font-size: .85rem;
    font-weight: 800;
}

.patrimony-evolution-good {
    background: var(--color-primary-16);
    color: var(--color-primary-accessible);
}

.patrimony-evolution-crit {
    background: var(--color-red-08);
    color: var(--color-red);
}

.patrimony-equation {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: stretch;
    gap: .75rem;
}

.patrimony-equation > b {
    align-self: center;
    color: var(--color-dark-48);
    font-size: 1.6rem;
    line-height: 1;
}

.patrimony-equation-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    column-gap: 1rem;
    padding: 1rem;
    border-radius: 1rem;
    border: 1px solid var(--color-dark-16);
    background: transparent;
}

.patrimony-equation-item span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    grid-row: span 2;
    width: 3rem;
    height: 3rem;
    border-radius: .9rem;
    font-size: 1.5rem;
    line-height: 1;
}

.patrimony-column-head span,
.patrimony-row-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: .7rem;
    font-size: 1.25rem;
    line-height: 1;
}

.patrimony-equation-item small {
    color: var(--color-dark-64);
    font-size: .75rem;
    font-weight: 900;
    line-height: 1.1;
    text-transform: uppercase;
}

.patrimony-equation-item strong {
    color: var(--color-dark);
    font-size: 1.5rem;
    line-height: 1;
}

.patrimony-equation-assets span,
.patrimony-column-assets .patrimony-column-head span,
.patrimony-column-assets .patrimony-row-icon {
    background: var(--color-primary-16);
    color: var(--color-primary-accessible);
}

.patrimony-equation-debts span,
.patrimony-column-debts .patrimony-column-head span,
.patrimony-column-debts .patrimony-row-icon {
    background: var(--color-red-08);
    color: var(--color-red);
}

.patrimony-equation-assets strong {
    color: var(--color-primary-accessible);
}

.patrimony-equation-debts strong {
    color: var(--color-red);
}

.patrimony-equation-net span,
.patrimony-column-net .patrimony-column-head span {
    background: var(--color-blue-08);
    color: var(--color-blue);
}

.patrimony-map-positive .patrimony-equation-net strong,
.patrimony-map-positive .patrimony-net-value {
    color: var(--color-primary-accessible);
}

.patrimony-map-negative .patrimony-equation-net strong,
.patrimony-map-negative .patrimony-net-value {
    color: var(--color-red);
}

.patrimony-columns {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.patrimony-column {
    display: grid;
    align-content: start;
    gap: 1rem;
    padding: 1.25rem;
    border-radius: 1.25rem;
    border: 1px solid var(--color-dark-16);
    background: transparent;
}

.patrimony-column-head {
    display: flex;
    align-items: center;
    gap: .75rem;

    padding-bottom: .5rem;
}

.patrimony-column-head strong {
    color: var(--color-dark);
    font-size: 1rem;
}

.patrimony-row {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
}

.patrimony-row-copy {
    flex: 1;
    display: grid;
    gap: .25rem;
    min-width: 0;
}

.patrimony-row-copy > div:first-child {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: .75rem;
}

.patrimony-row-copy strong {
    color: var(--color-dark);
    font-size: .92rem;
    line-height: 1.25;
}

.patrimony-row-copy small {
    color: var(--color-dark-64);
    font-size: .85rem;
    font-weight: 800;
    white-space: nowrap;
}

.patrimony-row-track {
    height: .55rem;
    overflow: hidden;
    border-radius: 999px;
    background: var(--color-dark-08);
}

.patrimony-row-track span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: var(--color-primary-accessible);
}

.patrimony-column-debts .patrimony-row-track span {
    background: var(--color-red);
}

.patrimony-net-value {
    color: var(--color-blue);
    font-size: 2rem;
    font-weight: 900;
    line-height: 1;
}

.patrimony-column-net p {
    margin: 0;
    color: var(--color-dark-64);
    font-size: .85rem;
    font-weight: 500;
    line-height: 1.45;
}

.patrimony-column-net > small {
    color: var(--color-dark-48);
    font-size: .82rem;
    font-weight: 800;
}

.pillar-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
}

.pillar-card {
    position: relative;
    overflow: hidden;
    padding: 1.4rem;
    background: var(--color-white);
}

.pillar-card::before {
    content: '';
    position: absolute;
    inset: 0 auto 0 0;
    width: .42rem;
    background: var(--color-red);
}

@media (max-width: 991px) {
    .pillar-card::before {
        display: none;
    }
}

.pillar-card-warn::before {
    background: var(--color-yellow);
}

.pillar-card-good::before {
    background: var(--color-primary-accessible);
}

.pillar-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.pillar-card-title {
    min-width: 0;
}

.pillar-status {
    display: inline-flex;
    align-items: center;
    min-height: 1.5rem;
    padding: 0 .75rem;
    background: var(--color-red-08);
    color: var(--color-red);
    font-size: .75rem;
    font-weight: 700;

    border-radius: 2rem;
}

.pillar-card-warn .pillar-status {
    background: var(--color-yellow-16);
    color: var(--color-yellow);
}

.pillar-card-good .pillar-status {
    background: var(--color-primary-16);
    color: var(--color-primary-accessible);
}

.pillar-card h3 {
    margin: .5rem 0 0;
    color: var(--color-dark);
    font-size: 1.25rem;
    line-height: 1.15;
}

.pillar-card-value {
    flex: 0 0 auto;
    display: grid;
    gap: .15rem;
    text-align: right;
}

.pillar-card-value strong {
    color: var(--color-dark);
    font-size: 2rem;
    line-height: 1;
}

.pillar-card-value span {
    color: var(--color-dark-64);
    font-size: .9rem;
    font-weight: 700;
}

.pillar-card-value small {
    color: var(--color-dark-48);
    font-size: .78rem;
    font-weight: 800;
}

.pillar-meter {
    position: relative;
    height: .7rem;
    margin-top: 1.6rem;
    border-radius: 999px;
    background: var(--color-dark-08);
}

.pillar-meter-fill {
    position: relative;
    display: block;
    height: 100%;
    min-width: .7rem;
    border-radius: inherit;
    background: var(--color-red);
}

.pillar-meter-fill::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 0;
    width: .85rem;
    height: .85rem;
    border-radius: 999px;
    background: inherit;
    transform: translate(50%, -50%);
}

.pillar-card-warn .pillar-meter-fill {
    background: var(--color-yellow);
}

.pillar-card-good .pillar-meter-fill {
    background: var(--color-primary-accessible);
}

.pillar-scale {
    display: flex;
    justify-content: space-between;
    gap: .5rem;
    margin-top: .55rem;
    color: var(--color-dark-48);
    font-size: .8rem;
    font-weight: 700;
}

.pillar-scale span:nth-child(2),
.pillar-scale span:nth-child(3) {
    text-align: center;
}

.pillar-scale span:last-child {
    text-align: right;
}

.pillar-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .8rem;
    margin-top: 1.35rem;
}

.pillar-info-box,
.pillar-next-action {
    border-radius: 1rem;
    border: 1px solid var(--color-dark-16);
    background: var(--color-dark-04);
}

.pillar-info-box {
    padding: .9rem;
}

.pillar-info-box strong,
.pillar-next-action span {
    color: var(--color-dark);
    font-size: .9rem;
    font-weight: 800;
}

.pillar-info-box strong {
    display: block;

    margin-top: -2px;
}

.pillar-info-box p {
    margin: .25rem 0 0;
    color: var(--color-dark-64);
    font-size: .94rem;
    line-height: 1.45;
}

.pillar-next-action {
    margin-top: .8rem;
    padding: .95rem 1rem;
    background: var(--color-primary-08);
    border-color: var(--color-primary-16);
}

.pillar-next-action span {
    display: block;
    color: var(--color-primary-accessible);

    margin-top: -2px;
}

.pillar-next-action strong {
    display: block;
    margin-top: .25rem;
    color: var(--color-dark);
    font-size: .98rem;
    line-height: 1.4;
}

.priority-box {
    display: flex;
    align-items: flex-start;
    gap: .85rem;
    border-color: var(--color-primary-16);
    background: var(--color-primary-04);
}

.priority-box-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.6rem;
    height: 2.6rem;
    border-radius: 999px;
    background: var(--color-primary-16);
    color: var(--color-primary-accessible);
    font-size: 1.45rem;
    line-height: 1;
    flex: 0 0 auto;
}

.priority-box-copy {
    display: grid;
    gap: .35rem;
    min-width: 0;
}

.reflection-panel {
    display: grid;
    gap: 1.25rem;
    padding: 1.75rem;

    background: transparent;

    padding: 0;
    border: 0;
}

.reflection-head {
    display: grid;
    gap: .5rem;
}

.reflection-head h3 {
    margin: 0;
    color: var(--color-dark);
    font-size: 1.55rem;
    line-height: 1.15;
}

.reflection-head p {
    margin: 0;
    color: var(--color-dark-64);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.4;
}

.reflection-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.reflection-card {
    display: grid;
    gap: .85rem;
    padding: 1.25rem;
    border-radius: 1.25rem;
    border: 1px solid var(--color-dark-16);
    background: var(--color-white);
}

.reflection-card-head {
    display: flex;
    align-items: center;
    gap: .8rem;
}

.reflection-card-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: .75rem;
    background: var(--color-blue-08);
    color: var(--color-blue);
    font-size: 1.25rem;
    line-height: 1;
    flex: 0 0 auto;
}

.reflection-card-warn .reflection-card-icon {
    background: var(--color-yellow-16);
    color: var(--color-yellow);
}

.reflection-card-good .reflection-card-icon {
    background: var(--color-primary-16);
    color: var(--color-primary-accessible);
}

.reflection-card-label {
    color: var(--color-dark-64);
    font-size: .86rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.reflection-card strong {
    color: var(--color-dark);
    font-size: 1.25rem;
    line-height: 1.25;
}

.reflection-card p {
    margin: 0;
    color: var(--color-dark-64);
    font-size: .98rem;
    font-weight: 700;
    line-height: 1.45;
}

.reflection-callout {
    padding: 1rem 1.2rem;
    border-radius: 1.25rem;
    border: 1px solid var(--color-primary-16);
    background: var(--color-primary-08);
    color: var(--color-primary-accessible);
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.45;
}

.analysis-list {
    display: grid;
    gap: .9rem;
}

.analysis-item,
.report-conclusion {
    gap: .85rem;
    padding: 1rem 1.1rem;
    border-radius: 1.25rem;
    background: var(--color-dark-04);
    border: 1px solid var(--color-dark-16);
}

.analysis-bar,
.report-conclusion-bar {
    width: .35rem;
    border-radius: 999px;
    flex-shrink: 0;
    background: var(--color-red);
}

.analysis-copy p,
.report-conclusion p {
    margin-bottom: 0;
}

.action-plan {
    overflow: hidden;
    border-radius: 1.25rem;
    border: 1px solid var(--color-dark-16);
    background: transparent;
}

.action-plan-head {
    display: flex;
    align-items: center;
    gap: .9rem;
    padding: 1rem 1.1rem;
    background: var(--color-primary-accessible);
    color: var(--color-white);
}

.action-plan-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 1.25rem;
    background: var(--color-white-16);
    flex: 0 0 auto;
    font-size: 1.45rem;
}

.action-plan-head h3,
.action-plan-head p {
    margin: 0;
}

.action-plan-head h3 {
    font-size: 1.1rem;
}

.action-plan-head p {
    margin-top: .2rem;
    color: var(--color-white-80);
    font-size: .92rem;
    line-height: 1.35;
}

.action-plan-list {
    display: grid;
    gap: .75rem;
    margin: 0;
    padding: 1rem;
    list-style: none;
}

.action-plan-list li {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: flex-start;
    gap: .75rem;
    padding: .9rem 1rem;
    border-radius: 1rem;
    background: var(--color-white);
    border: 1px solid var(--color-dark-16);
    color: var(--color-dark);
    font-weight: 700;
    line-height: 1.45;
}

.action-step-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.8rem;
    height: 1.8rem;
    border-radius: 999px;
    background: var(--color-primary-16);
    color: var(--color-primary-accessible);
    font-size: 1.05rem;
    flex: 0 0 auto;
}

.action-step-copy {
    display: grid;
    gap: .2rem;
}

.action-step-copy strong {
    color: var(--color-primary-accessible);
    font-size: .78rem;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.action-step-copy span {
    color: var(--color-dark);
}

.report-conclusion {
    display: flex;
    align-items: stretch;
}

.report-email-invite {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    grid-template-areas:
        "icon copy"
        "icon form";
    align-items: start;
    gap: 1rem;
    margin-top: 2.5rem;
    padding: 1.25rem;
    border: 1px solid var(--color-dark-16);
    border-radius: 1.25rem;
}

.report-email-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.25rem;
    height: 3.25rem;
    border-radius: 5rem;
    background: var(--color-primary-16);
    color: var(--color-primary-accessible);
    font-size: 1.55rem;
    grid-area: icon;
}

.report-email-copy {
    grid-area: copy;
}

.report-email-copy .report-section-label {
    margin-bottom: .125rem;
    
    font-size: .75rem;
}

.report-email-copy h3 {
    margin: 0;
    color: var(--color-dark);
    font-size: 1.2rem;
    line-height: 1.2;
}

.report-email-copy p:not(.report-section-label) {
    margin: .35rem 0 0;
    color: var(--color-dark-72);
    line-height: 1.45;
}

.report-email-form {
    display: grid;
    gap: .5rem;
    grid-area: form;
    max-width: 44rem;
}

.report-email-field {
    display: grid;
    grid-template-columns: minmax(10rem, .85fr) minmax(12rem, 1fr) auto;
    gap: .6rem;

    width: 100%;
}

.report-email-input {
    min-height: 3rem;
    padding: 0 1rem;
    border-radius: .85rem;
    font-size: .95rem;
}

.report-email-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .45rem;
    min-height: 3rem;
    padding: 0 1.2rem;
    border-radius: .85rem;
    background: var(--color-primary-accessible);
    color: var(--color-white);
    border: 0;
    cursor: pointer;
    font-size: .95rem;
    font-weight: 800;
    text-decoration: none;
    white-space: nowrap;
    transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}

.report-email-button:disabled {
    cursor: wait;
    opacity: .72;
    transform: none;
}

.report-email-button:not(:disabled):hover {
    transform: translateY(-1px);
    box-shadow: 0 .75rem 1.5rem var(--color-primary-16);
}

.report-email-button i {
    font-size: 1.1rem;
}

.report-turnstile {
    min-height: 4.0625rem;
}

.report-email-feedback {
    margin: 0;
    color: var(--color-dark-72);
    font-size: .85rem;
    font-weight: 800;
    line-height: 1.35;
}

.report-email-feedback.is-success {
    color: var(--color-primary-accessible);
}

.report-email-feedback.is-error {
    color: var(--color-red);
}

.report-app-download {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 1.25rem;
    margin-top: 1.5rem;
    padding: 1.5rem;
    border: 1px solid var(--color-primary-16);
    border-radius: 1.25rem;
    background: var(--color-primary-04);
}

.report-app-download-copy {
    display: grid;
    gap: .35rem;
}

.report-app-download-copy .report-section-label {
    margin-bottom: 0;
    font-size: .75rem;
}

.report-app-download-copy h3 {
    margin: 0;
    color: var(--color-dark);
    font-size: 1.55rem;
    line-height: 1.15;
}

.report-app-download-copy h3 span {
    color: var(--color-primary-accessible);
}

.report-app-download-copy p:not(.report-section-label) {
    max-width: 31rem;
    margin: 0;
    color: var(--color-dark-72);
    font-size: 1rem;
    line-height: 1.45;
}

.report-app-download__buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .75rem;
}

.report-app-badge {
    display: inline-flex;
    align-items: center;
    overflow: hidden;
    border-radius: .85rem;
    text-decoration: none;
    transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}

.report-app-badge:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 24px var(--color-dark-16);
}

.report-app-badge:active {
    transform: translateY(0);
    opacity: .95;
}

.report-app-badge img {
    display: block;
    width: 8.5rem;
    height: auto;
}

.report-footer {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-dark-16);
    gap: 1.25rem;

    justify-content: space-between;
    text-align: left;
}

.report-issued-at {
    white-space: nowrap;
}

.report-actions {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 3rem;
}

.report-reset-button,
.report-edit-button {
    flex: 0 1 auto;
    min-width: 14rem;
}

.report-reset-button {
    background: var(--color-primary-accessible);
    color: var(--color-white);
}

.report-edit-button {
    background: var(--color-dark-08);
    color: var(--color-dark);
}

body.is-result {
    padding: 0;
    background: var(--color-white);

    .calculator {
        max-width: 70rem;

        border: 1px solid transparent;

        box-shadow: none;
    }

    .progress {
        display: none;
    }

    .step-progress {
        display: none;
    }

    .brand-badge {
        display: none;
    }
}

body.is-result::before {
    content: none;
}

@media (max-width: 640px) {
    .calculator {
        padding: 24px 20px;
    }

    .profile-grid {
        grid-template-columns: 1fr;
    }

    .profile-item-wide {
        grid-column: auto;
    }

    .report-masthead,
    .report-meta,
    .report-verdict,
    .indicator-row,
    .report-footer {
        flex-direction: column;
    }

    .report-section.first.report-overview {
        grid-template-columns: 1fr;
        margin-top: 2.25rem;
    }

    .report-result-card,
    .report-health-map {
        min-height: auto;
        padding: 1.75rem;
        border-radius: 1.25rem;
    }

    .report-result-card .report-score {
        font-size: 4rem;
    }

    .health-map-head {
        flex-direction: column;
        gap: .5rem;
        margin-bottom: 1.8rem;
    }

    .health-map-head h3 {
        font-size: 1.35rem;
    }

    .indicator-row {
        align-items: flex-start;
    }

    .indicator-value {
        text-align: left;
    }

    .executive-summary-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .executive-points {
        grid-template-columns: 1fr;
    }

    .money-map-summary {
        flex-direction: column;
    }

    .money-map-balance {
        text-align: left;
    }

    .money-map-cards {
        grid-template-columns: 1fr;
    }

    .money-map-bar-row {
        grid-template-columns: 1fr;
        gap: .45rem;
    }

    .money-map-bar-row small {
        text-align: left;
        white-space: normal;
    }

    .patrimony-map-head {
        flex-direction: column;
    }

    .patrimony-equation-block {
        padding: 1.2rem;
    }

    .patrimony-equation,
    .patrimony-columns {
        grid-template-columns: 1fr;
    }

    .patrimony-equation > b {
        justify-self: center;
    }

    .patrimony-row-copy > div:first-child {
        align-items: flex-start;
        flex-direction: column;
        gap: .2rem;
    }

    .pillar-grid {
        grid-template-columns: 1fr;
    }

    .pillar-card {
        padding: 1.2rem;
    }

    .pillar-card-top {
        align-items: flex-start;
        flex-direction: column;
    }

    .pillar-card-value {
        text-align: left;
    }

    .pillar-info-grid {
        grid-template-columns: 1fr;
    }

    .reflection-grid {
        grid-template-columns: 1fr;
    }

    .report-email-invite {
        grid-template-columns: 1fr;
        grid-template-areas:
            "icon"
            "copy"
            "form";
        align-items: flex-start;
    }

    .report-email-form,
    .report-email-field {
        width: 100%;
    }

    .report-email-field {
        grid-template-columns: 1fr;
    }

    .report-email-button {
        width: 100%;
    }

    .report-app-download {
        grid-template-columns: 1fr;
        align-items: flex-start;
    }

    .report-app-download__buttons {
        justify-content: flex-start;
    }

    .report-score {
        font-size: 2.6rem;
    }
}
