  :root{
    --blue:#0a3d91;--blue2:#0f56c9;--blue3:#1877f2;
    --teal:#16c6a4;--pink:#e91e63;--bg:#f6f8fb;
    --ink:#0b2a4a;--muted:#5a6b85;--line:#e6ebf2;
    --amber:#ffb547;--purple:#7c5cff;
  }
  *{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
  html,body{margin:0;padding:0;background:#e9edf2;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,sans-serif;color:var(--ink)}
  .stage{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;gap:24px;flex-wrap:wrap}
  /* Contador de reset de MIA, fuera del teléfono. */
  .mia-reset-meter{align-self:center;width:240px;display:flex;align-items:flex-start;gap:10px;
    background:#fff;border:1px solid #e6e9f4;border-radius:16px;padding:14px 16px;
    box-shadow:0 12px 30px rgba(30,40,90,.10);font-family:inherit}
  .mia-reset-meter .mrm-dot{flex:0 0 10px;width:10px;height:10px;border-radius:50%;margin-top:4px;background:#c9cfdd}
  .mia-reset-meter.live .mrm-dot{background:#16c6a4;box-shadow:0 0 0 4px rgba(22,198,164,.18);animation:mrm-pulse 1.6s ease-in-out infinite}
  .mia-reset-meter:not(.live):not(.done) .mrm-dot{background:#3a7bff;animation:mrm-pulse 1s linear infinite}
  .mia-reset-meter.done .mrm-dot{background:#7c5cff}
  .mia-reset-meter .mrm-body{display:flex;flex-direction:column;gap:3px;min-width:0}
  .mia-reset-meter .mrm-body b{font-size:14px;font-weight:800;color:#1c2438;font-variant-numeric:tabular-nums}
  .mia-reset-meter .mrm-body span{font-size:11px;color:#8590a8;line-height:1.35}
  @keyframes mrm-pulse{0%,100%{opacity:1}50%{opacity:.35}}
  .phone{width:390px;height:820px;background:#fff;border-radius:42px;box-shadow:0 30px 70px rgba(10,40,90,.18),0 8px 18px rgba(10,40,90,.08);position:relative;overflow:hidden;border:10px solid #111}
  .notch{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:120px;height:28px;background:#111;border-radius:20px;z-index:30}
  .screen{position:absolute;inset:0;display:flex;flex-direction:column;background:#fff}
  .statusbar{height:44px;display:flex;justify-content:space-between;align-items:center;padding:0 26px;font-weight:600;font-size:15px}
  .statusbar .right{display:flex;align-items:center;gap:5px}
  .bars{display:flex;align-items:flex-end;gap:2px;height:12px}
  .bars i{width:3px;background:#111;border-radius:1px;display:block}
  .bars i:nth-child(1){height:4px}.bars i:nth-child(2){height:6px}.bars i:nth-child(3){height:9px}.bars i:nth-child(4){height:12px}
  .batt{width:24px;height:12px;border:1.5px solid #111;border-radius:3px;position:relative;padding:1px}
  .batt::after{content:"";position:absolute;right:-3px;top:3px;width:2px;height:6px;background:#111;border-radius:1px}
  .batt i{display:block;height:100%;background:#111;border-radius:1px}
  .content{flex:1;overflow-y:auto;padding:0 22px 110px}
  .content::-webkit-scrollbar{display:none}

  /* HOME */
  .header{display:flex;align-items:center;gap:12px;padding:6px 0 10px}
  .avatar{width:48px;height:48px;border-radius:50%;background:#fbe0ec;color:#c2185b;display:grid;place-items:center;font-weight:700;font-size:15px}
  .hello{flex:1}
  .hello h2{margin:0;font-size:20px;font-weight:700}
  .hello a{color:var(--blue3);font-size:14px;font-weight:600}
  .help{background:#e9f1ff;color:var(--blue3);border:0;border-radius:22px;padding:8px 14px;font-weight:600;font-size:14px;display:flex;align-items:center;gap:6px}
  .reset-btn{background:#fff0f0;color:var(--pink);border:0;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;cursor:pointer;font-size:18px;flex:0 0 38px}
  .reset-btn:active{transform:scale(.92)}
  .saldo-card{background:#fff;border-radius:18px;padding:14px 0 10px;text-align:center;box-shadow:0 8px 24px rgba(10,40,90,.06);margin-top:6px}
  .saldo-card .lbl{color:var(--blue3);font-weight:700;letter-spacing:.18em;font-size:13px}
  .chev{color:var(--blue3);font-size:20px;line-height:1}
  .actions{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:22px 0 18px}
  .action{display:flex;flex-direction:column;align-items:center;gap:8px}
  .action .ic{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;color:#fff}
  .action .ic.blue{background:var(--blue2)}.action .ic.teal{background:var(--teal)}
  .action span{font-size:13px;font-weight:600}
  .banner{background:linear-gradient(135deg,#dff0ff,#bfe0ff);border-radius:18px;padding:18px;display:flex;align-items:center;justify-content:space-between;min-height:130px}
  .banner h3{margin:0;font-size:26px;font-weight:800;line-height:1.05;color:#0b2a4a}
  .vermas{display:inline-block;margin-top:10px;background:#0b2a4a;color:#fff;padding:5px 12px;border-radius:14px;font-size:12px;font-weight:600}
  .qr-card{background:#fff;border-radius:12px;padding:10px 14px;text-align:center;box-shadow:0 6px 14px rgba(0,0,0,.08);position:relative}
  .badge{position:absolute;top:-8px;right:-6px;background:#ffb547;color:#4a2b00;font-size:10px;font-weight:700;padding:2px 8px;border-radius:6px}
  .dots{display:flex;justify-content:center;gap:6px;margin:14px 0 6px}
  .dots i{width:6px;height:6px;border-radius:50%;background:#cfe0f5;display:block}
  .dots i.on{background:var(--blue3);width:8px;height:8px}
  .section-title{font-size:18px;font-weight:700;margin:18px 0 10px}
  .cards-row{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}
  .cards-row::-webkit-scrollbar{display:none}
  .flat-card{flex:0 0 108px;height:118px;background:#fff;border-radius:14px;box-shadow:0 6px 16px rgba(10,40,90,.06);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;position:relative}
  .flat-card span{font-size:14px;font-weight:600;text-align:center;line-height:1.1}
  .services{display:flex;gap:10px;overflow-x:auto;padding:4px 0 2px}
  .services::-webkit-scrollbar{display:none}
  .srv{flex:0 0 70px;height:70px;border-radius:14px;background:#fff;box-shadow:0 6px 16px rgba(10,40,90,.06);display:grid;place-items:center;font-weight:700;font-size:12px}

  .tabbar{position:absolute;left:0;right:0;bottom:0;height:86px;background:#fff;border-top-left-radius:24px;border-top-right-radius:24px;box-shadow:0 -6px 20px rgba(10,40,90,.08);display:flex;align-items:center;justify-content:space-around;padding:0 10px 14px}
  .tab{display:flex;flex-direction:column;align-items:center;gap:4px;color:#6b7a92;font-size:12px;font-weight:600;background:none;border:0;cursor:pointer;padding:6px 8px}
  .tab.active{color:var(--blue3)}
  .tab.center{position:relative;top:-22px}
  .tab.center .bub{width:62px;height:62px;border-radius:50%;background:var(--blue3);display:grid;place-items:center;color:#fff;box-shadow:0 10px 22px rgba(24,119,242,.4)}

  /* MOVIMIENTOS */
  .back{background:none;border:0;color:var(--blue3);font-size:28px;padding:8px 0;cursor:pointer}
  .title{font-size:34px;font-weight:800;margin:4px 0 14px}

  .summary{background:linear-gradient(135deg,#0f56c9,#1877f2);color:#fff;border-radius:18px;padding:16px;margin-bottom:14px;box-shadow:0 10px 24px rgba(15,86,201,.25)}
  .summary .row{display:flex;justify-content:space-between;align-items:center}
  .summary .lbl{font-size:12px;opacity:.85;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
  .summary .month{font-size:14px;font-weight:700}
  .summary .big{font-size:26px;font-weight:800;margin-top:4px}
  .summary .sub{display:flex;justify-content:space-between;margin-top:12px;gap:10px}
  .summary .sub div{flex:1;background:rgba(255,255,255,.12);border-radius:12px;padding:10px}
  .summary .sub small{font-size:11px;opacity:.85;display:block}
  .summary .sub b{font-size:15px;font-weight:700}
  .summary .bar{height:6px;background:rgba(255,255,255,.18);border-radius:3px;margin-top:10px;overflow:hidden;display:flex}
  .summary .bar i{display:block;height:100%}
  .summary .delta{font-size:11px;margin-top:6px;opacity:.9}

  .insight{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;margin-bottom:14px;display:flex;gap:12px;position:relative;box-shadow:0 6px 18px rgba(10,40,90,.05)}
  .insight .icwrap{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#ffecd1,#ffd28a);display:grid;place-items:center;flex-shrink:0;font-size:22px}
  .insight .body{flex:1;min-width:0}
  .insight .tag{font-size:10px;color:var(--amber);font-weight:800;letter-spacing:.1em;text-transform:uppercase}
  .insight h4{margin:2px 0 4px;font-size:14px;font-weight:700;line-height:1.25}
  .insight p{margin:0;font-size:13px;color:var(--muted);line-height:1.35}
  .insight .actions-row{margin-top:10px;display:flex;gap:8px}
  .insight button.primary{background:var(--blue3);color:#fff;border:0;padding:7px 14px;border-radius:20px;font-weight:700;font-size:12px;cursor:pointer}
  .insight button.ghost{background:#eef3fb;color:var(--blue3);border:0;padding:7px 12px;border-radius:20px;font-weight:700;font-size:12px;cursor:pointer}
  .insight button.ghost.sel{background:var(--blue3);color:#fff}
  .insight .close{position:absolute;top:8px;right:10px;background:none;border:0;color:#9aa6b7;font-size:18px;cursor:pointer}

  .search{display:flex;align-items:center;gap:8px;background:#f1f4f9;border-radius:12px;padding:10px 12px;margin-bottom:10px}
  .search input{flex:1;background:transparent;border:0;outline:0;font-size:14px;color:var(--ink)}
  .chips{display:flex;gap:8px;overflow-x:auto;padding:4px 0 12px;margin:0 -22px;padding-left:22px;padding-right:22px}
  .chips::-webkit-scrollbar{display:none}
  .chip{flex:0 0 auto;padding:7px 14px;border-radius:20px;background:#f1f4f9;border:0;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;white-space:nowrap}
  .chip.on{background:var(--blue3);color:#fff}

  .daygroup{margin-top:4px}
  .dayhdr{font-size:14px;font-weight:700;margin:14px 0 6px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
  .mov{display:flex;align-items:center;gap:12px;padding:10px 0;cursor:pointer;border-bottom:1px solid #f0f3f8}
  .mov:last-child{border-bottom:0}
  .mov .ic{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex:0 0 42px}
  .mov .ic.qr{background:#0f56c9;color:#fff}
  .mov .ic.bn{background:#e3f6c6;color:#4a7a2b;font-weight:800;font-size:12px}
  .mov .ic.shell{background:#f2a93a;color:#fff}
  .mov .mid{flex:1;min-width:0}
  .mov .mid b{display:block;font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mov .mid .meta{display:flex;gap:6px;align-items:center;margin-top:3px;flex-wrap:wrap}
  .mov .mid small{color:var(--muted);font-size:12px}
  .cat{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;text-transform:uppercase;letter-spacing:.04em}
  .cat.super{background:#fde2ec;color:#c2185b}
  .cat.comb{background:#fff1d6;color:#a76b00}
  .cat.trans{background:#d7f5ea;color:#1a8f6a}
  .cat.rest{background:#e6e3ff;color:#5a3dd6}
  .cat.otros{background:#eef2f7;color:#5a6b85}
  .rec{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;background:#e9f1ff;color:var(--blue3);display:inline-flex;align-items:center;gap:3px}
  .amt{font-weight:700;font-size:14px;white-space:nowrap}
  .amt.neg{color:var(--pink)}.amt.pos{color:var(--teal)}
  .kebab{color:#9aa6b7;padding:6px 2px 6px 8px;font-size:18px;line-height:.3;letter-spacing:1px}

  .insights-link{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#f6f2ff,#eaf3ff);border:1px solid #e0d7ff;border-radius:14px;padding:12px 14px;margin:6px 0 14px;cursor:pointer}
  .insights-link b{font-size:13px;font-weight:700}
  .insights-link small{font-size:11px;color:var(--muted);display:block;margin-top:2px}

  /* modal detail */
  .sheet-bg{position:absolute;inset:0;background:rgba(11,42,74,.45);z-index:40;display:flex;align-items:flex-end}
  .sheet{background:#fff;width:100%;border-top-left-radius:24px;border-top-right-radius:24px;padding:18px 22px 28px;max-height:80%;overflow-y:auto;animation:up .22s ease}
  @keyframes up{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
  .sheet .grab{width:42px;height:4px;background:#dbe3ee;border-radius:2px;margin:0 auto 12px}
  .sheet h3{margin:6px 0 2px;font-size:20px;font-weight:800}
  .sheet .amtbig{font-size:26px;font-weight:800;margin:8px 0 14px}
  .sheet .row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid #f0f3f8;font-size:14px}
  .sheet .row span:first-child{color:var(--muted)}
  .sheet .ai{background:linear-gradient(135deg,#eaf3ff,#f6f2ff);border-radius:14px;padding:12px;margin-top:14px;font-size:13px;display:flex;gap:10px}
  .sheet .ai .spark{font-size:22px}
  .sheet .ai b{display:block;font-weight:700;margin-bottom:2px}

  /* insights screen */
  .ins-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin-bottom:10px}
  .ins-card .t{font-size:13px;font-weight:700}
  .ins-card .d{font-size:12px;color:var(--muted);margin:3px 0 8px}
  .ins-card .fb{display:flex;gap:6px}
  .ins-card .fb button{background:#f1f4f9;border:0;border-radius:18px;padding:5px 12px;font-size:13px;cursor:pointer}
  .ins-card .fb button.sel{background:var(--blue3);color:#fff}
  .ins-card .stamp{font-size:10px;color:#9aa6b7;text-transform:uppercase;letter-spacing:.08em;font-weight:700}

  /* AVATAR PULSE */
  .avpulse{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#fff,#f6f2ff);border:1px solid #e0d7ff;border-radius:16px;padding:10px 14px;margin-bottom:12px;cursor:pointer;box-shadow:0 6px 16px rgba(124,92,255,.08)}
  .avpulse .face{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#eaf3ff,#f6e8ff);display:grid;place-items:center;font-size:30px;flex:0 0 56px;box-shadow:inset 0 0 0 2px #fff}
  .avpulse .body{flex:1;min-width:0}
  .avpulse .trait{font-size:11px;color:var(--purple);font-weight:800;letter-spacing:.1em;text-transform:uppercase}
  .avpulse .phrase{font-size:13px;font-weight:600;color:var(--ink);margin-top:2px;line-height:1.3}
  .avpulse .chev{color:var(--purple);font-size:22px;font-weight:700}

  /* PERSONALITY SHEET */
  .psh-trait{margin:10px 0}
  .psh-trait .lbl{display:flex;justify-content:space-between;font-size:13px;font-weight:600;margin-bottom:4px}
  .psh-bar{height:8px;background:#f1f4f9;border-radius:4px;overflow:hidden}
  .psh-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--purple),var(--blue3));border-radius:4px}
  .psh-spark{display:flex;align-items:flex-end;gap:4px;height:48px;margin:8px 0 4px}
  .psh-spark i{flex:1;background:linear-gradient(180deg,var(--purple),#cfb9ff);border-radius:3px;display:block}
  .psh-cohort{background:#eaf3ff;border-radius:12px;padding:12px;font-size:13px;margin-top:14px}
  .psh-cohort b{color:var(--blue3)}
  .psh-share{margin-top:16px;width:100%;background:var(--blue3);color:#fff;border:0;border-radius:22px;padding:12px;font-weight:700;font-size:14px;cursor:pointer}

  /* TIMELINE FUTURO */
  .tl-section{font-size:11px;font-weight:800;letter-spacing:.1em;color:var(--muted);margin:18px 0 4px;text-transform:uppercase}
  .tl-balance{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#f0fff7,#e0f7ee);border:1px solid #c5ecda;border-radius:12px;padding:10px 14px;margin:6px 0 10px;font-size:13px}
  .tl-balance.warn{background:linear-gradient(135deg,#fff8eb,#ffefcc);border-color:#ffd99c}
  .tl-balance.bad{background:linear-gradient(135deg,#fff0f0,#ffd9d9);border-color:#ffb0b0}
  .tl-balance b{font-size:15px;font-weight:800}
  .tl-today{position:sticky;top:0;background:#fff;z-index:5;text-align:center;font-size:12px;font-weight:800;letter-spacing:.12em;color:var(--blue3);padding:10px 0;margin:8px 0 4px;border-top:2px solid var(--blue3);border-bottom:2px solid var(--blue3)}
  .mov.phantom{opacity:.6;border-left:2px dashed var(--purple);padding-left:8px;margin-left:-10px}
  .ghost-tag{font-size:14px;margin-left:4px}
  .conf-pill{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;background:#f0e7ff;color:var(--purple);text-transform:uppercase;letter-spacing:.04em}

  /* VIEW SCOPE LABEL */
  .vscope{font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px;display:flex;align-items:center;gap:6px}
  .vscope .dot{width:6px;height:6px;border-radius:50%;background:var(--blue3);display:inline-block}

  /* VIEW CHIPS (segmented) */
  .topbar{display:flex;align-items:center;gap:10px;padding:6px 0 12px}
  .topbar .back{flex:0 0 auto;margin:0}
  .topbar .vchips{flex:1;min-width:0;margin:0;padding:2px 0}
  .vchips{display:flex;gap:8px;overflow-x:auto;padding:6px 0 14px;margin:4px -22px 0;padding-left:22px;padding-right:22px}
  .vchips::-webkit-scrollbar{display:none}
  .vchip{flex:0 0 auto;display:flex;align-items:center;gap:6px;padding:9px 14px;border-radius:22px;background:#f1f4f9;border:0;font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;white-space:nowrap;transition:all .15s}
  .vchip .em{font-size:15px;line-height:1}
  /* Ícono de MIA en su pestaña: la imagen reemplaza al emoji a tamaño glifo. */
  .vchip .em-mia{width:20px;height:20px;border-radius:50%;object-fit:cover;display:block;margin:-2px 0}
  .vchip.on{background:var(--blue3);color:#fff;box-shadow:0 6px 14px rgba(24,119,242,.3)}

  /* CATEGORIES VIEW */
  .donut-wrap{display:flex;align-items:center;gap:18px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;margin-bottom:14px;box-shadow:0 6px 16px rgba(10,40,90,.05)}
  .donut-svg{flex:0 0 120px;width:120px;height:120px;position:relative}
  .donut-center{position:absolute;inset:0;display:grid;place-items:center;text-align:center}
  .donut-center .lbl{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em}
  .donut-center .val{font-size:14px;font-weight:800;margin-top:2px}
  .donut-legend{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}
  .donut-legend .it{display:flex;align-items:center;gap:8px;font-size:13px}
  .donut-legend .sw{width:10px;height:10px;border-radius:3px;flex:0 0 10px}
  .donut-legend b{font-weight:700;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .donut-legend .pct{font-weight:700;color:var(--muted)}

  .cat-list{display:flex;flex-direction:column;gap:8px}
  .cat-row{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;display:flex;align-items:center;gap:12px;cursor:pointer}
  .cat-row .ic{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-size:18px;flex:0 0 38px}
  .cat-row .mid{flex:1;min-width:0}
  .cat-row .mid b{display:block;font-size:14px;font-weight:700}
  .cat-row .bar2{height:5px;background:#f1f4f9;border-radius:3px;margin-top:6px;overflow:hidden}
  .cat-row .bar2 i{display:block;height:100%;border-radius:3px}
  .cat-row .amt{font-size:14px;font-weight:800;text-align:right}
  .cat-row .amt small{display:block;font-size:11px;color:var(--muted);font-weight:600}

  /* TOP VIEW */
  .rank-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #f0f3f8;cursor:pointer}
  .rank-row:last-child{border-bottom:0}
  .rank-row .num{width:28px;height:28px;border-radius:50%;background:#f1f4f9;color:var(--muted);font-weight:800;font-size:13px;display:grid;place-items:center;flex:0 0 28px}
  .rank-row .num.gold{background:#fff3d1;color:#a76b00}
  .rank-row .num.silver{background:#eef2f7;color:#5a6b85}
  .rank-row .num.bronze{background:#ffe4d1;color:#a04a00}

  /* CASHFLOW VIEW */
  .cf-toggle{display:flex;background:#f1f4f9;border-radius:14px;padding:3px;margin-bottom:12px;gap:2px}
  .cf-toggle button{flex:1;background:none;border:0;padding:8px;border-radius:11px;font-size:12px;font-weight:700;color:var(--muted);cursor:pointer}
  .cf-toggle button.on{background:#fff;color:var(--blue3);box-shadow:0 2px 6px rgba(10,40,90,.08)}
  .cf-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
  .cf-kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px;text-align:center}
  .cf-kpi small{font-size:10px;color:var(--muted);font-weight:700;letter-spacing:.06em;text-transform:uppercase;display:block;margin-bottom:4px}
  .cf-kpi b{font-size:13px;font-weight:800;display:block}
  .cf-kpi b.pos{color:var(--teal)}
  .cf-kpi b.neg{color:var(--pink)}
  .cf-kpi b.net.pos{color:var(--teal)}
  .cf-kpi b.net.neg{color:var(--pink)}

  .cf-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:0 6px 16px rgba(10,40,90,.05)}
  .cf-legend{display:flex;gap:14px;font-size:11px;color:var(--muted);font-weight:600;margin-bottom:10px}
  .cf-legend .dot{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:5px;vertical-align:middle}
  .cf-bars{display:flex;align-items:flex-end;justify-content:space-between;gap:4px;height:170px;border-bottom:1px solid var(--line);padding-bottom:4px;margin-bottom:6px;position:relative}
  .cf-week{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;height:100%;justify-content:flex-end;position:relative}
  .cf-net{position:absolute;top:-14px;font-size:9px;font-weight:800;color:var(--ink);white-space:nowrap}
  .cf-net.neg{color:var(--pink)}
  .cf-pair{display:flex;align-items:flex-end;gap:3px;width:100%;justify-content:center;height:calc(100% - 14px)}
  .cf-bar{width:12px;border-radius:4px 4px 0 0;min-height:4px;transition:opacity .15s}
  .cf-bar.in{background:var(--teal)}
  .cf-bar.out{background:var(--pink)}
  .cf-week:hover .cf-bar{opacity:.85}
  .cf-week.best{background:linear-gradient(180deg,transparent 60%,#d7f5ea 100%);border-radius:6px}
  .cf-week.worst{background:linear-gradient(180deg,transparent 60%,#fde2e7 100%);border-radius:6px}
  .cf-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
  .cf-labels span{flex:1;text-align:center}

  .cf-highlights{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .cf-hl{padding:10px;border-radius:12px;font-size:12px}
  .cf-hl b{display:block;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-bottom:3px}
  .cf-hl.best{background:#d7f5ea;color:#1a8f6a}
  .cf-hl.worst{background:#fde2e7;color:#c2185b}

  .cf-avg{margin-top:10px;padding:10px 12px;background:#f6f8fb;border-radius:12px;font-size:12px;color:var(--muted);display:flex;justify-content:space-between}
  .cf-avg b{color:var(--ink);font-weight:800}

  /* FUTURE VIEW */
  .fc-hero{background:linear-gradient(135deg,#7c5cff,#1877f2);color:#fff;border-radius:18px;padding:18px;margin-bottom:14px;box-shadow:0 12px 28px rgba(124,92,255,.25)}
  .fc-hero .lbl{font-size:11px;opacity:.85;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
  .fc-hero .big{font-size:28px;font-weight:800;margin-top:4px}
  .fc-hero .sub{font-size:12px;opacity:.85;margin-top:6px}
  .fc-hero.bad{background:linear-gradient(135deg,#e91e63,#b71c4d)}
  .fc-hero.warn{background:linear-gradient(135deg,#ffa726,#fb8c00)}

  /* WELCOME SHEET */
  .wel-hero{text-align:center;padding:2px 0 0}
  /* MIA presentándose: avatar grande en loop arriba del título. */
  .wel-mia{width:76px;height:76px;margin:0 auto 8px;border-radius:50%;overflow:hidden;
    box-shadow:0 0 0 3px rgba(24,119,242,.30),0 14px 34px rgba(20,60,120,.28);animation:mia-breathe 3.4s ease-in-out infinite}
  .wel-mia video{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%;pointer-events:none}
  .wel-hero .badge2{display:inline-block;background:linear-gradient(135deg,#7c5cff,#1877f2);color:#fff;font-size:10px;font-weight:800;letter-spacing:.12em;padding:5px 10px;border-radius:12px;text-transform:uppercase}
  .wel-hero h2{margin:4px 0 4px;font-size:20px;font-weight:800;line-height:1.2}
  .wel-hero p{margin:0;color:var(--muted);font-size:13px;line-height:1.35}
  .wel-feats{margin:12px 0 6px;display:flex;flex-direction:column;gap:7px}
  .wel-feat{display:flex;align-items:flex-start;gap:10px;padding:9px 11px;background:#f6f8fb;border-radius:11px}
  .wel-feat .em{font-size:19px;flex:0 0 26px;text-align:center}
  .wel-feat .body b{display:block;font-size:13.5px;font-weight:700}
  .wel-feat .body small{font-size:11.5px;color:var(--muted);line-height:1.3}
  .wel-cta{margin-top:10px;width:100%;background:var(--blue3);color:#fff;border:0;border-radius:24px;padding:12px;font-weight:700;font-size:15px;cursor:pointer}

  /* CHAT FAB + DRAWER */
  .chatfab{position:absolute;right:18px;bottom:100px;width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,#1877f2,#7c5cff);border:0;color:#fff;font-size:22px;display:grid;place-items:center;box-shadow:0 12px 24px rgba(124,92,255,.4);cursor:pointer;z-index:35}
  .chatfab:active{transform:scale(.95)}
  .chat-sheet{background:#fff;width:100%;border-top-left-radius:24px;border-top-right-radius:24px;height:85%;display:flex;flex-direction:column;animation:up .22s ease}
  .chat-hdr{display:flex;align-items:center;gap:10px;padding:14px 18px 10px;border-bottom:1px solid var(--line)}
  .chat-hdr .spark{font-size:22px}
  .chat-hdr h3{margin:0;font-size:16px;font-weight:800;flex:1}
  .chat-hdr small{display:block;font-size:11px;color:var(--muted);font-weight:500}
  .chat-hdr .clear{background:#f1f4f9;border:0;color:var(--muted);font-size:11px;font-weight:700;padding:6px 10px;border-radius:14px;cursor:pointer}
  .chat-hdr .x{background:none;border:0;color:var(--muted);font-size:24px;cursor:pointer}
  .chat-body{flex:1;overflow-y:auto;padding:14px 18px;display:flex;flex-direction:column;gap:10px}
  .chat-body::-webkit-scrollbar{display:none}
  .bub{max-width:85%;padding:10px 14px;border-radius:16px;font-size:13px;line-height:1.4}
  .bub.ai{background:#f1f4f9;color:var(--ink);align-self:flex-start;border-bottom-left-radius:4px}
  .bub.user{background:var(--blue3);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
  .bub.chat-typing{display:inline-flex;align-items:center;gap:4px;padding:12px 14px}
  .chat-typing-dot{width:6px;height:6px;border-radius:50%;background:var(--muted,#7a8aa0);display:block;animation:chat-typing-blink 1.4s ease-in-out infinite}
  .chat-typing-dot:nth-child(2){animation-delay:.18s}
  .chat-typing-dot:nth-child(3){animation-delay:.36s}
  @keyframes chat-typing-blink{0%,80%,100%{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-2px)}}
  .bub .ev-toggle{margin-top:8px;background:none;border:0;color:var(--blue3);font-size:11px;font-weight:700;cursor:pointer;padding:0}
  .bub .ev-list{margin-top:6px;background:#fff;border-radius:10px;padding:6px}
  .bub .ev-item{display:flex;justify-content:space-between;font-size:12px;padding:4px 6px;cursor:pointer;border-radius:6px}
  .bub .ev-item:hover{background:#f1f4f9}
  .bub .fb-row{margin-top:6px;display:flex;gap:6px}
  .bub .fb-row button{background:#fff;border:0;border-radius:12px;padding:3px 8px;font-size:12px;cursor:pointer}
  .bub .fb-row button.sel{background:var(--blue3);color:#fff}
  .chat-chips{display:flex;gap:6px;overflow-x:auto;padding:8px 18px}
  .chat-chips::-webkit-scrollbar{display:none}
  .chat-chips button{flex:0 0 auto;background:#eaf3ff;border:0;border-radius:16px;padding:7px 12px;font-size:12px;font-weight:600;color:var(--blue3);cursor:pointer;white-space:nowrap}
  .chat-input{display:flex;gap:8px;padding:10px 14px 16px;border-top:1px solid var(--line)}
  .chat-input input{flex:1;background:#f1f4f9;border:0;border-radius:22px;padding:11px 16px;font-size:14px;outline:0}
  .chat-input button{background:var(--blue3);color:#fff;border:0;border-radius:50%;width:42px;height:42px;font-size:18px;cursor:pointer}

  /* === BudgetView === */
  .budget-view{padding:4px 0 24px}
  .budget-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
  .budget-header small{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em}
  .budget-header h3{font-size:18px;font-weight:800;color:var(--ink);margin:2px 0 0}
  .budget-add-btn{width:34px;height:34px;border-radius:50%;background:var(--blue3);color:#fff;border:0;font-size:20px;line-height:1;cursor:pointer;box-shadow:0 6px 14px rgba(24,119,242,.3)}
  .budget-error{background:#fff4e6;color:#a85a00;border:1px solid #ffd99c;border-radius:10px;padding:8px 12px;font-size:12px;margin-bottom:10px}
  .budget-empty{color:var(--muted);font-size:13px;padding:20px 4px;text-align:center}
  .budget-add-form{background:#f6f8fb;border:1px solid var(--line);border-radius:14px;padding:12px;margin-bottom:12px;display:flex;flex-direction:column;gap:8px}
  .budget-add-form select,.budget-add-form input{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:14px;font-family:inherit;outline:0}
  .budget-add-actions{display:flex;justify-content:flex-end;gap:8px}
  .budget-btn{border:0;border-radius:10px;padding:9px 14px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit}
  .budget-btn.primary{background:var(--blue3);color:#fff}
  .budget-btn.primary:disabled{opacity:.5;cursor:not-allowed}
  .budget-btn.ghost{background:transparent;color:var(--muted)}
  .budget-list{display:flex;flex-direction:column;gap:10px}
  .budget-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;box-shadow:0 2px 6px rgba(10,40,90,.04)}
  .budget-item.warn{border-color:#ffd99c;background:#fff8ee}
  .budget-item.over{border-color:#f0a020;background:#fff4e6}
  .budget-item-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
  .budget-item-cat{display:flex;align-items:center;gap:8px}
  .budget-emoji{font-size:20px}
  .budget-cat-name{font-size:14px;font-weight:700;color:var(--ink)}
  .budget-monto{background:transparent;border:0;font-size:14px;font-weight:800;color:var(--ink);cursor:pointer;font-family:inherit;padding:4px 6px;border-radius:8px}
  .budget-monto:hover{background:#f1f4f9}
  .budget-edit{display:flex;align-items:center;gap:4px}
  .budget-edit input{width:100px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:13px;font-weight:700;font-family:inherit;text-align:right;outline:0}
  .budget-link{background:transparent;border:0;color:var(--blue3);font-weight:700;font-size:13px;cursor:pointer;padding:6px 8px;font-family:inherit}
  .budget-link.ghost{color:var(--muted)}
  .budget-bar{width:100%;height:8px;background:#eef2f7;border-radius:99px;overflow:hidden}
  .budget-bar-fill{height:100%;background:linear-gradient(90deg,#5bb47a,#3a7bff);border-radius:99px;transition:width .3s ease}
  .budget-item.warn .budget-bar-fill{background:linear-gradient(90deg,#f0a020,#ffc857)}
  .budget-item.over .budget-bar-fill{background:linear-gradient(90deg,#e8443a,#f0a020)}
  .budget-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px;font-size:12px;color:var(--muted)}
  .budget-pct{font-weight:700;color:var(--ink)}
  .budget-restante{flex:1;text-align:right;color:var(--muted)}
  .budget-item.over .budget-restante{color:#c43a30;font-weight:700}
  .budget-sin-asignar{width:100%;text-align:left;background:#fff;border:1px dashed var(--line);border-radius:14px;padding:12px 14px;cursor:pointer;font-family:inherit;margin-top:4px}
  .budget-sin-asignar:hover{border-color:var(--blue3);background:#f4f8ff}
  .budget-sin-asignar-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
  .budget-sin-asignar small{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em;display:block}
  .budget-sin-asignar-amt{font-size:16px;font-weight:800;color:var(--ink);margin:2px 0}
  .budget-sin-asignar-cta{font-size:13px;font-weight:700;color:var(--blue3)}

  .budget-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px;padding-top:6px;border-top:1px dashed rgba(10,40,90,.08)}
  .budget-actions .budget-link{padding:4px 0;font-size:12px}
  .budget-item.pulse{animation:budget-pulse 2.5s ease-out;box-shadow:0 0 0 0 rgba(232,68,58,0)}
  @keyframes budget-pulse{
    0%{box-shadow:0 0 0 0 rgba(232,68,58,.5);transform:scale(1)}
    20%{box-shadow:0 0 0 10px rgba(232,68,58,0);transform:scale(1.02)}
    40%{box-shadow:0 0 0 0 rgba(232,68,58,.4)}
    60%{box-shadow:0 0 0 10px rgba(232,68,58,0)}
    100%{box-shadow:0 0 0 0 rgba(232,68,58,0);transform:scale(1)}
  }

  .scope-picker{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
  .scope-picker-label{font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;padding-left:2px}
  .scope-opt{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#f6f8fb;border:1px solid var(--line);border-radius:12px;cursor:pointer;font-family:inherit;text-align:left;width:100%;transition:background .12s,border-color .12s}
  .scope-opt.on{background:#eaf3ff;border-color:var(--blue3)}
  .scope-opt-emoji{font-size:20px;line-height:1;flex:0 0 28px;text-align:center}
  .scope-opt-text{flex:1;min-width:0}
  .scope-opt-title{font-size:13px;font-weight:700;color:var(--ink);line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .scope-opt-desc{font-size:11px;color:var(--muted);margin-top:2px;line-height:1.3}
  .scope-opt-radio{width:18px;height:18px;border-radius:50%;border:2px solid #cfd6e0;display:flex;align-items:center;justify-content:center;font-size:10px;color:transparent;flex:0 0 18px}
  .scope-opt-radio.on{border-color:var(--blue3);color:var(--blue3)}


  /* ============================================================
     MIA — modo inmersivo (IA native). Tab oscura, glass + neón.
     ============================================================ */
  /* ===== MIA — tema claro moderno ===== */
  .content.mia-mode{
    display:flex;flex-direction:column;overflow:hidden;padding-bottom:0;
    background:
      radial-gradient(120% 80% at 50% -8%, rgba(24,119,242,.12), transparent 58%),
      radial-gradient(90% 60% at 100% 0%, rgba(58,123,255,.08), transparent 55%),
      linear-gradient(180deg,#f6f7fd 0%,#eef1fb 60%,#eaeefb 100%);
  }
  /* Chrome de la tab */
  .mia-mode .back{color:#1877f2}
  .mia-mode .vchip{background:#fff;color:#5a6b85;border:1px solid #e6e9f4;box-shadow:0 2px 8px rgba(30,40,90,.05)}
  .mia-mode .vchip.on{background:linear-gradient(135deg,#1877f2,#3a7bff);color:#fff;border-color:transparent;box-shadow:0 8px 20px rgba(24,119,242,.32)}
  .mia-mode .vchip-more-menu{background:#fff;border-color:#e6e9f4;box-shadow:0 10px 30px rgba(30,40,90,.14)}
  .mia-mode .vchip-more-item{color:#39435c}
  .mia-mode .vchip-more-item:hover{background:#f2f5fd}
  .mia-mode .vchip-more-item.on{background:rgba(24,119,242,.1);color:#1877f2}

  .mia-home{position:relative;flex:1;min-height:0;display:flex;flex-direction:column;color:#1c2438;animation:m-bubble-in .25s ease}
  /* Header propio de MIA-protagonista (banda separada, sobre el scroll) */
  /* Avatar de MIA: la imagen llena el contenedor circular en todos los tamaños.
     El glow/ring y las animaciones (pop/think/breathe) los pone cada contenedor. */
  .mia-ava-face{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%;pointer-events:none}
  .mia-chathead{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:5px;max-height:0;opacity:0;overflow:hidden;padding:0;margin:0;
    transition:max-height .5s cubic-bezier(.34,1.25,.45,1),opacity .35s ease,padding .5s ease,margin .5s ease}
  .mia-chathead.show{max-height:130px;opacity:1;padding:6px 0 12px;margin-bottom:8px;border-bottom:1px solid #e6e9f4}
  .mia-chathead-ava{width:66px;height:66px;border-radius:50%;display:grid;place-items:center;font-size:38px;overflow:hidden;
    background:linear-gradient(135deg,#fff,#f3f1ff);box-shadow:0 0 0 3px rgba(24,119,242,.45),0 12px 30px rgba(24,119,242,.38);
    transform:scale(.4);opacity:0;transition:transform .5s cubic-bezier(.34,1.5,.4,1) .1s,opacity .35s ease .1s}
  .mia-chathead.show .mia-chathead-ava{transform:scale(1);opacity:1}
  .mia-chathead-ava .mia-ava-face{display:block;line-height:1;animation:mia-pop .4s cubic-bezier(.18,1.4,.4,1)}
  .mia-chathead-ava.thinking{animation:mia-think 1s ease-in-out infinite}
  .mia-chathead-name{font-size:14px;font-weight:800;color:#1c2438}
  .mia-chathead-state{color:#8590a8;font-weight:600}
  /* Bienvenida colapsable (hero + balance) */
  .mia-welcome-top{display:grid;grid-template-rows:1fr;transition:grid-template-rows .45s cubic-bezier(.4,0,.2,1),opacity .35s ease,margin .45s ease}
  .mia-welcome-top.collapsed{grid-template-rows:0fr;opacity:0;margin-bottom:0;pointer-events:none}
  .mia-welcome-top>.mia-welcome-inner{overflow:hidden;min-height:0;transition:transform .45s cubic-bezier(.4,0,.2,1)}
  .mia-welcome-top.collapsed>.mia-welcome-inner{transform:translateY(-14px)}
  .mia-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:2px 1px 12px;scrollbar-width:none}
  .mia-scroll::-webkit-scrollbar{display:none}
  /* Chip de sugerencia de MIA (próximo paso). Lado MIA (izquierda). */
  .mia-sugg-chip,.mia-sugg-note{align-self:flex-start;max-width:82%;margin-top:-2px;
    font-size:13px;font-weight:700;line-height:1.3;padding:10px 14px;border-radius:16px;border-bottom-left-radius:6px;
    animation:m-bubble-in .3s ease both}
  .mia-sugg-chip{display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:1px solid transparent;text-align:left}
  .mia-sugg-chip:active{transform:scale(.97)}
  .mia-sugg-arrow{font-weight:800;opacity:.7}
  .mia-sugg-note{opacity:.95}
  /* Tonos: cálido (default), alerta, celebrando, neutral. */
  .tone-calido{background:#e9f1ff;color:#1877f2;border-color:#cfe0f5}
  .tone-alerta{background:#fff0f3;color:#d83a66;border-color:#ffd4de}
  .tone-celebrando{background:#eafaf3;color:#0f9d76;border-color:#c7f0e0}
  .tone-neutral{background:#eef1f7;color:#4a5573;border-color:#e1e6f0}

  /* Hero protagonista: solo el avatar grande de MIA + su nombre (sin texto). */
  .mia-hero-solo{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 0 18px}
  .mia-hero-bigava{width:96px;height:96px;border-radius:50%;overflow:hidden;
    box-shadow:0 0 0 3px rgba(24,119,242,.30),0 16px 36px rgba(20,60,120,.26);animation:mia-breathe 3.4s ease-in-out infinite}
  .mia-hero-name{font-size:17px;font-weight:800;letter-spacing:.04em;
    background:linear-gradient(90deg,#1877f2,#3a7bff);-webkit-background-clip:text;background-clip:text;color:transparent}

  /* Hero asesor */
  .mia-hero{position:relative;display:flex;gap:13px;align-items:flex-start;padding:16px;border-radius:20px;margin-bottom:16px;
    background:linear-gradient(135deg,#fff 0%,#f3f1ff 100%);
    border:1px solid #e7e6fb;box-shadow:0 12px 30px rgba(60,50,140,.10);overflow:hidden}
  .mia-hero::after{content:"";position:absolute;inset:-40% -20% auto auto;width:200px;height:200px;border-radius:50%;
    background:radial-gradient(circle,rgba(24,119,242,.16),transparent 65%);filter:blur(6px);animation:mia-glow 6s ease-in-out infinite}
  .mia-hero-avatar{position:relative;z-index:1;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;font-size:26px;overflow:hidden;
    flex:0 0 48px;background:#fff;box-shadow:0 0 0 2px rgba(24,119,242,.35),0 6px 16px rgba(24,119,242,.28);animation:mia-breathe 3.4s ease-in-out infinite}
  /* Cara reactiva: hace "pop" en cada cambio de emoji (key remonta el span) */
  .mia-hero-avatar .mia-ava-face{display:block;line-height:1;animation:mia-pop .4s cubic-bezier(.18,1.4,.4,1)}
  .mia-hero-avatar.thinking{animation:mia-think 1s ease-in-out infinite}
  @keyframes mia-pop{0%{transform:scale(.3) rotate(-18deg);opacity:0}60%{transform:scale(1.18) rotate(6deg)}100%{transform:scale(1) rotate(0);opacity:1}}
  @keyframes mia-think{0%,100%{transform:rotate(-6deg)}50%{transform:rotate(6deg)}}
  .mia-hero-text{position:relative;z-index:1}
  .mia-hero-title{font-size:13px;font-weight:800;margin-bottom:4px;letter-spacing:.2px;
    background:linear-gradient(90deg,#1877f2,#3a7bff);-webkit-background-clip:text;background-clip:text;color:transparent}
  .mia-hero-frase{font-size:13px;line-height:1.45;color:#4a566f;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

  /* Snapshot — tarjeta blanca, columnas */
  .mia-stats{display:flex;align-items:stretch;margin-bottom:18px;border-radius:16px;overflow:hidden;
    background:#fff;border:1px solid #e9ecf6;box-shadow:0 6px 18px rgba(30,40,90,.06)}
  .mia-stat{flex:1 1 0;min-width:0;background:none;border:0;padding:14px 6px;text-align:center;cursor:pointer;font-family:inherit;color:inherit}
  .mia-stat:active{background:#f5f7fd}
  .mia-stat-sep{width:1px;background:#eceff7;margin:12px 0}
  .mia-stat-label{font-size:9.5px;font-weight:800;color:#8590a8;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mia-stat-value{font-size:18px;font-weight:800;color:#1c2438;margin:4px 0 2px;white-space:nowrap}
  .mia-stat.tone-ok .mia-stat-value{color:#0f9d76}
  .mia-stat.tone-warn .mia-stat-value{color:#d98512}
  .mia-stat.tone-bad .mia-stat-value{color:#e3447a}
  .mia-stat-sub{font-size:10px;color:#8590a8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

  .mia-section-title{font-size:11px;font-weight:800;color:#6b7790;text-transform:uppercase;letter-spacing:.6px;margin:6px 2px 9px}
  .mia-section-head{display:flex;justify-content:space-between;align-items:center;margin:6px 2px 9px}
  .mia-section-head .mia-section-title{margin:0}
  .mia-section-toggle{display:flex;align-items:center;gap:6px;background:none;border:0;padding:0;cursor:pointer;font-family:inherit}
  .mia-section-chev{font-size:11px;color:#8590a8;transition:transform .18s ease;transform:rotate(-90deg)}
  .mia-section-chev.open{transform:rotate(0deg)}
  .mia-section-count{font-size:11px;font-weight:700;color:#1877f2}
  .mia-section-link{background:none;border:0;color:#1877f2;font-size:11.5px;font-weight:700;cursor:pointer;font-family:inherit;padding:0}
  .mia-section-link:active{opacity:.6}

  /* Últimos movimientos (compacto, una línea) — colapsable con animación */
  .mia-recent-wrap{display:grid;grid-template-rows:0fr;opacity:0;margin-bottom:0;
    transition:grid-template-rows .28s ease,opacity .24s ease,margin-bottom .28s ease}
  .mia-recent-wrap.open{grid-template-rows:1fr;opacity:1;margin-bottom:16px}
  .mia-recent-wrap>.mia-recent{overflow:hidden;min-height:0}
  .mia-recent{display:flex;flex-direction:column;
    background:#fff;border:1px solid #e9ecf6;border-radius:16px;padding:4px;box-shadow:0 6px 18px rgba(30,40,90,.06)}
  .mia-rec-empty{font-size:13px;color:#8590a8;padding:10px 4px}
  .mia-rec{display:flex;align-items:center;gap:10px;width:100%;text-align:left;font-family:inherit;cursor:pointer;
    background:none;border:0;border-radius:10px;padding:8px 8px;color:inherit}
  .mia-rec:active{background:#f5f7fd}
  .mia-rec+.mia-rec{border-top:1px solid #f1f3fa}
  .mia-rec-em{font-size:16px;flex:0 0 20px;text-align:center}
  .mia-rec-name{flex:1;min-width:0;font-size:12.5px;font-weight:600;color:#27314a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mia-rec-amt{flex:0 0 auto;font-size:12.5px;font-weight:800;white-space:nowrap}
  .mia-rec-amt.neg{color:#e3447a}
  .mia-rec-amt.pos{color:#0f9d76}

  /* Hilo de conversación (debajo de la bienvenida) */
  .mia-thread{display:flex;flex-direction:column;gap:8px;margin-top:16px;padding-top:14px;border-top:1px solid #e6e9f4}
  .mia-mode .bub{max-width:88%}
  .mia-mode .bub.ai{background:#fff;color:#27314a;border:1px solid #e9ecf6;box-shadow:0 4px 12px rgba(30,40,90,.05)}
  .mia-mode .bub.user{background:linear-gradient(135deg,#1877f2,#3a7bff);color:#fff;box-shadow:0 6px 16px rgba(24,119,242,.28)}
  .mia-mode .bub .ev-toggle{color:#1877f2}
  .mia-mode .bub .ev-list{background:#f5f7fd}
  .mia-mode .chat-typing-dot{background:#aab4cc}

  /* Composer fijo abajo */
  .mia-composer{position:relative;flex:0 0 auto;padding-top:8px;border-top:1px solid #e6e9f4;
    background:rgba(246,247,253,.86);backdrop-filter:blur(10px)}
  /* Avatar flotante arrastrable — compañero vivo */
  .mia-buddy-wrap{position:absolute;z-index:6;display:flex;align-items:center;gap:7px;cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none;
    transition:transform .5s cubic-bezier(.5,-0.2,.35,1.25),opacity .4s ease}
  .mia-buddy-wrap:active{cursor:grabbing}
  /* Al conversar, MIA "vuela" hacia arriba (a su header) y se desvanece. */
  .mia-buddy-wrap.gone{opacity:0;transform:translate(-24px,-220px) scale(.45);pointer-events:none}
  .mia-buddy{flex:0 0 auto;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-size:25px;overflow:hidden;
    background:linear-gradient(135deg,#fff,#f3f1ff);box-shadow:0 0 0 2px rgba(24,119,242,.4),0 10px 24px rgba(24,119,242,.34);animation:mia-breathe 3.4s ease-in-out infinite}
  .mia-buddy .mia-ava-face{display:block;line-height:1;animation:mia-pop .4s cubic-bezier(.18,1.4,.4,1)}
  .mia-buddy.thinking{animation:mia-think 1s ease-in-out infinite}
  /* Burbuja de 3 puntitos al lado de la cabeza */
  .mia-buddy-dots{display:flex;align-items:center;gap:3px;background:#fff;border:1px solid #e7e6fb;border-radius:14px;padding:8px 10px;
    box-shadow:0 6px 16px rgba(60,50,140,.16);animation:mia-pop .3s ease}
  .mia-chips{display:flex;gap:8px;overflow-x:auto;flex-wrap:nowrap;padding:0 0 9px;scrollbar-width:none;
    -webkit-mask-image:linear-gradient(90deg,#000 86%,transparent);mask-image:linear-gradient(90deg,#000 86%,transparent)}
  .mia-chips::-webkit-scrollbar{display:none}
  .mia-chip{flex:0 0 auto;background:#fff;color:#4f5d7a;border:1px solid #e2e6f1;border-radius:16px;
    padding:7px 13px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;box-shadow:0 2px 6px rgba(30,40,90,.04)}
  .mia-chip:active{background:#eef0fb;border-color:#cfd3ec}
  .mia-chat-input{display:flex;gap:8px;align-items:center;padding:0 0 8px}
  .mia-chat-input input{flex:1;border:1px solid #e2e6f1;border-radius:18px;padding:12px 16px;font-size:13px;font-family:inherit;outline:none;
    background:#fff;color:#1c2438;box-shadow:0 2px 8px rgba(30,40,90,.04)}
  .mia-chat-input input::placeholder{color:#9aa6bd}
  .mia-chat-input input:focus{border-color:rgba(24,119,242,.55);box-shadow:0 0 0 3px rgba(24,119,242,.14)}
  .mia-chat-input button{flex:0 0 auto;width:42px;height:42px;border-radius:50%;border:0;cursor:pointer;font-size:16px;color:#fff;
    background:linear-gradient(135deg,#1877f2,#3a7bff);box-shadow:0 6px 16px rgba(24,119,242,.4)}
  .mia-chat-input button:disabled{opacity:.5;cursor:default}

  /* Empty-state del chat */
  .mia-hint-empty{margin-top:14px;text-align:center;font-size:12.5px;color:#8590a8}

  /* ===== Componentes ricos dentro del chat ===== */
  .cc-card{align-self:flex-start;max-width:92%;background:#fff;border:1px solid #e9ecf6;border-radius:16px;
    padding:13px;box-shadow:0 6px 18px rgba(30,40,90,.07);animation:mia-pop .32s ease}
  .cc-title{font-size:11px;font-weight:800;color:#6b7790;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
  /* Animación del gráfico dentro del widget */
  .cc-donut{animation:cc-donut-in .55s cubic-bezier(.2,.8,.3,1) both}
  @keyframes cc-donut-in{from{opacity:0;transform:scale(.65) rotate(-110deg)}to{opacity:1;transform:none}}
  .cc-leg-bar>i,.cc-bud-bar>i,.cc-cmp-bar,.cc-top-bar>i{transform-origin:left;animation:cc-grow-x .6s .12s ease both}
  @keyframes cc-grow-x{from{transform:scaleX(0)}to{transform:scaleX(1)}}
  .cc-trend-bar{transform-origin:bottom;animation:cc-grow-y .5s .1s ease both}
  @keyframes cc-grow-y{from{transform:scaleY(0)}to{transform:scaleY(1)}}
  .cc-ring{animation:cc-donut-in .55s cubic-bezier(.2,.8,.3,1) both}
  /* Desglose: donut + leyenda */
  .cc-breakdown{display:flex;gap:14px;align-items:center}
  .cc-donut{position:relative;flex:0 0 84px;width:84px;height:84px;border-radius:50%}
  .cc-donut-hole{position:absolute;inset:22%;background:#fff;border-radius:50%;display:grid;place-items:center;text-align:center}
  .cc-donut-total{font-size:12px;font-weight:800;color:#1c2438;line-height:1}
  .cc-donut-cap{font-size:8px;color:#8590a8;text-transform:uppercase;letter-spacing:.5px}
  .cc-legend{flex:1;min-width:0;display:flex;flex-direction:column;gap:7px}
  .cc-leg-head{display:flex;align-items:center;gap:6px;font-size:11.5px}
  .cc-dot{width:9px;height:9px;border-radius:3px;flex:0 0 9px}
  .cc-leg-name{flex:1;min-width:0;color:#27314a;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .cc-leg-val{color:#6b7790;font-weight:700;white-space:nowrap}
  .cc-leg-bar{display:block;height:5px;border-radius:3px;background:#eef1f8;overflow:hidden;margin-top:3px}
  .cc-leg-bar>i{display:block;height:100%;border-radius:3px}
  /* Presupuestos */
  .cc-budget{display:flex;flex-direction:column;gap:11px}
  .cc-bud-head{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;margin-bottom:4px}
  .cc-bud-name{color:#27314a;font-weight:700}
  .cc-bud-pct{font-weight:800}
  .cc-bud-pct.ok{color:#0f9d76}.cc-bud-pct.warn{color:#d98512}.cc-bud-pct.over{color:#e3447a}
  .cc-bud-bar{height:7px;border-radius:4px;background:#eef1f8;overflow:hidden}
  .cc-bud-bar>i{display:block;height:100%;border-radius:4px}
  .cc-bud-bar>i.ok{background:linear-gradient(90deg,#22c79a,#0f9d76)}
  .cc-bud-bar>i.warn{background:linear-gradient(90deg,#ffc16b,#d98512)}
  .cc-bud-bar>i.over{background:linear-gradient(90deg,#ff8aa6,#e3447a)}
  .cc-bud-sub{font-size:10.5px;color:#8590a8;margin-top:3px}
  /* Movimiento */
  .cc-mov{display:flex;align-items:center;gap:10px;width:100%;text-align:left;font-family:inherit;cursor:pointer;background:#f7f8fc;border:1px solid #eceff7;border-radius:12px;padding:10px}
  .cc-mov-em{flex:0 0 34px;width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:18px}
  .cc-mov-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
  .cc-mov-main b{font-size:13px;color:#1c2438;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .cc-mov-main small{font-size:10.5px;color:#8590a8}
  .cc-mov-amt{flex:0 0 auto;font-size:13px;font-weight:800}
  .cc-mov-amt.neg{color:#e3447a}.cc-mov-amt.pos{color:#0f9d76}
  .cc-movs{display:flex;flex-direction:column;gap:7px}
  .cc-movs-total{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:9px;border-top:1px dashed #e2e6f1;font-size:12.5px;font-weight:800;color:#27314a}
  .cc-movs-total .neg{color:#e3447a}.cc-movs-total .pos{color:#0f9d76}
  .cc-actions{display:flex;gap:8px;margin-top:10px}
  .cc-btn{flex:1;border-radius:12px;padding:9px;font-size:12.5px;font-weight:700;cursor:pointer;font-family:inherit;border:1px solid transparent}
  .cc-btn.ghost{background:#f2f5fd;color:#4f5d7a;border-color:#e2e6f1}
  .cc-btn.primary{background:linear-gradient(135deg,#1877f2,#3a7bff);color:#fff;box-shadow:0 6px 14px rgba(24,119,242,.32)}
  .cc-btn:active{transform:translateY(1px)}
  .cc-btn:disabled{opacity:.55;cursor:default}
  /* Confirmación de acción */
  .cc-confirm-detail{font-size:13px;color:#27314a;font-weight:600;margin:-2px 0 4px}
  .cc-confirm-result{align-self:flex-start;font-size:13px;font-weight:700;padding:11px 14px}
  .cc-confirm-result.ok{color:#0f9d76;background:#e8f8f1;border-color:#cdeede}
  .cc-confirm-result.cancel{color:#8590a8}
  /* Categorizar inline (chips) */
  .cc-cat-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:11px}
  .cc-cat-chip{background:#f2f5fd;border:1px solid #e2e6f1;border-radius:14px;padding:7px 11px;font-size:12px;font-weight:700;color:#4f5d7a;cursor:pointer;font-family:inherit;white-space:nowrap}
  .cc-cat-chip:active{background:#e6e9fb;border-color:#cfd3ec}
  .cc-cat-chip:disabled{opacity:.5;cursor:default}
  /* Anillo (detalle tope / meta) */
  .cc-ring{position:relative;flex:0 0 72px;width:72px;height:72px;border-radius:50%}
  .cc-ring-hole{position:absolute;inset:20%;background:#fff;border-radius:50%;display:grid;place-items:center;text-align:center}
  .cc-ring-center{font-size:14px;font-weight:800;color:#1c2438;line-height:1}
  .cc-ring-cap{font-size:8px;color:#8590a8;text-transform:uppercase;letter-spacing:.5px}
  .cc-detail-head{display:flex;align-items:center;gap:14px;margin-bottom:10px}
  .cc-detail-info{flex:1;min-width:0}
  .cc-detail-amt{font-size:16px;font-weight:800;color:#1c2438}
  .cc-detail-amt small{font-size:11px;color:#8590a8;font-weight:600}
  .cc-detail-sub{font-size:12px;font-weight:700;margin-top:2px}
  /* Tendencia */
  .cc-trend{display:flex;align-items:flex-end;justify-content:space-between;gap:8px;height:118px;padding-top:6px}
  .cc-trend-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:4px;height:100%}
  .cc-trend-val{font-size:9px;font-weight:700;color:#6b7790;white-space:nowrap}
  .cc-trend-bar{width:60%;max-width:26px;border-radius:6px 6px 2px 2px;background:linear-gradient(180deg,#1877f2,#3a7bff)}
  .cc-trend-lbl{font-size:10px;color:#8590a8;text-transform:uppercase}
  /* Comparativa */
  .cc-compare{display:flex;flex-direction:column;gap:11px}
  .cc-cmp-head{display:flex;justify-content:space-between;align-items:center;font-size:12px;margin-bottom:4px}
  .cc-cmp-name{color:#27314a;font-weight:700}
  .cc-cmp-delta{font-weight:800}
  .cc-cmp-delta.up{color:#e3447a}.cc-cmp-delta.down{color:#0f9d76}
  .cc-cmp-bars{display:flex;flex-direction:column;gap:3px}
  .cc-cmp-bar{display:block;height:7px;border-radius:4px;min-width:2px}
  .cc-cmp-bar.prev{background:#cfd6ea}
  .cc-cmp-bar.cur{background:#1877f2}
  .cc-cmp-legend{display:flex;gap:14px;margin-top:9px;font-size:10.5px;color:#8590a8}
  .cc-cmp-legend span{display:flex;align-items:center;gap:5px}
  .cc-cmp-legend i{width:10px;height:7px;border-radius:3px;display:inline-block}
  .cc-cmp-legend i.prev{background:#cfd6ea}.cc-cmp-legend i.cur{background:#1877f2}
  /* Top comercios */
  .cc-top{display:flex;flex-direction:column;gap:9px}
  .cc-top-row{display:flex;align-items:center;gap:10px}
  .cc-top-rank{flex:0 0 20px;width:20px;height:20px;border-radius:50%;background:#eef1f8;color:#6b7790;font-size:11px;font-weight:800;display:grid;place-items:center}
  .cc-top-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
  .cc-top-name{font-size:12.5px;font-weight:600;color:#27314a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .cc-top-bar{display:block;height:5px;border-radius:3px;background:#eef1f8;overflow:hidden}
  .cc-top-bar>i{display:block;height:100%;border-radius:3px}
  .cc-top-val{flex:0 0 auto;font-size:12.5px;font-weight:800;color:#1c2438;text-align:right;display:flex;flex-direction:column;line-height:1.1}
  .cc-top-val small{font-size:9.5px;color:#8590a8;font-weight:600}

  @keyframes mia-breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
  @keyframes mia-glow{0%,100%{opacity:.5;transform:translate(0,0)}50%{opacity:.9;transform:translate(-12px,10px)}}

  /* Tab-bar — grupo "Análisis" (base, tema claro) */
  .vchip-more-wrap{position:relative;display:inline-flex;flex:0 0 auto}
  .vchip-more-backdrop{position:fixed;inset:0;z-index:44}
  .vchip-more-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:45;background:#fff;border:1px solid var(--line);
    border-radius:14px;box-shadow:0 14px 32px rgba(10,40,90,.18);padding:6px;min-width:160px;display:flex;flex-direction:column;animation:m-bubble-in .18s ease}
  .vchip-more-item{display:flex;align-items:center;gap:8px;background:none;border:0;border-radius:10px;padding:9px 12px;
    font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;font-family:inherit;text-align:left;white-space:nowrap}
  .vchip-more-item:hover{background:#f6f8fb}
  .vchip-more-item.on{background:#eef4ff;color:var(--blue2)}
  .vchip-more-item .em{font-size:15px}
