/* =============================================================================
   monthly.css — Análisis Mensual · Mobile-first cards
   ============================================================================= */

.ma-view-menu,
.ma-balance-validation,
.ma-cabecera,
.ma-filters,
.ma-transactions-panel,
.ma-charts-block,
.ma-analytics-block {
    margin-bottom: 1rem;
}

.ma-monthly-flow {
    display: flex;
    flex-direction: column;
}

.ma-balance-validation { order: 1; }
.ma-cabecera { order: 2; }
.ma-analytics-block { order: 3; }
.ma-charts-block { order: 4; }
.ma-filters { order: 5; }
.ma-transactions-panel { order: 6; }

.ma-section-title,
.ma-balance-validation__title {
    margin: 0;
    font-family: var(--lf-font-display);
    font-size: 1.1rem;
    font-style: italic;
    font-weight: 700;
    color: var(--lf-fg);
}

.ma-status-dot {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 999px;
    flex-shrink: 0;
}

.ma-status-dot--ok {
    background: rgba(16,185,129,.2);
    border: 1px solid rgba(16,185,129,.6);
}

.ma-status-dot--error {
    background: rgba(239,68,68,.2);
    border: 1px solid rgba(239,68,68,.6);
}

.ma-status-dot--pending {
    background: rgba(148,163,184,.2);
    border: 1px solid rgba(148,163,184,.6);
}

.ma-balance-validation {
    padding: 1rem;
}

.ma-balance-validation__header,
.ma-filters__header,
.ma-transactions-panel__header,
.ma-analytics-block__header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    margin-bottom: .9rem;
}

.ma-balance-validation__badge,
.ma-transaction-card__status {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    font-size: .74rem;
    font-weight: 700;
    border-radius: var(--lf-radius-pill);
    padding: .28rem .62rem;
    border: 1px solid transparent;
}

.ma-balance-validation__badge.ok,
.ma-transaction-card__status.is-ok {
    color: #10b981;
    border-color: rgba(16,185,129,.45);
    background: rgba(16,185,129,.12);
}

.ma-balance-validation__badge.error {
    color: #f59e0b;
    border-color: rgba(245,158,11,.45);
    background: rgba(245,158,11,.12);
}

.ma-balance-validation__badge.pending,
.ma-transaction-card__status.is-pending {
    color: var(--lf-fg-2);
    border-color: var(--lf-border-dark);
    background: rgba(148,163,184,.12);
}

.ma-balance-validation__stack {
    display: grid;
    gap: .75rem;
}

.ma-balance-item {
    padding: .9rem;
    background: rgba(16,42,67,.42);
    border: 1px solid var(--lf-border-dark);
    border-radius: var(--lf-radius-md);
}

.ma-balance-item__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    margin-bottom: .75rem;
}

.ma-balance-item__title {
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--lf-fg-2);
}

.ma-balance-item__metrics {
    display: grid;
    gap: .65rem;
    margin: 0;
}

.ma-balance-item__metrics div {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
}

.ma-balance-item__metrics dt {
    font-size: .78rem;
    color: var(--lf-fg-3);
}

.ma-balance-item__metrics dd {
    margin: 0;
    font-family: var(--lf-font-mono);
    font-size: .84rem;
    color: var(--lf-fg);
}

.ma-cabecera {
    display: grid;
    gap: 1rem;
}

.ma-titulo {
    font-family: var(--lf-font-display);
    font-size: clamp(1.7rem, 4vw, 2.4rem);
    font-weight: 700;
    font-style: italic;
    color: var(--lf-fg);
}

.ma-selector-card {
    padding: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
}

.ma-selector-mes {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
    background: rgba(10,25,41,.62);
    border: 1px solid var(--lf-border-dark);
    border-radius: var(--lf-radius-md);
    padding: .45rem;
}

.ma-selector-mes__label {
    flex: 1;
    min-width: 0;
    text-align: center;
    font-size: .95rem;
    font-weight: 700;
}

.ma-selector-card__range {
    margin-top: .7rem;
    font-size: .82rem;
    color: var(--lf-fg-3);
}

.ma-filters {
    padding: 1rem;
}

.ma-filters__meta {
    font-size: .8rem;
    color: var(--lf-fg-3);
}

.ma-filter-grid {
    display: grid;
    gap: 1rem;
    margin-bottom: 1rem;
}

.ma-tag-picker {
    position: relative;
}

.ma-tag-picker__chips {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
    padding: .45rem;
    background: rgba(16,42,67,.6);
    border: 1px solid var(--lf-border-dark);
    border-radius: var(--lf-radius-sm);
    align-items: center;
}

.ma-chip {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .28rem .6rem;
    background: #FF8000;
    color: #000;
    border-radius: var(--lf-radius-sm);
    font-size: .78rem;
    font-weight: 600;
}

.ma-chip button {
    border: none;
    background: transparent;
    color: rgba(0,0,0,.85);
    cursor: pointer;
    font-size: .82rem;
    font-weight: 700;
    line-height: 1;
    padding: 0 .1rem;
}

.ma-tag-picker__search {
    position: relative;
    flex: 1;
    min-width: 160px;
}

.ma-tag-picker__search input {
    width: 100%;
    padding: .5rem .6rem;
    border: 1px solid var(--lf-border-dark);
    border-radius: var(--lf-radius-sm);
    background: rgba(16,42,67,.6);
    color: var(--lf-fg);
    font-size: .84rem;
}

.ma-tag-picker__dropdown {
    position: absolute;
    top: calc(100% + .25rem);
    left: 0;
    right: 0;
    background: var(--lf-card-dark);
    border: 1px solid var(--lf-border-dark);
    border-radius: var(--lf-radius-sm);
    max-height: 220px;
    overflow-y: auto;
    z-index: 10;
    box-shadow: var(--lf-shadow-md);
}

.ma-tag-picker__dropdown button {
    width: 100%;
    padding: .65rem .8rem;
    border: none;
    background: transparent;
    color: var(--lf-fg);
    text-align: left;
    cursor: pointer;
    font-size: .84rem;
    border-bottom: 1px solid var(--lf-border-dark);
}

.ma-tag-picker__dropdown button:hover {
    background: rgba(255,128,0,.08);
}

.ma-tag-picker__dropdown button:last-child {
    border-bottom: none;
}

.ma-filter-no-tags {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    margin-top: .45rem;
    color: var(--lf-fg-2);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .03em;
    cursor: pointer;
    user-select: none;
}

.ma-filter-no-tags input {
    width: 14px;
    height: 14px;
    margin: 0;
    accent-color: var(--lf-papaya);
    cursor: pointer;
}

.ma-filter-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-top: .5rem;
    align-items: center;
}

.ma-filter-action-btn {
    border: 1px solid rgba(45,226,230,.45);
    background: rgba(45,226,230,.12);
    color: var(--lf-accent-cyan);
    border-radius: var(--lf-radius-sm);
    padding: .4rem .58rem;
    font-size: .73rem;
    font-weight: 600;
    line-height: 1;
    cursor: pointer;
}

.ma-filter-action-btn:hover {
    background: rgba(45,226,230,.2);
    border-color: rgba(45,226,230,.7);
}

.ma-filter-hint {
    font-size: .75rem;
    color: var(--lf-fg-3);
    margin-left: auto;
}

.ma-filter-toolbar {
    display: grid;
    gap: .85rem;
}

.ma-filtros__grupo {
    display: inline-flex;
    flex-wrap: wrap;
    border: 1px solid var(--lf-border-dark);
    border-radius: var(--lf-radius-md);
    overflow: hidden;
    width: fit-content;
    max-width: 100%;
}

.ma-filtros__toggle {
    background: transparent;
    border: none;
    color: var(--lf-fg-2);
    padding: .55rem .95rem;
    cursor: pointer;
    font-size: .8rem;
    font-weight: 600;
    transition: all var(--lf-transition);
    border-right: 1px solid var(--lf-border-dark);
    font-family: var(--lf-font-ui);
}

.ma-filtros__toggle:last-child {
    border-right: none;
}

.ma-filtros__toggle:hover {
    background: rgba(255,128,0,.08);
    color: var(--lf-papaya);
}

.ma-filtros__toggle.activo {
    background: var(--lf-papaya);
    color: #000;
}

.ma-filter-toolbar__links {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.ma-transactions-panel {
    display: grid;
    gap: .85rem;
}

.ma-transactions-panel__meta {
    font-size: .8rem;
    color: var(--lf-fg-3);
}

.ma-transaction-list {
    display: grid;
    gap: .85rem;
}

.ma-transaction-card {
    display: grid;
    grid-template-columns: 8px minmax(0, 1fr) auto auto;
    align-items: center;
    gap: .55rem;
    min-height: 48px;
    padding: .42rem .55rem;
    background: rgba(16,42,67,.74);
    border: 1px solid rgba(45,226,230,.12);
    border-radius: var(--lf-radius-md);
    box-shadow: none;
}

.ma-transaction-card__status-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #22c55e;
}

.ma-transaction-card__status-dot.is-pending {
    background: #facc15;
}

.ma-transaction-card__heading {
    display: flex;
    align-items: center;
    gap: .4rem;
    min-width: 0;
}

.ma-transaction-card__date {
    font-family: var(--lf-font-mono);
    font-size: .625rem;
    color: var(--lf-fg-3);
    flex: 0 0 auto;
}

.ma-transaction-card__actions {
    display: flex;
    gap: .2rem;
    flex-shrink: 0;
}

.ma-action-btn {
    width: 24px;
    height: 24px;
    padding: 0;
    border-radius: 7px;
    border: 1px solid rgba(255,255,255,.2);
    background: rgba(255,255,255,.05);
    color: rgba(255,255,255,.82);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all var(--lf-transition);
}

.ma-action-btn svg {
    width: 12px;
    height: 12px;
}

.ma-action-btn:hover {
    border-color: rgba(45,226,230,.52);
    background: rgba(45,226,230,.14);
    color: #fff;
}

.ma-action-btn--cyan {
    border-color: rgba(45,226,230,.52);
    background: rgba(45,226,230,.14);
    color: rgba(255,255,255,.92);
}

.ma-action-btn--cyan:hover {
    border-color: rgba(45,226,230,.78);
    background: rgba(45,226,230,.24);
}

.ma-action-btn--quick.is-active {
    border-color: rgba(255,128,0,.72);
    background: rgba(255,128,0,.18);
    color: var(--lf-papaya);
}

.ma-transaction-card__main {
    min-width: 0;
}

.ma-transaction-card__description {
    margin: 0;
    overflow: hidden;
    font-size: .8125rem;
    font-weight: 600;
    line-height: 1.15;
    color: var(--lf-fg);
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ma-transaction-card__meta {
    display: flex;
    align-items: center;
    gap: .38rem;
    min-width: 0;
    margin-top: .25rem;
    font-size: .6875rem;
    color: var(--lf-fg-2);
}

.ma-account-link {
    overflow: hidden;
    color: var(--lf-accent-cyan);
    font-weight: 500;
    text-decoration: none;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ma-account-link:hover,
.ma-tag-link:hover {
    color: var(--lf-papaya);
}

.ma-transaction-card__balance {
    overflow: hidden;
    color: var(--lf-fg-3);
    font-family: var(--lf-font-mono);
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ma-transaction-card__amount {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: .2rem;
    font-family: var(--lf-font-mono);
    font-size: .8125rem;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    line-height: 1;
    white-space: nowrap;
}

.ma-transaction-card__amount.is-income {
    color: var(--lf-success);
}

.ma-transaction-card__amount.is-expense {
    color: var(--lf-danger);
}

.ma-conversion-indicador {
    font-size: .56rem;
    color: #60a5fa;
    cursor: help;
    user-select: none;
}

.ma-tag-link,
.ma-tag-link--muted {
    display: inline-flex;
    align-items: center;
    max-width: 7rem;
    overflow: hidden;
    padding: .125rem .38rem;
    border-radius: var(--lf-radius-sm);
    background: rgba(255,128,0,.08);
    color: #FF8000;
    font-family: var(--lf-font-mono);
    font-size: .625rem;
    line-height: 1.1;
    text-decoration: none;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 0 0 auto;
}

.ma-tag-link--muted {
    background: rgba(15,34,56,.15);
    color: #0F2238;
}

.ma-transfer-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .125rem .38rem;
    border-radius: 999px;
    background: rgba(255,128,0,.08);
    color: #FF8000;
    border: 1px solid rgba(255,128,0,.22);
    font-size: .625rem;
    font-weight: 600;
    white-space: nowrap;
}

.ma-quick-edit {
    grid-column: 1 / -1;
    display: grid;
    gap: .75rem;
    margin-top: .4rem;
    padding: .8rem;
    background: rgba(10,25,41,.58);
    border: 1px solid rgba(45,226,230,.18);
    border-radius: var(--lf-radius-md);
}

.ma-quick-edit__field {
    display: grid;
    gap: .34rem;
}

.ma-quick-edit__field > span {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--lf-fg-3);
}

.ma-quick-edit__field input,
.ma-quick-edit__field select {
    width: 100%;
    min-height: 38px;
    padding: .55rem .65rem;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: var(--lf-radius-sm);
    background: rgba(16,42,67,.76);
    color: var(--lf-fg);
    font-size: .86rem;
}

.ma-quick-tags {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .4rem;
    min-height: 42px;
    padding: .4rem;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: var(--lf-radius-sm);
    background: rgba(16,42,67,.54);
}

.ma-quick-tag {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    max-width: 100%;
    padding: .24rem .48rem;
    border-radius: var(--lf-radius-sm);
    background: rgba(255,128,0,.14);
    color: #FF8000;
    font-family: var(--lf-font-mono);
    font-size: .68rem;
}

.ma-quick-tag button {
    border: none;
    background: transparent;
    color: currentColor;
    font-weight: 700;
    cursor: pointer;
    line-height: 1;
}

.ma-quick-tags__input-wrap {
    position: relative;
    flex: 1;
    min-width: 120px;
}

.ma-quick-tags__input-wrap input {
    min-height: 30px;
    padding: .35rem .45rem;
    border: none;
    background: transparent;
}

.ma-quick-tags__input-wrap input:focus {
    outline: none;
}

.ma-quick-tags__suggestions {
    position: absolute;
    z-index: 20;
    top: calc(100% + .35rem);
    left: 0;
    right: 0;
    max-height: 180px;
    overflow-y: auto;
    border: 1px solid var(--lf-border-dark);
    border-radius: var(--lf-radius-sm);
    background: var(--lf-card-dark);
    box-shadow: var(--lf-shadow-md);
}

.ma-quick-tags__suggestions button {
    width: 100%;
    padding: .58rem .65rem;
    border: none;
    border-bottom: 1px solid rgba(255,255,255,.08);
    background: transparent;
    color: var(--lf-fg);
    text-align: left;
    font-size: .8rem;
    cursor: pointer;
}

.ma-quick-tags__suggestions button:hover {
    background: rgba(255,128,0,.1);
}

.ma-quick-edit__error {
    padding: .5rem .65rem;
    border: 1px solid rgba(255,59,59,.38);
    border-radius: var(--lf-radius-sm);
    background: rgba(255,59,59,.1);
    color: var(--lf-danger);
    font-size: .76rem;
}

.ma-quick-edit__actions {
    display: flex;
    justify-content: flex-start;
    gap: .5rem;
}

.ma-quick-edit__cancel {
    margin-left: auto;
}

.ma-quick-edit__cancel,
.ma-quick-edit__save,
.ma-quick-edit__delete,
.ma-quick-edit__editor {
    min-height: 36px;
    padding: .55rem .78rem;
    border-radius: var(--lf-radius-sm);
    font-family: var(--lf-font-ui);
    font-size: .8rem;
    font-weight: 700;
    cursor: pointer;
}

.ma-quick-edit__cancel {
    border: 1px solid rgba(255,255,255,.14);
    background: transparent;
    color: var(--lf-fg-2);
}

.ma-quick-edit__save {
    border: 1px solid rgba(255,128,0,.7);
    background: var(--lf-papaya);
    color: #000;
}

.ma-quick-edit__cancel:disabled,
.ma-quick-edit__save:disabled,
.ma-quick-edit__delete:disabled,
.ma-quick-edit__editor:disabled {
    opacity: .6;
    cursor: not-allowed;
}

.ma-quick-edit__delete {
    border: 1px solid rgba(255,59,59,.38);
    background: rgba(255,59,59,.08);
    color: var(--lf-danger);
}

.ma-quick-edit__delete:hover {
    border-color: rgba(255,59,59,.65);
    background: rgba(255,59,59,.18);
}

.ma-quick-edit__editor {
    border: 1px solid rgba(255,255,255,.14);
    background: transparent;
    color: var(--lf-fg-2);
}

.ma-quick-edit__editor:hover {
    border-color: rgba(255,255,255,.3);
    color: var(--lf-fg);
}

.ma-analytics-block__header {
    margin-bottom: 1rem;
}

.ma-kpi-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: .85rem;
    margin-bottom: 1rem;
}

.ma-kpi {
    padding: 1rem 1.05rem .95rem;
}

.ma-kpi__label {
    display: block;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--lf-fg-3);
    margin-bottom: .55rem;
}

.ma-kpi__valor {
    font-size: 1.3rem;
}

.ma-kpi__sub {
    margin-top: .45rem;
    font-size: .8rem;
    color: var(--lf-fg-3);
}

.ma-kpi--ingresos .ma-kpi__valor { color: var(--lf-success); }
.ma-kpi--gastos .ma-kpi__valor { color: var(--lf-danger); }
.ma-kpi--balance .ma-kpi__valor { color: var(--lf-papaya); }
.ma-kpi--balance.negativo .ma-kpi__valor { color: var(--lf-danger); }
.ma-kpi--saldo .ma-kpi__valor { color: var(--lf-accent-cyan); }

.ma-graficos-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.ma-grafico {
    background: var(--lf-card-dark);
    border: 1px solid var(--lf-border-dark);
    border-radius: var(--lf-radius-lg);
    padding: 1.1rem;
    min-height: 280px;
    display: flex;
    flex-direction: column;
    box-shadow: none;
}

.ma-grafico__titulo {
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--lf-accent-cyan);
    font-family: var(--lf-font-mono);
    margin-bottom: 1rem;
}

.ma-grafico__canvas-wrap {
    flex: 1;
    position: relative;
    min-height: 220px;
}

.ma-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(10,25,41,.82);
    backdrop-filter: blur(4px);
    z-index: 250;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.ma-modal {
    width: 100%;
    max-width: 760px;
    background: var(--lf-card-dark);
    border: 1px solid var(--lf-border-dark);
    border-radius: var(--lf-radius-lg);
    box-shadow: var(--lf-shadow-lg);
}

.ma-modal__header,
.ma-modal__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--lf-border-dark);
}

.ma-modal__footer {
    border-bottom: none;
    border-top: 1px solid var(--lf-border-dark);
    justify-content: flex-end;
}

.ma-modal__titulo {
    font-family: var(--lf-font-display);
    font-size: 1rem;
    font-weight: 700;
    font-style: italic;
}

.ma-modal__body {
    padding: 1rem 1.25rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: .8rem;
}

.ma-campo {
    display: flex;
    flex-direction: column;
    gap: .3rem;
}

.ma-campo--full {
    grid-column: 1 / -1;
}

.ma-campo label {
    font-size: .72rem;
    color: var(--lf-fg-3);
    text-transform: uppercase;
    letter-spacing: .06em;
}

.ma-campo input,
.ma-campo select {
    width: 100%;
    background: rgba(16,42,67,.6);
    border: 1px solid var(--lf-border-dark);
    color: var(--lf-fg);
    border-radius: var(--lf-radius-md);
    padding: .5rem .65rem;
    font-size: .84rem;
}

.ma-check {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

.ma-estado {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem 1rem;
    color: var(--lf-fg-2);
    gap: .75rem;
    text-align: center;
}

.ma-estado__icono {
    font-size: 1.75rem;
    opacity: .4;
}

.ma-estado__texto {
    font-size: .875rem;
    color: var(--lf-fg-3);
}

.cargando {
    opacity: .55;
    pointer-events: none;
}

.ma-estado--error {
    background: rgba(244,67,54,0.08);
    border-color: var(--lf-danger);
}

.mt-2 {
    margin-top: 0.5rem;
}

.link-action {
    font-size: .75rem;
    color: var(--lf-accent-cyan);
    text-decoration: none;
    padding: .4rem .65rem;
    border: 1px solid var(--lf-accent-cyan);
    border-radius: var(--lf-radius-sm);
}

.link-action:hover {
    background: rgba(45,226,230,0.08);
}

@media (max-width: 640px) {
    .ma-cabecera { order: 1; }
    .ma-analytics-block { order: 2; }
    .ma-transactions-panel { order: 3; }
    .ma-filters { order: 4; }
    .ma-charts-block { order: 5; }
    .ma-balance-validation { order: 6; }

    .ma-kpi--mobile-hidden,
    .ma-kpi--ingresos,
    .ma-grafico--mobile-hidden {
        display: none;
    }

    .ma-view-menu {
        margin-bottom: .5rem;
        overflow-x: auto;
    }

    .ma-cabecera {
        gap: .35rem;
        margin-bottom: .48rem;
    }

    .ma-cabecera > div:first-child {
        display: none;
    }

    .ma-selector-card {
        padding: 0;
    }

    .ma-selector-card .eyebrow,
    .ma-analytics-block__header {
        display: none;
    }

    .ma-selector-mes {
        border-color: rgba(255,255,255,.1);
        border-radius: var(--lf-radius-sm);
        padding: .22rem;
        background: rgba(10,25,41,.36);
    }

    .ma-selector-mes__label {
        font-size: .82rem;
        font-weight: 700;
    }

    .ma-selector-card__range {
        display: none;
    }

    .ma-selector-mes .btn-icon {
        width: 28px;
        height: 28px;
        border-radius: var(--lf-radius-sm);
    }

    .ma-analytics-block,
    .ma-transactions-panel,
    .ma-filters,
    .ma-charts-block {
        margin-bottom: .5rem;
    }

    .ma-kpi-grid {
        grid-template-columns: minmax(0, 1.15fr) minmax(0, .85fr);
        gap: .38rem;
        margin-bottom: 0;
    }

    .ma-kpi {
        padding: .48rem .56rem;
        border-radius: var(--lf-radius-md);
    }

    .ma-kpi__label {
        margin-bottom: .18rem;
        font-size: .58rem;
        letter-spacing: .07em;
    }

    .ma-kpi__valor {
        font-size: .95rem;
        line-height: 1.05;
    }

    .ma-kpi__sub {
        margin-top: .16rem;
        font-size: .62rem;
        line-height: 1.1;
    }

    .ma-kpi--balance .ma-kpi__sub {
        display: none;
    }

    .ma-transactions-panel {
        gap: .38rem;
    }

    .ma-transactions-panel__header {
        margin-bottom: 0;
        gap: .35rem;
    }

    .ma-transactions-panel__header .eyebrow {
        display: none;
    }

    .ma-transactions-panel__meta {
        display: none;
    }

    .ma-transaction-list {
        gap: .35rem;
    }

    .ma-transaction-card {
        grid-template-columns: 8px minmax(0, 1fr) auto 60px;
        gap: .32rem;
        min-height: 46px;
        padding: .28rem .42rem;
    }

    .ma-transaction-card__actions {
        gap: .18rem;
        justify-content: flex-end;
    }

    .ma-action-btn--full {
        display: none;
    }

    .ma-action-btn--quick,
    .ma-action-btn--cyan {
        width: 26px;
        height: 26px;
    }

    .ma-action-btn--quick {
        border-color: rgba(255,128,0,.45);
        background: rgba(255,128,0,.12);
    }

    .ma-action-btn--cyan {
        display: inline-flex;
        border-color: rgba(45,226,230,.45);
        background: rgba(45,226,230,.11);
    }

    .ma-transaction-card__description {
        font-size: .78rem;
    }

    .ma-transaction-card__date {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 1.35rem;
        height: 1.35rem;
        border: 1px solid rgba(255,128,0,.32);
        border-radius: var(--lf-radius-sm);
        background: rgba(255,128,0,.1);
        color: var(--lf-papaya);
        font-size: .72rem;
        font-weight: 800;
        line-height: 1;
    }

    .ma-transaction-card__amount {
        font-size: .76rem;
    }

    .ma-tag-link,
    .ma-tag-link--muted {
        max-width: 5.75rem;
    }

    .ma-transfer-chip {
        padding: .125rem .38rem;
        font-size: .6rem;
    }

    .ma-quick-edit {
        margin-top: .18rem;
        padding: .48rem;
        gap: .5rem;
    }

    .ma-quick-edit__field {
        gap: .22rem;
    }

    .ma-quick-edit__field > span {
        font-size: .62rem;
    }

    .ma-quick-edit__field input,
    .ma-quick-edit__field select {
        min-height: 34px;
        padding: .4rem .5rem;
    }

    .ma-quick-tags {
        min-height: 34px;
        padding: .28rem;
        gap: .28rem;
    }

    .ma-quick-tag {
        padding: .18rem .36rem;
        font-size: .62rem;
    }

    .ma-quick-tags__input-wrap {
        min-width: 96px;
    }

    .ma-quick-tags__input-wrap input {
        min-height: 26px;
        padding: .25rem .3rem;
    }

    .ma-quick-tags__suggestions button {
        padding: .45rem .5rem;
        font-size: .72rem;
    }

    .ma-quick-edit__error {
        padding: .38rem .5rem;
        font-size: .7rem;
    }

    .ma-quick-edit__field input,
    .ma-quick-tags__input-wrap input {
        font-size: 16px;
        line-height: 1.25;
    }

    .ma-quick-edit__actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: .35rem;
    }

    .ma-quick-edit__cancel,
    .ma-quick-edit__save,
    .ma-quick-edit__delete,
    .ma-quick-edit__editor {
        min-height: 32px;
        padding: .45rem .55rem;
        font-size: .74rem;
    }

    .ma-filters {
        padding: .85rem;
    }

    .ma-filters__header {
        margin-bottom: .65rem;
    }

    .ma-filter-grid {
        gap: .75rem;
    }

    .ma-grafico {
        min-height: 240px;
        padding: .85rem;
    }

    .ma-grafico__canvas-wrap {
        min-height: 190px;
    }
}

@media (min-width: 700px) {
    .ma-cabecera {
        grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
        align-items: end;
    }

    .ma-balance-validation__stack,
    .ma-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ma-filter-grid,
    .ma-graficos-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

}

@media (min-width: 1100px) {
    .ma-balance-validation__stack {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .ma-kpi-grid {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .ma-transaction-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ma-modal__body {
        grid-template-columns: 1fr 1fr;
    }
}
