:root {
  --bg: #070b16;
  --bg2: #0b1120;
  --panel: #0f1729;
  --panel2: #131d33;
  --panel-dark: #0a1020;
  --txt: #eaf0fb;
  --muted: #8a96b0;
  --accent: #2f80ff;
  --accent2: #1e6bff;
  --green: #22c55e;
  --red: #f4566c;
  --amber: #f5c451;
  --border: #1c2740;
  --radius: 18px;
}
* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { margin: 0; padding: 0; width: 100%; max-width: 100%; overflow-x: hidden; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  background: var(--bg);
  color: var(--txt); font-size: 15px; min-height: 100vh;
}
main, .layout, .mainwrap, .view, .grid, .col-main, .col-side, .panel { min-width: 0; max-width: 100%; }
input, select, button { min-width: 0; }
input[type="date"], input[type="month"] {
  display: flex; align-items: center; width: 100%; min-width: 0; max-width: 100%;
  -webkit-min-logical-width: 0;
  -webkit-appearance: none; appearance: none;
  box-sizing: border-box; line-height: 1.2;
}
/* En iPhone los campos de fecha se deformaban; esto los normaliza. */
input[type="date"]::-webkit-date-and-time-value,
input[type="month"]::-webkit-date-and-time-value { text-align: left; margin: 0; }
h1, h2, h3 { margin: 0; }
canvas { max-width: 100%; }
.chart-wrap { position: relative; height: 240px; width: 100%; }
.ui-icon {
  --icon: url("icons/wallet.svg");
  display: inline-block;
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
  background: currentColor;
  -webkit-mask: var(--icon) center / contain no-repeat;
  mask: var(--icon) center / contain no-repeat;
}
.icon-add-circle { --icon: url("icons/add-circle.svg"); }
.icon-bank { --icon: url("icons/bank.svg"); }
.icon-calendar { --icon: url("icons/calendar.svg"); }
.icon-cash { --icon: url("icons/cash.svg"); }
.icon-credit-card { --icon: url("icons/credit-card.svg"); }
.icon-expense { --icon: url("icons/expense.svg"); }
.icon-edit { --icon: url("icons/edit.svg"); }
.icon-home { --icon: url("icons/home.svg"); }
.icon-income { --icon: url("icons/income.svg"); }
.icon-more-grid { --icon: url("icons/more-grid.svg"); }
.icon-pie-chart { --icon: url("icons/pie-chart.svg"); }
.icon-receipt-clock { --icon: url("icons/receipt-clock.svg"); }
.icon-search { --icon: url("icons/search.svg"); }
.icon-settings { --icon: url("icons/settings.svg"); }
.icon-target { --icon: url("icons/target.svg"); }
.icon-transactions { --icon: url("icons/transactions.svg"); }
.icon-trash { --icon: url("icons/trash.svg"); }
.icon-user { --icon: url("icons/user.svg"); }
.icon-wallet { --icon: url("icons/wallet.svg"); }

/* ===== Portada pública ===== */
body.landing-active { background: #070b16; }
body.landing-active .bottomnav { display: none; }
body.auth-open { overflow: hidden; }
.landing-page {
  --landing-width: 1120px;
  min-height: 100vh; background: #070b16; color: var(--txt); overflow: hidden;
}
.landing-header {
  position: fixed; z-index: 30; top: 12px; left: 50%; transform: translateX(-50%);
  width: min(calc(100% - 40px), var(--landing-width)); height: 64px;
  display: flex; align-items: center; justify-content: space-between; gap: 26px;
  box-sizing: border-box; padding: 0 16px;
  background: rgba(7, 12, 25, .92);
  border: 1px solid rgba(137, 157, 198, .18);
  border-radius: 12px;
  box-shadow: 0 12px 36px rgba(0, 0, 0, .34);
  -webkit-backdrop-filter: blur(18px) saturate(125%);
  backdrop-filter: blur(18px) saturate(125%);
}
.landing-brand { display: inline-flex; align-items: center; color: #fff; text-decoration: none; }
.landing-brand .landing-brand-logo { display: block; width: 132px; height: auto; }
.landing-nav { display: flex; align-items: center; gap: 30px; margin-left: auto; }
.landing-nav a {
  color: #aab4c8; text-decoration: none; font-size: 13px; font-weight: 650;
}
.landing-nav a:hover { color: #fff; }
.landing-header-actions { display: flex; align-items: center; gap: 10px; }
.landing-header button, .landing-hero button {
  font-family: inherit; cursor: pointer;
}
.landing-login {
  background: transparent; border: 0; color: #c9d2e2; padding: 10px 12px;
  font-size: 13px; font-weight: 700;
}
.landing-primary, .landing-secondary {
  min-height: 46px; padding: 0 20px; border-radius: 8px; font-size: 14px; font-weight: 800;
}
.landing-primary {
  border: 1px solid var(--accent); background: var(--accent); color: #fff;
  box-shadow: 0 12px 30px rgba(47,128,255,.22);
}
.landing-primary.compact { min-height: 40px; padding-inline: 16px; font-size: 13px; }
.landing-secondary {
  border: 1px solid rgba(234,240,251,.24); background: rgba(7,11,22,.62); color: #fff;
  backdrop-filter: blur(8px);
}
.landing-primary:hover { background: var(--accent2); }
.landing-secondary:hover { border-color: rgba(234,240,251,.5); }
.landing-hero {
  position: relative; min-height: min(880px, 92vh); display: flex; align-items: center;
  padding: 108px max(24px, calc((100% - var(--landing-width)) / 2)) 80px;
  border-bottom: 1px solid var(--border);
}
.landing-hero-image {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center top;
}
.landing-hero-shade {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(7,11,22,.98) 0%, rgba(7,11,22,.9) 38%, rgba(7,11,22,.48) 70%, rgba(7,11,22,.62) 100%),
    linear-gradient(180deg, rgba(7,11,22,.28), rgba(7,11,22,.08) 65%, #070b16 100%);
}
.landing-hero-content { position: relative; z-index: 2; width: min(620px, 60%); }
.landing-hero h1 {
  max-width: 620px; margin: 0; font-size: 62px; line-height: 1.02; font-weight: 850; letter-spacing: 0;
}
.landing-hero h1 span { color: #6aa2ff; }
.landing-hero-content > p {
  max-width: 570px; margin: 24px 0 0; color: #b9c3d6; font-size: 19px; line-height: 1.55;
}
.landing-hero-actions { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.landing-hero-proof {
  display: flex; align-items: center; gap: 9px; margin-top: 22px;
  color: #8e9ab1; font-size: 12px; line-height: 1.45;
}
.landing-hero-proof .ui-icon { width: 17px; height: 17px; color: var(--accent); }
.landing-section {
  width: min(calc(100% - 40px), var(--landing-width)); margin: 0 auto; padding: 104px 0;
  scroll-margin-top: 92px;
}
.landing-section-copy { max-width: 720px; }
.landing-section h2 {
  margin: 0; font-size: 40px; line-height: 1.1; font-weight: 820; letter-spacing: 0;
}
.landing-section-copy > p, .landing-product-copy > p, .landing-trace-copy > p {
  margin: 16px 0 0; color: var(--muted); font-size: 17px; line-height: 1.6;
}
.landing-problem {
  display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: 72px; align-items: start;
}
.landing-problem-list { display: flex; flex-direction: column; border-top: 1px solid var(--border); }
.landing-problem-list > div {
  display: grid; grid-template-columns: minmax(180px, .8fr) minmax(0, 1.2fr);
  gap: 24px; padding: 21px 0; border-bottom: 1px solid var(--border);
}
.landing-problem-list b { font-size: 14px; }
.landing-problem-list span { color: var(--muted); font-size: 13px; line-height: 1.5; }
.landing-product {
  display: grid; grid-template-columns: minmax(290px, .72fr) minmax(0, 1.28fr);
  gap: 64px; align-items: center;
}
.landing-check-list { list-style: none; margin: 28px 0 0; padding: 0; }
.landing-check-list li {
  position: relative; padding: 12px 0 12px 27px; border-bottom: 1px solid var(--border);
  color: #cbd4e4; font-size: 14px;
}
.landing-check-list li::before {
  content: ''; position: absolute; left: 2px; top: 18px; width: 8px; height: 8px;
  border-radius: 50%; background: var(--accent);
}
.landing-product-visual { margin: 0; min-width: 0; }
.landing-product-visual img, .landing-trace-visual img {
  display: block; width: 100%; height: auto; border: 1px solid #273450;
  border-radius: 8px; box-shadow: 0 28px 70px rgba(0,0,0,.38);
}
.landing-product-visual figcaption {
  margin-top: 12px; color: #758198; font-size: 11px; text-align: right;
}
.landing-features { border-top: 1px solid var(--border); }
.landing-feature-list {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 54px; margin-top: 48px; border-top: 1px solid var(--border);
}
.landing-feature-list article {
  display: grid; grid-template-columns: 42px minmax(0, 1fr); gap: 17px;
  padding: 28px 0; border-bottom: 1px solid var(--border);
}
.landing-feature-icon {
  width: 42px; height: 42px; display: grid; place-items: center;
  color: var(--accent); background: rgba(47,128,255,.1); border: 1px solid rgba(47,128,255,.2);
  border-radius: 8px;
}
.landing-feature-icon .ui-icon { width: 21px; height: 21px; }
.landing-feature-list h3, .landing-step-list h3 {
  margin: 0; font-size: 16px; line-height: 1.35;
}
.landing-feature-list p, .landing-step-list p {
  margin: 7px 0 0; color: var(--muted); font-size: 13px; line-height: 1.55;
}
.landing-trace {
  display: grid; grid-template-columns: minmax(0, 1.28fr) minmax(300px, .72fr);
  gap: 64px; align-items: center;
}
.landing-inline-stat {
  display: flex; flex-direction: column; gap: 6px; margin-top: 28px; padding-left: 16px;
  border-left: 3px solid var(--accent);
}
.landing-inline-stat strong { font-size: 14px; }
.landing-inline-stat span { color: var(--muted); font-size: 12px; }
.landing-steps { border-top: 1px solid var(--border); }
.landing-step-list {
  list-style: none; margin: 48px 0 0; padding: 0; display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)); border-top: 1px solid var(--border);
}
.landing-step-list li {
  display: flex; align-items: flex-start; gap: 18px; padding: 28px 24px 28px 0;
  border-bottom: 1px solid var(--border);
}
.landing-step-list li + li { padding-left: 24px; border-left: 1px solid var(--border); }
.landing-step-list > li > span { color: var(--accent); font-size: 12px; font-weight: 850; }
.landing-security {
  display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 60px; align-items: center;
  padding-block: 66px; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
}
.landing-security > div:first-child { max-width: 650px; }
.landing-security p { color: var(--muted); line-height: 1.6; }
.landing-security-points { display: flex; flex-direction: column; gap: 10px; }
.landing-security-points > span {
  display: flex; align-items: center; gap: 9px; color: #b7c1d3; font-size: 12px;
}
.landing-security-points .ui-icon { width: 17px; height: 17px; color: var(--accent); }
.landing-footer {
  width: min(calc(100% - 40px), var(--landing-width)); margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  padding: 28px 0 36px; border-top: 1px solid var(--border); color: #6f7b91; font-size: 11px;
}
.landing-footer .landing-brand-logo { width: 122px; }

/* ===== Auth ===== */
.app-hidden { display: none !important; }
.auth-screen {
  position: fixed; inset: 0; z-index: 100; display: grid; place-items: center; padding: 20px;
  background: rgba(2,5,12,.82); backdrop-filter: blur(12px); overflow-y: auto;
}
.auth-box {
  position: relative; width: 100%; max-width: 380px; background: var(--panel);
  border: 1px solid #263451; border-radius: var(--radius); padding: 30px 26px;
  box-shadow: 0 30px 90px rgba(0,0,0,.55);
}
.auth-close {
  position: absolute; top: 11px; right: 11px; width: 32px; height: 32px;
  display: grid; place-items: center; border: 0; background: transparent; color: var(--muted);
  border-radius: 50%; font-size: 15px;
}
.auth-close:hover { background: var(--panel2); color: #fff; }
.auth-brand-logo { display: block; width: min(210px, 72%); height: auto; margin: 0 auto; }
.auth-sub { text-align: center; color: var(--muted); margin: 10px 0 22px; }
.auth-switch { text-align: center; margin-top: 18px; color: var(--muted); font-size: 14px; }
.auth-switch .link-btn { font-size: 14px; }
.google-btn { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; padding: 12px; border-radius: 12px; background: #fff; color: #1a1a1a; font-weight: 600; font-size: 15px; text-decoration: none; border: 1px solid #dadce0; }
.google-btn:active { opacity: .85; }
.google-btn .g { font-weight: 800; color: #4285f4; font-family: Arial, sans-serif; }
.auth-forgot { display: block; width: 100%; text-align: center; margin-top: 14px; font-size: 13px; background: none; border: none; }
.auth-divider { display: flex; align-items: center; gap: 12px; color: var(--muted); font-size: 13px; margin: 20px 0; }
.auth-divider::before, .auth-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.auth-forgot { display: block; margin: -4px auto 0; }

@media (max-width: 899px) {
  .landing-header { top: 8px; width: calc(100% - 28px); height: 62px; padding-inline: 12px; }
  .landing-brand .landing-brand-logo { width: 124px; }
  .landing-nav { display: none; }
  .landing-login { display: none; }
  .landing-hero {
    min-height: 760px; padding: 100px 20px 66px; align-items: flex-end;
  }
  .landing-hero-image { object-position: 58% top; }
  .landing-hero-shade {
    background: linear-gradient(180deg, rgba(7,11,22,.4) 0%, rgba(7,11,22,.74) 42%, #070b16 84%);
  }
  .landing-hero-content { width: 100%; }
  .landing-hero h1 { font-size: 46px; max-width: 650px; }
  .landing-hero-content > p { font-size: 17px; max-width: 590px; }
  .landing-section { width: calc(100% - 40px); padding: 78px 0; }
  .landing-section h2 { font-size: 34px; }
  .landing-problem, .landing-product, .landing-trace, .landing-security {
    grid-template-columns: minmax(0, 1fr); gap: 42px;
  }
  .landing-product-visual { order: -1; }
  .landing-feature-list { gap: 0 30px; }
  .landing-security-points { flex-direction: row; flex-wrap: wrap; }
}

@media (max-width: 560px) {
  .landing-header { width: calc(100% - 16px); padding-inline: 10px; border-radius: 10px; }
  .landing-brand .landing-brand-logo { width: 112px; }
  .landing-primary.compact { min-height: 38px; padding-inline: 13px; }
  .landing-hero { min-height: 700px; padding-inline: 16px; }
  .landing-hero h1 { font-size: 40px; }
  .landing-hero-content > p { font-size: 16px; }
  .landing-hero-actions { align-items: stretch; flex-direction: column; }
  .landing-hero-actions button { width: 100%; }
  .landing-hero-proof { align-items: flex-start; }
  .landing-section { width: calc(100% - 32px); padding: 66px 0; }
  .landing-section h2 { font-size: 30px; }
  .landing-problem-list > div { grid-template-columns: 1fr; gap: 7px; }
  .landing-feature-list, .landing-step-list { grid-template-columns: 1fr; }
  .landing-feature-list article { grid-template-columns: 38px minmax(0, 1fr); gap: 13px; }
  .landing-feature-icon { width: 38px; height: 38px; }
  .landing-step-list li, .landing-step-list li + li {
    padding: 22px 0; border-left: 0;
  }
  .landing-security { width: calc(100% - 32px); }
  .landing-security-points { flex-direction: column; }
  .landing-footer { width: calc(100% - 32px); align-items: flex-start; flex-direction: column; }
  .auth-screen { padding: 12px; }
  .auth-box { padding: 26px 20px; }
}

/* ===== Layout ===== */
.layout { display: flex; min-height: 100vh; }
.sidebar { display: none; }
.mainwrap { flex: 1; min-width: 0; padding: 0 16px 90px; }

/* Topbar */
.topbar {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 4px; background: linear-gradient(180deg, var(--bg) 60%, transparent);
}
.page-title { font-size: 22px; font-weight: 700; }
.month { color: var(--muted); font-size: 13px; text-transform: capitalize; }
.topbar-right { display: flex; align-items: center; gap: 10px; }
.icon-btn { width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--border); background: var(--panel); color: var(--txt); font-size: 17px; }
.profile-wrap { position: relative; }
.avatar { width: 38px; height: 38px; border-radius: 50%; border: none; color: #fff; background: linear-gradient(135deg, var(--accent), #7b5cff); display: grid; place-items: center; font-weight: 700; overflow: hidden; background-size: cover; background-position: center; }
.avatar.has-photo { color: transparent; }
.profile-menu {
  position: absolute; top: 48px; right: 0; width: 250px; z-index: 40;
  background: var(--panel); border: 1px solid var(--border); border-radius: 14px;
  box-shadow: 0 16px 40px rgba(0,0,0,.35); padding: 12px;
}
.profile-email { font-weight: 700; font-size: 14px; overflow-wrap: anywhere; }
.profile-meta { color: var(--muted); font-size: 12px; margin: 4px 0 10px; line-height: 1.5; }
.profile-menu button {
  display: block; width: 100%; text-align: left; background: var(--panel2); border: 1px solid var(--border);
  color: var(--txt); padding: 11px 12px; border-radius: 11px; margin-top: 8px; font-size: 14px;
}
#profile-logout { color: var(--red); }

/* Views */
.view { display: none; animation: fade .2s ease; }
.view.active { display: block; }
@keyframes fade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }
.grid { display: flex; flex-direction: column; gap: 16px; }

/* Panels */
.panel { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; margin-bottom: 16px; }
.panel-dark { background: linear-gradient(135deg, #0c1426, #0a1a3a); border: 1px solid #1a2c52; border-radius: var(--radius); padding: 18px; margin-bottom: 16px; }
.panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.panel-head h2 { font-size: 15px; }
.link-btn { background: none; border: none; color: var(--accent); font-size: 13px; font-weight: 600; }
.panel-intro { color: var(--muted); font-size: 13px; line-height: 1.5; margin: -6px 0 14px; }
.empty-copy { color: var(--muted); font-size: 13px; line-height: 1.5; }

/* Hero balances */
.hero-head {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  color: var(--muted); font-size: 13px; margin-bottom: 12px;
}
.hero-head-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.hero-visibility-edit {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  min-height: 32px; padding: 6px 10px; border: 1px solid rgba(47,128,255,.38);
  border-radius: 9px; background: rgba(47,128,255,.12); color: var(--accent);
  font-size: 12px; font-weight: 750;
}
.hero-visibility-edit .ui-icon { width: 16px; height: 16px; }
.hero-balances { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.hbal { position: relative; min-width: 0; overflow: hidden; background: rgba(255,255,255,.03); border: 1px solid var(--border); border-radius: 14px; padding: 12px; }
.hbal .n { min-width: 0; color: var(--muted); font-size: 12px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hbal .v {
  display: block; width: 100%; max-width: 100%; min-width: 0; font-size: 20px; font-weight: 700;
  margin-top: 4px; white-space: nowrap; overflow: visible; font-variant-numeric: tabular-nums;
  line-height: 1.12;
}
.hbal .v.neg { color: var(--red); }
.hbal.credit { border-color: #4a3a6e; }
.hero-balances-empty {
  grid-column: 1 / -1; padding: 14px; border: 1px dashed var(--border); border-radius: 12px;
  color: var(--muted); font-size: 12px; line-height: 1.5; text-align: center;
}
.account-visibility-list { display: flex; flex-direction: column; gap: 8px; }
.account-visibility-option {
  display: flex !important; flex-direction: row !important; align-items: center; gap: 10px !important;
  margin: 0 !important; padding: 11px 12px; border: 1px solid var(--border);
  border-radius: 11px; background: var(--panel);
}
.account-visibility-option input { width: 17px !important; height: 17px; flex: 0 0 auto; }
.account-visibility-option span { display: flex; flex-direction: column; min-width: 0; color: var(--txt); }
.account-visibility-option small { color: var(--muted); font-size: 11px; margin-top: 2px; }

/* Vinculación con Telegram */
.telegram-panel { max-width: 820px; }
.telegram-status {
  display: flex; align-items: center; gap: 11px; padding: 12px 0 16px;
  border-bottom: 1px solid var(--border);
}
.telegram-status-dot {
  width: 10px; height: 10px; border-radius: 50%; flex: 0 0 auto;
  background: var(--amber); box-shadow: 0 0 0 5px rgba(245,196,81,.1);
}
.telegram-status.linked .telegram-status-dot { background: var(--green); box-shadow: 0 0 0 5px rgba(34,197,94,.1); }
.telegram-status b, .telegram-status span { display: block; }
.telegram-status b { font-size: 14px; }
.telegram-status span { color: var(--muted); font-size: 12px; margin-top: 3px; }
.telegram-guide { counter-reset: telegram-step; }
.telegram-step {
  display: grid; grid-template-columns: 30px minmax(0, 1fr); gap: 13px;
  padding: 17px 0; border-bottom: 1px solid var(--border);
}
.telegram-step-number {
  display: grid; place-items: center; width: 28px; height: 28px; border-radius: 50%;
  background: rgba(47,128,255,.13); border: 1px solid rgba(47,128,255,.32);
  color: var(--accent); font-size: 12px; font-weight: 850;
}
.telegram-step b { display: block; font-size: 14px; }
.telegram-step p { color: var(--muted); font-size: 12px; line-height: 1.55; margin: 4px 0 0; }
.telegram-store-links, .telegram-command-row { display: flex; align-items: center; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.telegram-store-links a, .telegram-open-bot {
  display: inline-flex; align-items: center; gap: 7px; min-height: 34px; padding: 7px 11px;
  border: 1px solid var(--border); border-radius: 9px; color: var(--accent);
  background: var(--panel2); text-decoration: none; font-size: 12px; font-weight: 700;
}
.telegram-open-bot .ui-icon { width: 15px; height: 15px; }
.telegram-bot-unavailable { display: block; color: var(--amber); font-size: 11px; margin-top: 9px; }
.telegram-command-row { flex-wrap: nowrap; }
.telegram-command-row code {
  min-width: 0; flex: 1; padding: 10px 12px; border-radius: 9px;
  background: #080d19; border: 1px solid var(--border); color: #dce6fa;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.telegram-command-row button {
  display: inline-flex; align-items: center; gap: 6px; min-height: 38px; padding: 8px 11px;
  border: 1px solid rgba(47,128,255,.34); border-radius: 9px;
  background: rgba(47,128,255,.12); color: var(--accent); font-weight: 750;
}
.telegram-command-row .ui-icon { width: 15px; height: 15px; }
.telegram-command-summary { display: flex; flex-wrap: wrap; gap: 8px 16px; padding-top: 16px; font-size: 12px; }
.telegram-command-summary b { width: 100%; font-size: 13px; }
.telegram-command-summary span { color: var(--muted); }
.telegram-command-summary code { color: var(--accent); }
@media (max-width: 560px) {
  .telegram-panel { padding: 13px; }
  .telegram-step { grid-template-columns: 27px minmax(0, 1fr); gap: 10px; padding-block: 15px; }
  .telegram-step-number { width: 25px; height: 25px; }
  .telegram-command-row { align-items: stretch; }
  .telegram-command-row code { padding: 10px; font-size: 11px; }
  .telegram-command-row button { padding-inline: 9px; }
  .telegram-command-summary { flex-direction: column; gap: 7px; }
}

/* Dólar */
.dolar { display: flex; gap: 10px; margin-bottom: 16px; }
.dol { flex: 1; background: #0c0e12; border: 1px solid #20242c; border-radius: 14px; padding: 12px; text-align: center; }
.dol .dl { font-size: 12px; color: #8a96b0; }
.dol .dv { font-size: 18px; font-weight: 700; margin-top: 4px; color: #eaf0fb; }

/* Month totals */
.month-totals { display: flex; gap: 12px; }
.mt { flex: 1; min-width: 0; background: var(--panel2); border-radius: 14px; padding: 14px; text-align: center; }
.mt.traceable { border: 1px solid transparent; color: var(--txt); font: inherit; }
.mt .val { overflow-wrap: normal; }
.mt .lbl { font-size: 12px; color: var(--muted); }
.mt .val {
  display: block; width: 100%; min-width: 0; font-size: 18px; font-weight: 700;
  margin-top: 4px; white-space: nowrap; overflow: hidden; font-variant-numeric: tabular-nums;
}
.mt .val.in { color: var(--green); }
.mt .val.out { color: var(--red); }

/* Category rows */
.catrow { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--border); gap: 10px; }
.catrow:is(button) { width: 100%; background: transparent; color: var(--txt); border-top: 0; border-left: 0; border-right: 0; text-align: left; font: inherit; }
.catrow:last-child { border: none; }
.catrow .l { display: flex; align-items: center; gap: 8px; min-width: 0; }
.catrow .ui-icon, .bgt .ui-icon, .card-box .ui-icon { color: var(--accent); width: 18px; height: 18px; }
.ui-icon.cat-colored { color: var(--cat-color, var(--accent)); }
.label-icon { display: inline-flex; align-items: center; gap: 8px; min-width: 0; }
.cat-color-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--cat-color, var(--accent)); flex: 0 0 auto; box-shadow: 0 0 0 3px rgba(255,255,255,.04); }
.bar { height: 6px; background: var(--cat-color, var(--accent)); border-radius: 3px; margin-top: 4px; }

/* Budgets */
.bgt { padding: 12px 0; border-bottom: 1px solid var(--border); }
.bgt:last-child { border: none; }
.bgt .top { display: flex; justify-content: space-between; font-size: 14px; margin-bottom: 8px; }
.bgt .track { height: 8px; background: var(--panel2); border-radius: 5px; overflow: hidden; }
.bgt .fill { height: 100%; background: var(--cat-color, var(--green)); border-radius: 5px; }
.bgt .fill.warn { background: var(--amber); }
.bgt .fill.over { background: var(--red); }
.bgt .sub { font-size: 12px; color: var(--muted); margin-top: 6px; display: flex; justify-content: space-between; }

/* Card boxes */
.card-box { background: var(--panel2); border-radius: 14px; padding: 14px; margin-bottom: 10px; }
.trace-card-box { display: block; width: 100%; color: var(--txt); border: 1px solid transparent; text-align: left; font: inherit; }
.card-box .ttl { display: flex; justify-content: space-between; font-weight: 600; align-items: center; }
.card-box .meta { color: var(--muted); font-size: 13px; margin-top: 6px; line-height: 1.7; }
.pill { font-size: 12px; padding: 3px 10px; border-radius: 20px; background: rgba(47,128,255,.15); color: var(--accent); }
.card-box-wrap { margin-bottom: 10px; }
.card-box-wrap .card-box { margin-bottom: 0; }
.card-statement { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap;
  background: var(--panel2); border-radius: 0 0 14px 14px; margin-top: -2px; padding: 12px 14px;
  border-top: 1px dashed rgba(255,255,255,.08); }
.card-statement.paid { border-left: 3px solid var(--green); }
.card-statement.pending { border-left: 3px solid var(--red); }
.card-statement-info { display: flex; flex-direction: column; gap: 2px; font-size: 13px; }
.card-statement-title { font-weight: 600; }
.card-statement-amount { color: var(--muted); }
.card-statement-info small { color: var(--muted); }
.card-statement-badge { font-weight: 600; font-size: 12px; width: fit-content; }
.card-statement-badge.paid { color: var(--green); }
.card-statement-badge.pending { color: var(--red); }
.card-statement-toggle { white-space: nowrap; }
.hbal-receivable { cursor: pointer; font: inherit; color: inherit; text-align: left; border: 1px dashed rgba(255,255,255,.16); }
.hbal-receivable:hover { border-color: var(--accent); }
.recv-summary { background: var(--panel2); border-radius: 12px; padding: 12px 14px; margin-bottom: 12px; font-size: 14px; }
.recv-row .recv-badge { font-size: 12px; font-weight: 600; margin-left: 6px; }
.recv-badge.paid { color: var(--green); }
.recv-badge.overdue { color: var(--red); }
.recv-badge.pending { color: var(--muted); }
.recv-row .ed-pay { color: var(--green); }

/* Cuentas a pagar */
.payable-kpis { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-bottom: 16px; }
.payable-kpi {
  min-width: 0; background: var(--panel); border: 1px solid var(--border);
  border-radius: 14px; padding: 13px;
}
.payable-kpi span { display: block; color: var(--muted); font-size: 11px; margin-bottom: 7px; }
.payable-kpi b { display: block; font-size: 18px; overflow-wrap: anywhere; }
.payable-kpi.primary { border-color: rgba(47,128,255,.35); }
.payable-kpi.primary b { color: var(--accent); }
.payable-kpi.danger b { color: var(--red); }
.payable-kpi.warning b { color: var(--amber); }
.payable-kpi.success b { color: var(--green); }
.payable-toolbar { display: flex; flex-direction: column; gap: 14px; overflow: hidden; }
.payable-filters { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.payable-filters label {
  display: flex; flex-direction: column; gap: 6px; min-width: 0; color: var(--muted); font-size: 12px;
}
.payable-filters select, .payable-filters input {
  display: block; width: 100%; min-width: 0; max-width: 100%; background: var(--panel2); border: 1px solid var(--border);
  color: var(--txt); padding: 11px 12px; border-radius: 11px; font-size: 14px;
}
.payable-toolbar-actions { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.payable-toolbar-actions button { white-space: normal; line-height: 1.25; min-width: 0; }
.btn-primary.compact { padding: 10px 13px; border-radius: 10px; font-size: 13px; }
.bill-list { display: flex; flex-direction: column; gap: 10px; }
.bill-card {
  width: 100%; min-width: 0; max-width: 100%;
  background: var(--panel2); border: 1px solid var(--border); border-radius: 14px;
  overflow: hidden;
}
.bill-card.overdue { border-color: rgba(244,86,108,.48); }
.bill-card.due-soon { border-color: rgba(245,196,81,.42); }
.bill-card.paid { opacity: .78; }
.bill-card-main {
  display: grid; grid-template-columns: 4px minmax(0, 1fr); gap: 12px;
  align-items: start; padding: 14px 14px 10px 0;
}
.bill-accent { align-self: stretch; min-height: 76px; background: var(--bill-color, var(--accent)); border-radius: 0 4px 4px 0; }
.bill-copy, .bill-title-line, .bill-dates, .bill-amount { min-width: 0; max-width: 100%; }
.bill-title-line { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.bill-title-line h3 { font-size: 15px; line-height: 1.3; overflow-wrap: anywhere; }
.bill-copy p { color: var(--muted); font-size: 12px; margin: 5px 0 8px; }
.bill-dates { display: flex; flex-wrap: wrap; gap: 6px 12px; color: var(--muted); font-size: 12px; }
.bill-dates span:first-child { color: var(--txt); font-weight: 600; }
.bill-amount { grid-column: 2; text-align: left; margin-top: 4px; }
.bill-amount b { display: block; font-size: 19px; }
.bill-amount small { color: var(--amber); display: block; margin-top: 3px; }
.bill-status {
  flex: 0 0 auto; white-space: nowrap; border-radius: 999px; padding: 4px 8px;
  font-size: 10px; font-weight: 750; background: rgba(138,150,176,.13); color: var(--muted);
}
.bill-status.overdue { background: rgba(244,86,108,.13); color: var(--red); }
.bill-status.due-soon { background: rgba(245,196,81,.13); color: var(--amber); }
.bill-status.partial { background: rgba(47,128,255,.14); color: var(--accent); }
.bill-status.paid { background: rgba(34,197,94,.13); color: var(--green); }
.bill-actions {
  display: flex; align-items: center; flex-wrap: wrap; gap: 8px;
  border-top: 1px solid var(--border); padding: 9px 12px;
}
.bill-actions button { min-height: 34px; }
.bill-pay {
  background: var(--accent); border: none; color: #fff; border-radius: 9px;
  padding: 8px 11px; font-size: 12px; font-weight: 700;
}
.danger-link { color: var(--red); }
.paid-note { color: var(--muted); font-size: 12px; }
.service-row {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  border-bottom: 1px solid var(--border); padding: 11px 0;
}
.service-row:last-child { border-bottom: 0; }
.service-row > div { min-width: 0; }
.service-row b { display: block; font-size: 13px; overflow-wrap: anywhere; }
.service-row span { display: block; color: var(--muted); font-size: 11px; margin-top: 4px; line-height: 1.4; }
.service-row.paused { opacity: .55; }
.empty-state {
  display: flex; flex-direction: column; gap: 5px; padding: 20px 12px;
  border: 1px dashed var(--border); border-radius: 12px; text-align: center;
}
.empty-state b { font-size: 14px; }
.empty-state span { color: var(--muted); font-size: 12px; line-height: 1.5; }
.bill-mini-total {
  display: flex; align-items: baseline; justify-content: space-between; gap: 10px;
  padding-bottom: 10px; border-bottom: 1px solid var(--border);
}
.bill-mini-total span { color: var(--muted); font-size: 12px; }
.bill-mini-total b { font-size: 17px; }
.bill-mini-row {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  width: 100%; background: transparent; color: var(--txt); border: 0;
  border-bottom: 1px solid var(--border); padding: 11px 0; text-align: left;
}
.bill-mini-row:last-child { border-bottom: 0; }
.bill-mini-main { display: flex; flex-direction: column; min-width: 0; gap: 3px; }
.bill-mini-main b { font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bill-mini-main small { color: var(--muted); font-size: 11px; }
.bill-mini-main small.overdue { color: var(--red); }
.bill-mini-main small.due-soon { color: var(--amber); }
.bill-mini-row strong { font-size: 13px; white-space: nowrap; }

/* Reports */
.report-dashboard { display: flex; flex-direction: column; gap: 12px; }
.report-dashboard > .panel, .report-pane .panel { margin-bottom: 0; }
.report-toolbar { padding: 12px; }
.report-toolbar-main { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.report-quick-field, .report-category-picker {
  display: flex; flex-direction: column; gap: 4px; min-width: 0;
}
.report-category-picker { position: relative; }
.report-control-caption {
  color: var(--muted); font-size: 11px; line-height: 1; padding-left: 2px;
}
.report-quick-ranges {
  display: flex; align-items: center; gap: 5px; min-width: 0; min-height: 40px;
  overflow-x: auto; scrollbar-width: none;
}
.report-quick-ranges::-webkit-scrollbar { display: none; }
.report-quick-ranges button, .report-view-tabs button {
  border: 0; background: transparent; color: var(--muted); font-weight: 700;
  white-space: nowrap; border-radius: 8px; padding: 8px 10px; min-height: 40px; font-size: 12px;
}
.report-quick-ranges button:hover, .report-quick-ranges button.active,
.report-view-tabs button:hover, .report-view-tabs button.active {
  color: var(--txt); background: var(--panel2);
}
.report-filter-toggle {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px; flex: 0 0 auto;
}
.report-filter-toggle .ui-icon { width: 16px; height: 16px; }
.report-filter-panel { display: none; grid-template-columns: minmax(0, 1fr); gap: 10px; margin-top: 10px; }
.report-filter-panel.open { display: grid; }
.report-controls { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.report-controls label { display: flex; flex-direction: column; gap: 4px; color: var(--muted); font-size: 11px; }
.report-controls input, .report-controls select {
  background: var(--panel2); border: 1px solid var(--border); color: var(--txt);
  min-height: 40px; padding: 9px 10px; border-radius: 9px; font-size: 13px; width: 100%; min-width: 0;
}
.report-category-toggle {
  width: 100%; min-height: 40px; display: flex; align-items: center; gap: 8px;
  background: var(--panel2); border: 1px solid var(--border); color: var(--txt);
  border-radius: 9px; padding: 9px 11px; font-size: 13px; font-weight: 700; text-align: left;
}
.report-category-toggle .ui-icon { width: 17px; height: 17px; color: var(--accent); }
.report-category-popover {
  position: absolute; top: calc(100% + 7px); right: 0; z-index: 30;
  width: min(420px, calc(100vw - 56px)); max-height: 390px; overflow-y: auto;
  background: var(--bg2); border: 1px solid var(--border); border-radius: 12px;
  box-shadow: 0 18px 45px rgba(0,0,0,.42); padding: 12px;
}
.report-category-popover-head {
  display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 10px;
}
.report-category-popover-head b { font-size: 13px; }
.report-category-popover .btn-primary { width: 100%; margin-top: 10px; }
.report-cats { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px; }
.report-cat {
  display: grid; grid-template-columns: 10px minmax(0, 1fr) 16px; align-items: center; gap: 7px;
  min-width: 0; background: var(--panel2); border: 1px solid var(--border); color: var(--txt);
  border-radius: 9px; padding: 8px; font-size: 12px; cursor: pointer;
}
.report-cat > span:nth-child(2) { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.report-cat:has(input:checked) { border-color: var(--cat-color, var(--accent)); background: rgba(47,128,255,.08); }
.report-cat input { width: 15px; height: 15px; margin: 0; accent-color: var(--accent); }
.report-view-tabs {
  display: inline-flex; align-self: flex-start; background: var(--panel);
  border: 1px solid var(--border); border-radius: 10px; padding: 3px;
}
.report-view-tabs button { min-width: 96px; }
.report-view-tabs button.active { background: var(--accent); color: #fff; }
.report-pane { display: none; }
.report-pane.active { display: block; }
.report-chart-panel { overflow: hidden; }
.report-chart-wrap {
  position: relative; height: 320px; width: 100%;
  background: linear-gradient(180deg, rgba(126,115,255,.11), rgba(19,29,51,.1));
  border: 1px solid rgba(126,115,255,.18); border-radius: 12px; padding: 8px;
}
.report-kpis { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.rkpi {
  position: relative; overflow: hidden; min-width: 0; min-height: 96px;
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
  border: 1px solid var(--border); border-radius: 12px; padding: 12px;
  color: var(--txt); text-align: left; font: inherit;
}
.rkpi::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -22px; height: 58px;
  background: var(--kpi-wave, rgba(47,128,255,.18));
  clip-path: polygon(0 45%, 13% 22%, 28% 38%, 44% 18%, 58% 50%, 74% 28%, 100% 40%, 100% 100%, 0 100%);
  opacity: .82;
}
.rkpi .k, .rkpi .v, .rkpi .delta { position: relative; z-index: 1; }
.rkpi .k { color: var(--muted); font-size: 12px; display: flex; align-items: center; gap: 7px; }
.rkpi .k .ui-icon { width: 16px; height: 16px; color: var(--accent); }
.rkpi .v { font-weight: 850; font-size: 19px; margin-top: 8px; overflow-wrap: anywhere; }
.rkpi .delta { display: inline-flex; align-items: center; margin-top: 6px; border-radius: 999px; padding: 3px 7px; font-size: 10px; background: rgba(138,150,176,.14); color: var(--muted); }
.rkpi .delta.good { color: var(--green); background: rgba(34,197,94,.12); }
.rkpi .delta.bad { color: var(--red); background: rgba(244,86,108,.12); }
.rkpi.income { --kpi-wave: rgba(34,197,94,.2); }
.rkpi.expense { --kpi-wave: rgba(244,86,108,.19); }
.rkpi.balance { --kpi-wave: rgba(126,115,255,.2); }
.rkpi.focus { --kpi-wave: rgba(245,196,81,.18); }
.report-summary-side { display: flex; flex-direction: column; gap: 12px; }
.report-distribution-content { display: grid; grid-template-columns: 150px minmax(0, 1fr); align-items: center; gap: 12px; }
.report-donut-wrap { position: relative; height: 160px; display: grid; place-items: center; }
.report-donut-wrap canvas { max-height: 160px; }
.report-donut-total {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; pointer-events: none;
  text-align: center; font-weight: 850; font-size: 18px; line-height: 1.1;
}
.report-donut-total span {
  display: block; white-space: nowrap; overflow: hidden; font-variant-numeric: tabular-nums;
}
.report-donut-total small { display: block; color: var(--muted); font-weight: 600; font-size: 11px; margin-top: 5px; }
.report-share-list, .report-deltas { display: flex; flex-direction: column; gap: 7px; }
.share-row, .delta-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 10px; align-items: center; font-size: 13px; }
.share-row:is(button) { width: 100%; background: transparent; border: 0; color: var(--txt); padding: 4px 0; text-align: left; font: inherit; }
.share-row .name, .delta-row .name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.share-row .meta, .delta-row .meta { color: var(--muted); font-size: 12px; }
/* % y monto siempre alineados a la derecha, prolijos sin importar el largo */
.share-row > div:last-child, .delta-row > div:last-child { text-align: right; }
.share-row > div:last-child b { display: block; }
.share-dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; margin-right: 7px; }
.delta-row .change.up { color: var(--red); }
.delta-row .change.down { color: var(--green); }
.report-table-wrap { overflow-x: auto; }
.report-table { width: 100%; border-collapse: collapse; min-width: 620px; }
.report-table th, .report-table td { padding: 11px 12px; border-bottom: 1px solid var(--border); text-align: left; font-size: 13px; }
.report-table th { color: var(--muted); font-weight: 700; }
.report-table td.amount { font-weight: 800; text-align: right; white-space: nowrap; }
.report-table tr:last-child td { border-bottom: 0; }
.traceable-report-row { cursor: pointer; }
.traceable-report-row:hover { background: rgba(47,128,255,.06); }
.feedback-list { display: flex; flex-direction: column; gap: 10px; }
.feedback-item { background: var(--panel2); border: 1px solid var(--border); border-radius: 14px; padding: 12px 13px; color: var(--txt); line-height: 1.45; }
.feedback-note { color: var(--muted); font-size: 12px; margin-top: 10px; }
.report-feedback-panel { max-width: 900px; }

/* Tx list */
.tx-panel-head { margin-bottom: 10px; }
.tx-tools { display: flex; flex-direction: column; gap: 8px; margin-bottom: 8px; }
.tx-tools-main { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 8px; align-items: stretch; }
.tx-search {
  position: relative; display: flex; align-items: center; min-width: 0; margin: 0;
}
.tx-search .ui-icon {
  position: absolute; left: 13px; width: 18px; height: 18px; color: var(--muted); pointer-events: none;
}
.tx-search input {
  width: 100%; min-width: 0; min-height: 44px; background: var(--panel2); border: 1px solid var(--border); color: var(--txt);
  padding: 10px 11px 10px 39px; border-radius: 11px; font-size: 14px;
}
.tx-search input:focus, .tx-filters select:focus, .tx-filters input:focus {
  outline: none; border-color: rgba(47,128,255,.75); box-shadow: 0 0 0 3px rgba(47,128,255,.14);
}
.tx-filter-toggle {
  min-height: 44px; display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  background: var(--panel2); border: 1px solid var(--border); color: var(--muted);
  border-radius: 11px; padding: 9px 11px; font-size: 12px; font-weight: 700;
}
.tx-filter-toggle .ui-icon { width: 17px; height: 17px; }
.tx-filter-toggle.active { color: var(--accent); border-color: rgba(47,128,255,.55); }
.tx-filter-toggle b {
  display: grid; place-items: center; min-width: 18px; height: 18px; padding: 0 5px;
  border-radius: 999px; background: var(--accent); color: #fff; font-size: 10px;
}
.tx-filters { display: none; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.tx-filters.open { display: grid; }
.tx-filters label { display: flex; flex-direction: column; gap: 4px; min-width: 0; color: var(--muted); font-size: 11px; }
.tx-filters label:nth-child(3) { grid-column: 1 / -1; }
.tx-filters select, .tx-filters input {
  display: block; width: 100%; min-width: 0; max-width: 100%;
  min-height: 40px; background: var(--panel2); border: 1px solid var(--border); color: var(--txt);
  padding: 8px 9px; border-radius: 9px; font-size: 13px;
}
.tx-filters select:disabled { opacity: .55; }
.tx-list { display: flex; flex-direction: column; }
.tx { display: flex; align-items: center; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--border); }
.tx:last-child { border: none; }
.tx .ic { width: 40px; height: 40px; border-radius: 12px; background: var(--panel2); display: grid; place-items: center; flex-shrink: 0; color: var(--accent); }
.tx .ic.in { color: var(--tx-color, var(--green)); }
.tx .ic.out { color: var(--tx-color, var(--red)); }
.tx .ic.tr { color: var(--amber); }
.tx .ic .ui-icon { width: 21px; height: 21px; }
.tx .info { flex: 1; min-width: 0; }
.tx .info.traceable-info { cursor: pointer; }
.tx .info.traceable-info:hover .t1 { color: var(--accent); }
.tx .info .t1 { font-weight: 600; font-size: 14px; }
.tx .info .t2 { color: var(--muted); font-size: 12px; margin-top: 2px; }
.tx .amt { font-weight: 700; font-size: 15px; white-space: nowrap; }
.tx .amt.in { color: var(--tx-color, var(--green)); } .tx .amt.out { color: var(--tx-color, var(--red)); } .tx .amt.tr { color: var(--amber); }
.tx-actions { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.tx-action {
  width: 32px; height: 32px; display: grid; place-items: center;
  background: transparent; border: none; border-radius: 8px; color: var(--muted); padding: 0;
}
.tx-action .ui-icon { width: 17px; height: 17px; }
.tx-action.edit:hover { color: var(--accent); background: rgba(47,128,255,.1); }
.tx-action.del:hover { color: var(--red); background: rgba(244,86,108,.1); }

/* Carga inteligente */
.smart-grid { display: grid; grid-template-columns: minmax(0, 1fr); gap: 16px; align-items: start; }
.smart-import-controls {
  display: grid; grid-template-columns: minmax(0, 1fr); gap: 10px; align-items: end;
}
.smart-import-controls label, .import-row > label {
  display: flex; flex-direction: column; gap: 6px; color: var(--muted); font-size: 12px;
}
.smart-import-controls input, .smart-import-controls select,
.import-row input, .import-row select {
  width: 100%; min-width: 0; background: var(--panel2); border: 1px solid var(--border);
  color: var(--txt); padding: 10px 11px; border-radius: 10px; font-size: 13px;
}
.smart-import-controls input[type="file"] { padding: 8px; }
.smart-import-controls input[type="file"]::file-selector-button {
  background: rgba(47,128,255,.14); border: 0; color: var(--accent);
  padding: 8px 10px; border-radius: 8px; margin-right: 9px; font-weight: 700;
}
.smart-status { min-height: 20px; margin: 11px 0 0; color: var(--muted); font-size: 13px; }
.smart-status.error { color: var(--red); }
.smart-status.success { color: var(--green); }
.import-summary {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; margin: 14px 0;
}
.import-summary span {
  background: var(--panel2); border: 1px solid var(--border); border-radius: 10px;
  padding: 9px 10px; color: var(--muted); font-size: 11px;
}
.import-summary b { display: block; color: var(--txt); font-size: 16px; margin-bottom: 2px; }
.import-summary .success b { color: var(--green); }
.import-summary .warning b { color: var(--amber); }
.import-summary .danger b { color: var(--red); }
.import-list { display: flex; flex-direction: column; gap: 9px; }
.import-row {
  display: grid; grid-template-columns: 28px minmax(0, 1fr);
  gap: 10px; align-items: start; padding: 12px;
  background: var(--panel2); border: 1px solid var(--border); border-radius: 12px;
}
.import-row.invalid { border-color: rgba(244,86,108,.4); }
.import-row.possible-duplicate { border-color: rgba(245,196,81,.35); }
.import-check { display: grid !important; place-items: center; padding-top: 7px; }
.import-check input { width: 17px; height: 17px; accent-color: var(--accent); padding: 0; }
.import-main { min-width: 0; grid-column: 2; }
.import-description { font-weight: 700; }
.import-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 7px; margin-top: 7px; }
.import-meta input { width: 145px; padding: 8px 9px; color: var(--muted); }
.import-state { font-size: 10px; padding: 4px 8px; border-radius: 999px; white-space: nowrap; }
.import-state.error { color: var(--red); background: rgba(244,86,108,.12); }
.import-state.duplicate { color: var(--amber); background: rgba(245,196,81,.12); }
.import-state.rule { color: var(--green); background: rgba(34,197,94,.12); }
.import-state.review { color: var(--muted); background: rgba(138,150,176,.12); }
.import-row > label:not(.import-check) { grid-column: 2; }
.import-amount span { display: flex; align-items: center; gap: 7px; }
.import-amount small { color: var(--muted); min-width: 28px; }
.import-footer {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  border-top: 1px solid var(--border); margin-top: 14px; padding-top: 14px;
}
.import-footer span { color: var(--muted); font-size: 12px; }
.import-footer button:disabled { opacity: .45; cursor: not-allowed; }
.rules-list { display: flex; flex-direction: column; }
.rule-row {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 12px 0; border-bottom: 1px solid var(--border);
}
.rule-row:last-child { border-bottom: 0; }
.rule-copy { min-width: 0; }
.rule-copy b { display: block; font-size: 13px; overflow-wrap: anywhere; }
.rule-copy span { display: block; color: var(--muted); font-size: 11px; line-height: 1.45; margin-top: 4px; }

/* Admin rows */
.admin-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--border); gap: 8px; }
.admin-row:last-child { border: none; }
.admin-row .meta { color: var(--muted); font-size: 12px; }
.admin-row button { background: none; border: none; color: var(--accent); font-size: 13px; }
.installment-plan-open {
  flex: 1; min-width: 0; display: flex; flex-direction: column; align-items: flex-start;
  text-align: left; color: var(--txt) !important; padding: 4px 0;
}
.installment-plan-open b { overflow-wrap: anywhere; }
.installment-plan-open .meta { display: block; margin-top: 3px; line-height: 1.45; }
.installment-plan-delete { flex: 0 0 auto; color: var(--red) !important; }
.admin-actions { display: flex; align-items: center; justify-content: flex-end; gap: 12px; flex-shrink: 0; }
.admin-actions .de { color: var(--red); }
.admin-test-msg { min-height: 18px; margin: -4px 0 10px; font-size: 13px; }
.btn-add { background: var(--panel2); color: var(--accent); border: 1px solid var(--border); padding: 7px 12px; border-radius: 10px; font-size: 13px; font-weight: 600; }
.code-line { background: #0a0e16; border: 1px solid var(--border); border-radius: 10px; padding: 12px; font-family: ui-monospace, monospace; font-size: 15px; color: var(--accent); text-align: center; user-select: all; }
.biglink { display: flex; align-items: center; gap: 10px; width: 100%; text-align: left; background: var(--panel2); border: 1px solid var(--border); color: var(--txt); padding: 16px; border-radius: 14px; font-size: 15px; margin-bottom: 12px; }
.biglink .ui-icon { color: var(--accent); }

/* Forms */
.seg { display: flex; background: var(--panel2); border-radius: 12px; padding: 4px; margin-bottom: 16px; }
.seg-btn { flex: 1; padding: 10px; border: none; background: transparent; color: var(--muted); border-radius: 9px; font-size: 14px; font-weight: 600; }
.seg-btn.active { background: var(--accent); color: #fff; }
.form { display: flex; flex-direction: column; gap: 14px; }
.form label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--muted); }
.row2 { display: flex; gap: 12px; } .row2 label { flex: 1; }
.form input, .form select, .modal-box input, .modal-box select {
  background: var(--panel2); border: 1px solid var(--border); color: var(--txt);
  padding: 13px; border-radius: 12px; font-size: 16px; width: 100%;
}
.modal-box input[type="color"] { height: 50px; padding: 6px; cursor: pointer; }
.modal-box input[type="color"]::-webkit-color-swatch-wrapper { padding: 0; }
.modal-box input[type="color"]::-webkit-color-swatch { border: 0; border-radius: 8px; }
#f-amount { font-size: 26px; font-weight: 700; text-align: center; }
.btn-primary { background: var(--accent); color: #fff; border: none; padding: 15px; border-radius: 12px; font-size: 16px; font-weight: 700; }

/* Modal compacto para cargar movimientos */
.movement-modal-box { max-width: 680px; padding: 18px; }
.movement-modal-box .modal-top { margin-bottom: 10px; }
.movement-modal-box .seg { margin-bottom: 12px; }
.movement-modal-box .seg-btn { padding: 9px; }
.movement-form { display: grid; grid-template-columns: minmax(0, 1fr); gap: 10px; }
.movement-form label { margin: 0; gap: 5px; font-size: 12px; }
.movement-form input, .movement-form select {
  padding: 10px 11px; border-radius: 10px; font-size: 14px; min-height: 42px;
}
.movement-form .movement-amount { grid-column: 1 / -1; }
.movement-form #f-amount {
  min-height: 58px; padding: 8px 12px; font-size: 24px; border-color: rgba(47,128,255,.25);
}
.movement-form #grp-account { display: contents; }
.movement-form #grp-transfer {
  grid-column: 1 / -1; display: grid; grid-template-columns: minmax(0, 1fr); gap: 10px;
}
.movement-more-toggle {
  grid-column: 1 / -1; width: 100%; min-height: 40px;
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  background: transparent; color: var(--accent); border: 1px dashed var(--border);
  border-radius: 10px; padding: 8px 11px; font-size: 13px; font-weight: 700; text-align: left;
}
.movement-more-toggle small {
  color: var(--muted); font-size: 11px; font-weight: 500; overflow: hidden;
  text-overflow: ellipsis; white-space: nowrap;
}
.movement-more-toggle::after { content: '⌄'; color: var(--muted); font-size: 15px; }
.movement-more-toggle.open::after { content: '⌃'; }
.movement-more-fields {
  grid-column: 1 / -1; display: grid; grid-template-columns: minmax(0, 1fr);
  gap: 10px; padding: 10px; background: rgba(255,255,255,.018);
  border: 1px solid var(--border); border-radius: 10px;
}
.movement-more-fields #grp-cuotas {
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 10px; grid-column: 1 / -1;
}
.movement-save, .movement-form .form-msg { grid-column: 1 / -1; }
.movement-save { min-height: 44px; padding: 11px; font-size: 14px; }
.movement-form .form-msg { margin: -2px 0 0; min-height: 16px; font-size: 12px; }

/* ===== Animación de "apretado" en botones ===== */
.btn-primary, .google-btn, .btn-add, .seg-btn, .link-btn, .nav-btn, .snav,
.fab, .inline-action, .admin-row button, .modal-box button, .movement-more-toggle {
  transition: transform .08s ease, opacity .15s ease, background .15s ease, box-shadow .15s ease;
  -webkit-tap-highlight-color: transparent;
}
.btn-primary:active, .google-btn:active, .btn-add:active,
.seg-btn:active, .modal-box button:active {
  transform: scale(.96); opacity: .9;
}
.link-btn:active, .nav-btn:active, .snav:active,
.inline-action:active, .admin-row button:active {
  transform: scale(.93); opacity: .8;
}
.fab:active { transform: scale(.9); opacity: .92; }
@media (hover: hover) {
  .btn-primary:hover { background: var(--accent2); }
  .google-btn:hover, .btn-add:hover { box-shadow: 0 0 0 1px var(--accent); }
}
.form-msg { text-align: center; font-size: 14px; min-height: 20px; }
.form-msg.err { color: var(--red); } .form-msg.ok { color: var(--green); }
.form-msg a { color: var(--accent); font-weight: 700; }
.form-msg small { color: var(--muted); line-height: 1.4; }
.inline-action { margin-top: 8px; background: none; border: none; color: var(--accent); font-weight: 700; font-size: 14px; }
.hidden { display: none !important; }

/* Bottom nav (móvil) */
.bottomnav {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 20;
  display: flex; align-items: center; background: var(--bg2); border-top: 1px solid var(--border);
  padding: 6px 4px calc(6px + env(safe-area-inset-bottom));
}
.nav-btn { flex: 1; background: none; border: none; color: var(--muted); font-size: 11px; display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 6px; }
.nav-btn .ui-icon { width: 22px; height: 22px; }
.nav-btn.active { color: var(--accent); }
.fab {
  width: 58px; height: 58px; margin: -23px 8px 0; border-radius: 50%;
  border: 4px solid var(--bg2); background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #fff; box-shadow: 0 10px 24px rgba(47,128,255,.38); flex-shrink: 0;
  display: grid; place-items: center; padding: 0;
}
.fab .ui-icon { width: 31px; height: 31px; }

/* Modal */
.modal { position: fixed; inset: 0; background: rgba(0,0,0,.65); display: grid; place-items: center; z-index: 50; padding: 16px; }
.modal-box { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; width: 100%; max-width: 440px; max-height: 92vh; overflow-y: auto; }
.modal-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.modal-box .x { background: none; border: none; color: var(--muted); font-size: 18px; }
.modal-box label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--muted); margin-bottom: 12px; }
.modal-box label.checkline { flex-direction: row; align-items: center; color: var(--txt); }
.modal-box label.checkline input { width: auto; }
.modal-actions { display: flex; gap: 10px; margin-top: 8px; }
.modal-actions button { flex: 1; }

/* Trazabilidad de totales, gráficos y cuotas */
.traceable, .traceable-row, .trace-card-box { cursor: pointer; }
.traceable:focus-visible, .traceable-row:focus-visible, .trace-card-box:focus-visible,
.installment-plan-open:focus-visible, .trace-plan-link:focus-visible {
  outline: 2px solid var(--accent); outline-offset: 2px;
}
@media (hover: hover) {
  .rkpi.traceable:hover, .mt.traceable:hover, .trace-card-box:hover {
    border-color: rgba(47,128,255,.48); transform: translateY(-1px);
  }
  .traceable-row:hover { color: var(--accent); background: rgba(47,128,255,.045); }
}
.trace-modal-box { max-width: 720px; padding: 18px; }
.trace-modal-top { align-items: flex-start; }
.trace-eyebrow {
  display: block; margin-bottom: 4px; color: var(--accent); font-size: 10px;
  font-weight: 800; text-transform: uppercase; letter-spacing: .08em;
}
.trace-modal-top h3 { font-size: 19px; line-height: 1.3; overflow-wrap: anywhere; }
.trace-summary {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; margin-bottom: 12px;
}
.trace-stat {
  min-width: 0; background: var(--panel2); border: 1px solid var(--border);
  border-radius: 11px; padding: 10px 11px;
}
.trace-stat span { display: block; color: var(--muted); font-size: 10px; margin-bottom: 5px; }
.trace-stat b { display: block; font-size: 15px; overflow-wrap: anywhere; }
.trace-stat.income b { color: var(--green); }
.trace-stat.expense b { color: var(--red); }
.trace-body {
  max-height: min(58vh, 530px); overflow-y: auto; padding-right: 3px;
  scrollbar-color: var(--border) transparent;
}
.trace-loading, .trace-empty { color: var(--muted); text-align: center; padding: 24px 10px; font-size: 13px; }
.trace-empty.error { color: var(--red); }
.trace-transaction {
  display: grid; grid-template-columns: 36px minmax(0, 1fr) auto; gap: 10px;
  align-items: center; padding: 11px 2px; border-bottom: 1px solid var(--border);
}
.trace-transaction:last-child { border-bottom: 0; }
.trace-transaction-icon {
  width: 36px; height: 36px; display: grid; place-items: center;
  border-radius: 10px; background: var(--panel2); color: var(--red);
}
.trace-transaction-icon.income { color: var(--green); }
.trace-transaction-icon.transfer { color: var(--amber); }
.trace-transaction-icon .ui-icon { width: 19px; height: 19px; }
.trace-transaction-copy { min-width: 0; }
.trace-transaction-copy > b {
  display: block; font-size: 13px; line-height: 1.35; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.trace-transaction-copy > span { display: block; color: var(--muted); font-size: 11px; margin-top: 3px; }
.trace-transaction > strong { font-size: 13px; white-space: nowrap; }
.trace-transaction > strong.income { color: var(--green); }
.trace-transaction > strong.expense { color: var(--red); }
.trace-transaction > strong.transfer { color: var(--amber); }
.trace-plan-link {
  display: inline-flex; align-items: center; gap: 5px; margin-top: 6px; padding: 0;
  background: none; border: 0; color: var(--accent); font-size: 11px; font-weight: 700;
}
.trace-plan-link .ui-icon { width: 14px; height: 14px; }
.trace-plan-meta { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 9px; }
.trace-plan-meta span {
  display: inline-flex; align-items: center; gap: 5px; color: var(--muted);
  background: var(--panel2); border: 1px solid var(--border); border-radius: 999px;
  padding: 5px 8px; font-size: 10px;
}
.trace-plan-meta .ui-icon { width: 13px; height: 13px; color: var(--accent); }
.trace-installments { display: flex; flex-direction: column; }
.trace-installment {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 10px 11px; border-left: 3px solid var(--border); border-bottom: 1px solid var(--border);
}
.trace-installment.current { border-left-color: var(--accent); background: rgba(47,128,255,.07); }
.trace-installment b { display: block; font-size: 13px; }
.trace-installment span { display: block; color: var(--muted); font-size: 11px; margin-top: 3px; }
.trace-installment strong { font-size: 13px; white-space: nowrap; }

/* ===== Escritorio: panel lateral + columnas ===== */
@media (min-width: 900px) {
  body { font-size: 15px; }
  .sidebar {
    display: flex; flex-direction: column; width: 250px; flex-shrink: 0;
    background: var(--bg2); border-right: 1px solid var(--border);
    padding: 22px 16px; position: sticky; top: 0; height: 100vh;
  }
  .side-nav { overflow-y: auto; min-height: 0; padding-right: 2px; }
  .sidebar-brand-logo { display: block; width: 150px; height: auto; }
  .welcome { margin: 22px 0 18px; font-size: 16px; font-weight: 600; }
  .welcome { overflow-wrap: anywhere; }
  .welcome small { display: block; color: var(--muted); font-size: 12px; font-weight: 400; margin-top: 4px; }
  .nav-section { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: 1px; margin: 16px 8px 8px; }
  .snav { display: flex; align-items: center; gap: 10px; width: 100%; text-align: left; background: none; border: none; color: var(--muted); padding: 11px 12px; border-radius: 12px; font-size: 14px; font-weight: 600; margin-bottom: 2px; }
  .snav .ui-icon { width: 19px; height: 19px; }
  .snav:hover { background: var(--panel); color: var(--txt); }
  .snav.active { background: var(--accent); color: #fff; }
  .side-add { margin-top: auto; background: linear-gradient(135deg, var(--accent), var(--accent2)); color: #fff; border: none; padding: 13px; border-radius: 12px; font-weight: 700; font-size: 14px; display: flex; align-items: center; justify-content: center; gap: 8px; }
  .side-add .ui-icon { width: 21px; height: 21px; }

  .mainwrap { padding: 0 24px 24px; max-width: 1280px; margin: 0 auto; }
  .topbar { padding: 16px 0; }
  .bottomnav { display: none; }
  .panel { padding: 14px; margin-bottom: 12px; }
  .panel-head { margin-bottom: 11px; }

  /* dos columnas */
  .grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 16px; align-items: start; }
  .col-main, .col-side { display: flex; flex-direction: column; }
  .hero-balances { grid-template-columns: repeat(4, 1fr); }
  #view-presupuestos .panel { max-width: 820px; }
  .tx-tools-main { grid-template-columns: minmax(0, 1fr); }
  .tx-filter-toggle { display: none; }
  .tx-filters { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr 1fr; }
  .tx-filters label:nth-child(3) { grid-column: auto; }
  #view-reportes .panel { max-width: none; }
  .report-toolbar { padding: 10px 12px; }
  .report-toolbar-main { justify-content: flex-start; }
  .report-filter-toggle { display: none; }
  .report-filter-panel {
    display: grid; grid-template-columns: minmax(0, 1fr);
    align-items: end; gap: 8px; margin-top: 8px;
  }
  .report-controls { grid-template-columns: repeat(5, minmax(0, 1fr)); }
  .report-overview-grid { grid-template-columns: minmax(0, 1.7fr) minmax(310px, .9fr); gap: 12px; }
  .report-view-tabs { margin-top: -2px; }
  .smart-grid { grid-template-columns: minmax(0, 1fr); gap: 20px; }
  .smart-rules-panel { max-width: 780px; }
  .payable-kpis { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
  .payable-toolbar { flex-direction: row; align-items: end; justify-content: space-between; }
  .payable-filters { width: min(420px, 50%); }
  .payable-toolbar-actions { display: flex; align-items: center; }
  .payable-grid { grid-template-columns: minmax(0, 1.7fr) minmax(280px, .8fr); }
  .bill-card-main { grid-template-columns: 4px minmax(0, 1fr) auto; align-items: center; }
  .bill-amount { grid-column: 3; grid-row: 1; text-align: right; margin: 0; }
  .movement-form { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px 12px; }
  .movement-form #grp-transfer { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .movement-more-fields { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1200px) {
  .hero-balances { grid-template-columns: repeat(5, 1fr); }
  .report-toolbar {
    display: grid; grid-template-columns: auto minmax(0, 1fr); align-items: end; gap: 12px;
  }
  .report-filter-panel {
    grid-template-columns: minmax(0, 1fr) minmax(180px, 220px); margin-top: 0;
  }
  .smart-import-controls { grid-template-columns: minmax(180px, 1.3fr) minmax(145px, 1fr) minmax(145px, 1fr) auto; }
  .import-summary { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .import-row {
    grid-template-columns: 28px minmax(170px, 1.5fr) minmax(90px, .65fr) minmax(120px, .9fr) minmax(110px, .9fr) minmax(95px, .65fr);
    align-items: end;
  }
  .import-main { grid-column: auto; }
  .import-row > label:not(.import-check) { grid-column: auto; }
}
@media (max-width: 560px) {
  .mainwrap { padding-inline: 12px; }
  .topbar { padding-inline: 2px; }
  #view-movimientos > .panel, #view-pagos .panel { padding: 12px; }
  .payable-kpis { gap: 8px; margin-bottom: 12px; }
  .payable-kpi { padding: 11px; }
  .payable-kpi b { font-size: 16px; }
  .payable-toolbar { gap: 10px; }
  .payable-filters { gap: 8px; }
  .payable-filters select, .payable-filters input { padding: 9px; font-size: 13px; }
  .payable-toolbar-actions { gap: 8px; }
  .payable-toolbar-actions button { min-height: 42px; padding: 9px 7px; font-size: 12px; }
  .bill-card-main { gap: 9px; padding: 12px 10px 9px 0; }
  .bill-copy p { margin-block: 4px 7px; }
  .report-kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
  .report-chart-wrap { height: 275px; }
  .report-view-tabs { width: 100%; }
  .report-view-tabs button { flex: 1; min-width: 0; padding-inline: 6px; }
  .report-distribution-content { grid-template-columns: 125px minmax(0, 1fr); gap: 9px; }
  .report-donut-wrap { height: 135px; }
  .report-donut-wrap canvas { max-height: 135px; }
  .report-donut-total { font-size: 14px; }
  .report-category-popover { position: fixed; top: 118px; left: 16px; right: 16px; width: auto; max-height: calc(100vh - 150px); }
  .report-cats { grid-template-columns: 1fr; }
  .movement-modal-box {
    max-height: calc(100vh - 24px); padding: 14px; border-radius: 14px;
  }
  .movement-modal-box .modal-top h3 { font-size: 17px; }
  .movement-modal-box .seg { margin-bottom: 9px; }
  .movement-form { gap: 8px; }
  .movement-form input, .movement-form select { min-height: 40px; padding: 9px 10px; }
  .movement-form #f-amount { min-height: 52px; font-size: 22px; }
  .movement-more-toggle { min-height: 38px; }
  .movement-save { min-height: 42px; }
  .tx-panel-head h2 { font-size: 14px; }
  .tx-tools-main { gap: 7px; }
  .tx-filter-toggle { padding-inline: 10px; }
  .tx-filter-toggle > span:not(.ui-icon) { display: none; }
  .tx-filters { padding-top: 2px; }
  .import-footer { align-items: stretch; flex-direction: column; }
  .import-footer button { width: 100%; }
  .tx { gap: 8px; }
  .tx .ic { width: 36px; height: 36px; border-radius: 10px; }
  .tx .amt { font-size: 14px; }
  .tx-actions { flex-direction: column; gap: 0; }
  .tx-action { width: 28px; height: 28px; }
  .trace-modal-box { max-height: calc(100vh - 24px); padding: 14px; border-radius: 14px; }
  .trace-modal-top h3 { font-size: 17px; }
  .trace-summary { gap: 6px; }
  .trace-stat { padding: 9px; }
  .trace-stat b { font-size: 13px; }
  .trace-body { max-height: calc(100vh - 220px); }
  .trace-transaction { grid-template-columns: 32px minmax(0, 1fr) auto; gap: 8px; }
  .trace-transaction-icon { width: 32px; height: 32px; }
  .trace-transaction-copy > b { max-width: 100%; }
  .trace-transaction > strong { font-size: 12px; }
  .trace-installment { padding-inline: 9px; }
}
@media (min-width: 560px) and (max-width: 899px) {
  .report-kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* ===== Resumen compacto en celular (que entren patrimonio y "Este mes") ===== */
@media (max-width: 560px) {
  .hero { padding: 12px; }
  .hero-head { margin-bottom: 8px; font-size: 12px; }
  .hero-balances { gap: 8px; }
  .hbal { padding: 9px 10px; border-radius: 12px; }
  .hbal .n { font-size: 11px; }
  .hbal .v { font-size: 16px; margin-top: 2px; }
  .hero-visibility-edit { min-height: 29px; padding: 5px 8px; }
  .month-totals { gap: 8px; }
  .mt { padding: 10px 6px; border-radius: 12px; }
  .mt .lbl { font-size: 11px; }
  .mt .val { font-size: 13px; }
}

/* ===== Resumen (compu): el gráfico llena el alto para no dejar hueco ===== */
@media (min-width: 1000px) {
  #view-inicio .col-main { display: flex; flex-direction: column; gap: 12px; }
  #view-inicio .col-main > * { margin-bottom: 0; }
  #view-inicio .col-main > .panel:last-child { flex: 1 1 auto; display: flex; flex-direction: column; }
  #view-inicio .col-main > .panel:last-child .chart-wrap { flex: 1 1 auto; height: auto; min-height: 260px; }
}

/* ===== Tooltips de ayuda (circulito con !) ===== */
.panel, .hero { position: relative; }
.help-dot {
  position: absolute; top: 13px; right: 13px; z-index: 3;
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px; border-radius: 50%; padding: 0; margin: 0;
  font-size: 10px; font-weight: 800; line-height: 1; cursor: help;
  background: rgba(47,128,255,.15); color: var(--accent); border: 1px solid rgba(47,128,255,.45);
  flex: 0 0 auto;
}
.help-dot:hover { background: rgba(47,128,255,.3); }
/* Reserva un huequito en la esquina para que el "!" no pise los botones del encabezado. */
.panel-head:has(.help-dot), .hero-head:has(.help-dot) { padding-right: 26px; }
.help-tip {
  position: fixed; z-index: 400; max-width: 260px;
  background: var(--bg2); border: 1px solid var(--border); border-radius: 10px;
  padding: 10px 12px; font-size: 13px; line-height: 1.5; color: var(--txt);
  box-shadow: 0 14px 36px rgba(0,0,0,.5);
}
.help-tip.hidden { display: none; }

/* ===== Alturas uniformes en barras de filtros y acciones ===== */
.smart-import-controls input,
.smart-import-controls select,
.smart-import-controls button,
.payable-filters select,
.payable-filters input,
.payable-toolbar-actions button,
.report-controls input,
.report-controls select,
.report-category-toggle,
.report-quick-ranges button,
.report-filter-toggle,
.tx-filters select,
.tx-filters input,
.tx-search input,
.tx-filter-toggle {
  height: 44px;
  min-height: 44px;
  box-sizing: border-box;
}
.smart-import-controls input[type="file"] { padding-top: 0; padding-bottom: 0; line-height: 42px; }
.report-quick-ranges { min-height: 44px; }
.report-quick-ranges button,
.payable-toolbar-actions button,
.smart-import-controls button {
  display: inline-flex; align-items: center; justify-content: center;
}

/* ===== Config con pestañas y categorías agrupadas ===== */
.config-panel { display: flex; flex-direction: column; gap: 14px; }
.config-tabs { align-self: stretch; }
.config-tabs button { flex: 1; min-width: 0; }
.config-pane { display: none; }
.config-pane.active { display: block; }
.category-groups-grid {
  display: grid; grid-template-columns: minmax(0, 1fr); gap: 18px;
}
.category-group { min-width: 0; }
.cat-group-head {
  display: flex; align-items: center; gap: 8px; margin: 0 2px 8px;
  color: var(--muted); font-size: 13px; font-weight: 750; letter-spacing: 0;
}
.cat-group-head .ui-icon { width: 16px; height: 16px; }
.cat-group-head.income { color: var(--green); }
.cat-group-head.expense { color: var(--red); }
.cat-group-head.both { color: #a6afc1; }
.cat-group-head b { margin-left: auto; font-weight: 700; opacity: .8; }
.category-group-list { display: flex; flex-direction: column; gap: 8px; }
.category-admin-row {
  min-height: 54px; margin: 0; padding: 9px 10px 9px 14px;
  border: 1px solid var(--border) !important; border-radius: 12px;
}
.category-admin-row.income {
  background: rgba(34,197,94,.065);
  border-color: rgba(34,197,94,.25) !important;
}
.category-admin-row.expense {
  background: rgba(244,86,108,.06);
  border-color: rgba(244,86,108,.24) !important;
}
.category-admin-row.both {
  background: rgba(166,175,193,.07);
  border-color: rgba(166,175,193,.2) !important;
}
.category-admin-row .label-icon { gap: 10px; }
.category-admin-row .label-icon b { overflow-wrap: anywhere; }
.category-admin-row .admin-actions { gap: 6px; }
.admin-actions .ed, .admin-actions .de {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px; border-radius: 9px; padding: 0;
}
.admin-actions .ui-icon { width: 18px; height: 18px; }
@media (min-width: 900px) {
  .category-groups-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: start; }
  .category-group.income { grid-column: 1; grid-row: 1; }
  .category-group.expense { grid-column: 2; grid-row: 1 / span 2; }
  .category-group.both { grid-column: 1; grid-row: 2; }
}

/* ===== Resumen: dólar arriba en celular, lateral en compu ===== */
.inicio-dolar-side { display: none; }
.inicio-dolar-top { display: flex; gap: 8px; margin-bottom: 14px; }
.inicio-dolar-top .dol { padding: 8px 6px; border-radius: 12px; }
.inicio-dolar-top .dol .dl { font-size: 10px; }
.inicio-dolar-top .dol .dv { font-size: 14px; margin-top: 2px; }
.inicio-budgets { margin-top: 16px; }
@media (min-width: 1000px) {
  .inicio-dolar-top { display: none; }
  .inicio-dolar-side { display: flex; }
}

/* ===== Total centrado en las tortas (que entre bien) ===== */
.report-donut-total { font-size: 15px; }
.report-donut-total span { display: block; max-width: 94%; margin: 0 auto; }
.chart-cat-wrap { position: relative; }
.chart-cat-total {
  position: absolute; left: 0; right: 0; top: 0; bottom: 40px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  pointer-events: none; text-align: center; font-weight: 850; font-size: 15px; line-height: 1.1;
}
.chart-cat-total span { display: block; max-width: 80%; }
.chart-cat-total small { display: block; color: var(--muted); font-weight: 600; font-size: 11px; margin-top: 4px; }
@media (max-width: 560px) {
  .report-donut-wrap { height: 160px; }
  .report-donut-wrap canvas { max-height: 160px; }
  .report-donut-total { font-size: 13px; }
  .chart-cat-total { font-size: 14px; }
}
