/* ===========================================================
   FINANZAS — Design System
   Minimalista · acento lima #D4E600 · claro / oscuro
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

/* ===== Iconos UIcons (Flaticon, regular-rounded) autohospedados ===== */
@font-face { font-family:'uicons'; font-style:normal; font-weight:400; font-display:swap; src:url('../uicons-bold-rounded.woff2') format('woff2'); }
.appi { display:inline-flex; align-items:center; justify-content:center; font-style:normal; line-height:1; flex:none; }
.appi::before { font-family:'uicons' !important; font-weight:400 !important; font-style:normal; font-variant:normal; text-transform:none; line-height:1; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
.appi-dashboard::before{content:"\e098"} .appi-wallet::before{content:"\f12a"} .appi-tx::before{content:"\ecc1"}
.appi-swap::before{content:"\e61b"} .appi-pie::before{content:"\e346"} .appi-budget::before{content:"\e33d"}
.appi-settings::before{content:"\eda3"} .appi-bank::before{content:"\e158"} .appi-cash::before{content:"\ea84"}
.appi-crypto::before{content:"\e1af"} .appi-card::before{content:"\e4c1"} .appi-plus::before{content:"\ec37"}
.appi-close::before{content:"\e4d0"} .appi-edit::before{content:"\eb87"} .appi-trash::before{content:"\f026"}
.appi-chevron::before{content:"\e07e"} .appi-chevdown::before{content:"\e07c"} .appi-back::before{content:"\e07a"}
.appi-sun::before{content:"\ef1e"} .appi-moon::before{content:"\ea97"} .appi-refresh::before{content:"\ece4"}
.appi-download::before{content:"\e5a3"} .appi-upload::before{content:"\f09c"} .appi-search::before{content:"\ed83"}
.appi-check::before{content:"\e35f"} .appi-arrowup::before{content:"\e0d2"} .appi-arrowdown::before{content:"\e0cf"}
.appi-filter::before{content:"\e6d0"} .appi-food::before{content:"\f0e8"} .appi-car::before{content:"\e2df"}
.appi-bag::before{content:"\edce"} .appi-home::before{content:"\e866"} .appi-fun::before{content:"\ee34"}
.appi-health::before{content:"\e83c"} .appi-income::before{content:"\ed46"} .appi-chart::before{content:"\e33f"}
.appi-star::before{content:"\eed9"} .appi-dots::before{content:"\ea34"} .appi-globe::before{content:"\e793"}
.appi-eye::before{content:"\e62c"} .appi-eyeoff::before{content:"\e62f"} .appi-moneybag::before{content:"\ed46"}
.appi-target::before{content:"\e284"} .appi-flag::before{content:"\e6ef"} .appi-calc::before{content:"\e29b"}
.appi-info::before{content:"\e8ce"} .appi-folder::before{content:"\e717"}

:root {
  --font-display: 'Space Grotesk', system-ui, sans-serif;
  --font-body: 'DM Sans', system-ui, sans-serif;

  /* accent — lima brillante */
  --accent: #c8dc00;
  --accent-strong: #b6c900;
  --accent-ink: #1a1d00;      /* texto sobre el lima */
  --accent-soft: rgba(200, 220, 0, 0.14);

  /* semantic */
  --pos: #3f9142;
  --neg: #d8584b;

  --radius-sm: 10px;
  --radius: 16px;
  --radius-lg: 22px;
  --radius-pill: 999px;

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.04), 0 1px 3px rgba(0,0,0,0.03);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.06), 0 1px 4px rgba(0,0,0,0.04);
  --shadow-lg: 0 18px 48px rgba(0,0,0,0.14);

  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);

  --maxw: 1180px;
}

/* ---------- LIGHT ---------- */
:root, [data-theme="light"] {
  --bg: #f6f6f4;
  --bg-2: #efefec;
  --surface: #ffffff;
  --surface-2: #fafaf8;
  --border: #e8e8e3;
  --border-strong: #dcdcd5;
  --text: #16170f;
  --text-2: #6c6e63;
  --text-3: #9a9c90;
  --hover: rgba(0,0,0,0.035);
  --accent-text: #5f6a00;      /* lima legible como texto en claro */
  --pos: #3a8a3e;
  --neg: #cf4d40;
  --scrim: rgba(20,20,16,0.42);
}

/* ---------- DARK ---------- */
[data-theme="dark"] {
  --bg: #0b0c0a;
  --bg-2: #111310;
  --surface: #171915;
  --surface-2: #1d201a;
  --border: #272a23;
  --border-strong: #34382e;
  --text: #f3f4ee;
  --text-2: #a4a89a;
  --text-3: #71756a;
  --hover: rgba(255,255,255,0.04);
  --accent-text: #c8dc00;
  --pos: #5fc164;
  --neg: #e8695c;
  --scrim: rgba(0,0,0,0.6);
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.4);
  --shadow-md: 0 6px 22px rgba(0,0,0,0.42);
  --shadow-lg: 0 24px 60px rgba(0,0,0,0.6);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { background: var(--bg); }

body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "tnum" 1, "cv01" 1;
  transition: background 0.35s var(--ease), color 0.35s var(--ease);
}

#root { min-height: 100vh; min-height: 100dvh; }

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, select, textarea { font-family: inherit; }
::selection { background: var(--accent); color: var(--accent-ink); }

/* range slider (simulador) */
.slider { -webkit-appearance: none; appearance: none; width: 100%; height: 5px; border-radius: 999px; background: var(--bg-2); outline: none; cursor: pointer; }
.slider::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 18px; height: 18px; border-radius: 50%; background: var(--accent); border: 3px solid var(--surface); box-shadow: var(--shadow-sm); cursor: pointer; transition: transform 0.12s var(--ease); }
.slider::-webkit-slider-thumb:hover { transform: scale(1.12); }
.slider::-moz-range-thumb { width: 16px; height: 16px; border-radius: 50%; background: var(--accent); border: 3px solid var(--surface); cursor: pointer; }
.slider::-moz-range-track { height: 5px; border-radius: 999px; background: var(--bg-2); }

/* numbers. NO ponemos `white-space: nowrap` global: hacía que cualquier número
   grande empujara el layout y desbordara/zoomeara la pantalla en celulares.
   Los números importantes usan <FitText> (una línea + se achican para entrar).
   El resto puede envolver el SÍMBOLO a otra línea (el número en sí no tiene
   espacios, así que nunca se parte ni desborda). Tablas que necesitan nowrap
   tienen su propia regla (.postable-row .num, .advtable-row .num). */
.num { font-family: var(--font-display); font-feature-settings: "tnum" 1; letter-spacing: -0.01em; }

/* scrollbar */
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 999px; border: 3px solid var(--bg); }
*::-webkit-scrollbar-track { background: transparent; }

/* =================== APP SHELL =================== */
.app { display: flex; min-height: 100vh; min-height: 100dvh; }

/* sidebar (desktop) */
.sidebar {
  width: 248px;
  flex-shrink: 0;
  border-right: 1px solid var(--border);
  background: var(--bg);
  padding: 22px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: sticky;
  top: 0;
  height: 100vh; height: 100dvh;
}
.brand { display: flex; align-items: center; gap: 11px; padding: 6px 10px 22px; }
.brand-mark {
  width: 34px; height: 34px; border-radius: 10px;
  background: var(--accent); color: var(--accent-ink);
  display: grid; place-items: center; flex-shrink: 0;
  font-family: var(--font-display); font-weight: 700; font-size: 19px;
}
/* marca Walioo: logo (ícono) + wordmark (logo de texto), igual que el login */
.brand-logo { width: 34px; height: 34px; border-radius: 10px; flex-shrink: 0; display: block; }
.brand-word { height: 21px; width: auto; display: block; }
/* el wordmark es blanco → en tema claro lo pasamos a oscuro para que contraste */
[data-theme="light"] .brand-word { filter: brightness(0); opacity: .82; }
.brand-name { font-family: var(--font-display); font-weight: 600; font-size: 17px; letter-spacing: -0.02em; }
.brand-sub { font-size: 11px; color: var(--text-3); letter-spacing: 0.04em; text-transform: uppercase; }

.nav-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 11px;
  color: var(--text-2); font-weight: 500; font-size: 14.5px;
  transition: background 0.16s var(--ease), color 0.16s var(--ease);
  width: 100%; text-align: left;
}
.nav-item:hover { background: var(--hover); color: var(--text); }
.nav-item.active { background: var(--surface); color: var(--text); box-shadow: var(--shadow-sm); }
.nav-item.active .nav-ico { color: var(--accent-text); }
.nav-ico { width: 19px; height: 19px; flex-shrink: 0; color: var(--text-3); }
.nav-item.active .nav-ico { color: var(--accent-text); }
.nav-spacer { flex: 1; }

/* main */
.main { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.main-inner { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 30px 34px 120px; flex: 1; overflow-x: clip; }

.topbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 26px; }
.page-title { font-family: var(--font-display); font-size: 27px; font-weight: 600; letter-spacing: -0.025em; margin: 0; }
.page-sub { color: var(--text-2); font-size: 13.5px; margin-top: 3px; }

/* mobile bottom nav */
.bottombar { display: none; }
.mobile-header { display: none; }

/* =================== PRIMITIVES =================== */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.card-pad { padding: 20px; }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 10px 16px; border-radius: var(--radius-pill);
  font-weight: 600; font-size: 14px; letter-spacing: -0.01em;
  transition: transform 0.12s var(--ease), background 0.16s var(--ease), border-color 0.16s, opacity 0.16s;
  white-space: nowrap;
}
.btn:active { transform: scale(0.97); }
.btn-primary { background: var(--accent); color: var(--accent-ink); }
.btn-primary:hover { background: var(--accent-strong); }
.btn-ghost { background: var(--surface); color: var(--text); border: 1px solid var(--border); }
.btn-ghost:hover { background: var(--hover); border-color: var(--border-strong); }
.btn-subtle { background: var(--bg-2); color: var(--text-2); }
.btn-subtle:hover { color: var(--text); }
.btn-icon { padding: 9px; border-radius: 11px; }
.btn-danger { color: var(--neg); }
.btn-block { width: 100%; }
.btn-lg { padding: 13px 20px; font-size: 15px; }

.chip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 12px; border-radius: var(--radius-pill);
  font-size: 13px; font-weight: 500; color: var(--text-2);
  background: var(--bg-2); border: 1px solid transparent;
  transition: all 0.15s var(--ease);
}
.chip:hover { color: var(--text); }
.chip.active { background: var(--accent); color: var(--accent-ink); font-weight: 600; }

.pill-tabs { display: inline-flex; gap: 4px; background: var(--bg-2); padding: 4px; border-radius: var(--radius-pill); }
.pill-tab { padding: 7px 15px; border-radius: var(--radius-pill); font-size: 13.5px; font-weight: 500; color: var(--text-2); transition: all 0.15s var(--ease); }
.pill-tab.active { background: var(--surface); color: var(--text); box-shadow: var(--shadow-sm); }

.label { font-size: 11.5px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-3); }

/* form fields */
.field { display: flex; flex-direction: column; gap: 7px; }
.field-label { font-size: 12.5px; font-weight: 600; color: var(--text-2); }
.input, .select {
  width: 100%; padding: 12px 14px; border-radius: var(--radius-sm);
  background: var(--surface-2); border: 1px solid var(--border);
  color: var(--text); font-size: 15px; outline: none;
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}
.input:focus, .select:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); background: var(--surface); }
.input::placeholder { color: var(--text-3); }
textarea.input { resize: vertical; min-height: 72px; }
.select { appearance: none; -webkit-appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239a9c90' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 13px center; padding-right: 38px;
}

/* ===== Simulador de ganancias ===== */
/* sin flechitas nativas en los campos numéricos (se superponían con el sufijo "meses") */
.sim input[type="number"]::-webkit-outer-spin-button,
.sim input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.sim input[type="number"] { -moz-appearance: textfield; appearance: textfield; }
.sim-grid { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr); gap: 18px; align-items: start; }
.sim-grid > * { min-width: 0; }
@media (max-width: 900px) { .sim-grid { grid-template-columns: minmax(0,1fr); } }
.sim-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.sim-line { display: flex; align-items: center; gap: 8px; }
.sim-line .input { padding: 9px 11px; font-size: 14px; }
.sim-line .select { padding: 9px 26px 9px 10px; font-size: 13px; background-position: right 8px center; }
.sim-range {
  -webkit-appearance: none; appearance: none; width: 100%; height: 7px;
  border-radius: 999px; background: var(--surface-2); outline: none; cursor: pointer; margin: 2px 0;
}
.sim-range::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none; width: 20px; height: 20px; border-radius: 50%;
  background: var(--accent); border: 3px solid var(--surface); box-shadow: var(--shadow-sm); cursor: pointer;
}
.sim-range::-moz-range-thumb {
  width: 20px; height: 20px; border-radius: 50%; background: var(--accent);
  border: 3px solid var(--surface); box-shadow: var(--shadow-sm); cursor: pointer;
}

/* segmented */
.seg { display: inline-flex; background: var(--bg-2); border-radius: var(--radius-sm); padding: 4px; gap: 3px; width: 100%; }
.seg-opt { flex: 1; padding: 9px; border-radius: 8px; font-size: 13.5px; font-weight: 600; color: var(--text-2); transition: all 0.15s; }
.seg-opt.active { background: var(--surface); color: var(--text); box-shadow: var(--shadow-sm); }
.seg-opt.active.pos { color: var(--pos); }
.seg-opt.active.neg { color: var(--neg); }

/* =================== MODAL / SHEET =================== */
.scrim {
  position: fixed; inset: 0; background: var(--scrim);
  backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px);
  z-index: 100; opacity: 0; animation: fade 0.2s var(--ease) forwards;
  display: flex; align-items: center; justify-content: center; padding: 20px;
}
@keyframes fade { to { opacity: 1; } }
.modal {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); width: 100%; max-width: 480px;
  box-shadow: var(--shadow-lg); max-height: 90vh; max-height: 90dvh; overflow-y: auto;
  transform: translateY(14px) scale(0.99); opacity: 0;
  animation: pop 0.26s var(--ease) forwards;
}
@keyframes pop { to { transform: translateY(0) scale(1); opacity: 1; } }
.modal-head { display: flex; align-items: center; justify-content: space-between; padding: 20px 22px 6px; }
.modal-title { font-family: var(--font-display); font-size: 19px; font-weight: 600; letter-spacing: -0.02em; margin: 0; }
.modal-body { padding: 16px 22px 22px; display: flex; flex-direction: column; gap: 16px; }

/* =================== HELPERS =================== */
.row { display: flex; align-items: center; }
.between { justify-content: space-between; }
.gap-2 { gap: 8px; } .gap-3 { gap: 12px; } .gap-4 { gap: 16px; }
.grid { display: grid; }
.stack { display: flex; flex-direction: column; }
.muted { color: var(--text-2); }
.muted-3 { color: var(--text-3); }
.pos { color: var(--pos); }
.neg { color: var(--neg); }
.center { text-align: center; }
.divider { height: 1px; background: var(--border); border: none; margin: 0; }
.fade-in { animation: fadein 0.3s var(--ease); }
@keyframes fadein { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }

/* account / category avatar */
.avatar {
  width: 40px; height: 40px; border-radius: 12px; flex-shrink: 0;
  display: grid; place-items: center; font-weight: 700; font-size: 15px;
  font-family: var(--font-display);
}
.avatar svg { width: 19px; height: 19px; }

/* list rows */
.lrow { display: flex; align-items: center; gap: 13px; padding: 13px 4px; }
.lrow + .lrow { border-top: 1px solid var(--border); }

/* fab (mobile) */
.fab { display: none; }

/* empty state */
.empty { text-align: center; padding: 48px 20px; color: var(--text-3); }
.empty-ico { width: 46px; height: 46px; margin: 0 auto 14px; color: var(--text-3); opacity: 0.6; }

/* progress bar */
.bar { height: 8px; border-radius: 999px; background: var(--bg-2); overflow: hidden; }
.bar-fill { height: 100%; border-radius: 999px; transition: width 0.5s var(--ease); }

/* tiny badge */
.badge { font-size: 11px; font-weight: 600; padding: 3px 8px; border-radius: 999px; background: var(--bg-2); color: var(--text-2); white-space: nowrap; }
.badge.live { background: var(--accent-soft); color: var(--accent-text); }

/* layout grids */
.dash-grid { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr); gap: 18px; align-items: stretch; }
.dash-grid > .card { height: 100%; }
.dash-grid > * { min-width: 0; }
.acc-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
/* grids de tarjetas con números: colapsan en móvil para que nada se salga */
.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
/* items de grid con min-width:0 → pueden encogerse bajo su contenido (un número
   largo sin espacios) para que FitText mida bien y nada infle la pantalla */
.grid-2 > *, .grid-3 > *, .grid-4 > *, .acc-grid > * { min-width: 0; }
@media (max-width: 900px) { .grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) { .grid-3 { grid-template-columns: minmax(0, 1fr); } }
@media (max-width: 520px) { .grid-2 { grid-template-columns: minmax(0, 1fr); } }
@media (max-width: 440px) { .grid-4 { grid-template-columns: minmax(0, 1fr); } }
/* franjas de números (ingresos/gastos/ahorro, total/pasivos): que las celdas
   puedan encogerse para que el FitText mida bien y nada se salga */
.flow-strip { align-items: stretch; }
.flow-strip > .stack { min-width: 0; justify-content: space-between; }
/* filas de Ajustes (tema/idioma/etc.): en móvil, label arriba y control abajo
   con ancho completo, para que no queden pegados */
@media (max-width: 560px) {
  .set-row { flex-direction: column; align-items: stretch; gap: 12px; }
  .set-row > div:last-child { width: 100% !important; }
}
.rate-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.acc-card { text-align: left; transition: transform 0.14s var(--ease), border-color 0.16s, box-shadow 0.16s; }
.acc-card:hover { transform: translateY(-2px); border-color: var(--border-strong); box-shadow: var(--shadow-md); }
.acc-card:active { transform: scale(0.99); }
.settings-wrap { max-width: 640px; }

@keyframes spin { to { transform: rotate(360deg); } }

/* animación de billetes al registrar ingreso/gasto */
.money-fx { position: fixed; z-index: 9999; pointer-events: none; font-size: 30px; will-change: transform, opacity; }
@keyframes moneyUp { 0% { transform: translateY(0) rotate(0); opacity: 0; } 12% { opacity: 1; } 100% { transform: translateY(-190px) translateX(var(--dx)) rotate(var(--r)); opacity: 0; } }
@keyframes moneyDown { 0% { transform: translateY(0) rotate(0); opacity: 0; } 12% { opacity: 1; } 100% { transform: translateY(190px) translateX(var(--dx)) rotate(var(--r)); opacity: 0; } }

/* toggle de idioma en el login */
.auth-lang { margin-left: auto; display: inline-flex; gap: 2px; background: var(--bg-2); border-radius: 8px; padding: 2px; }
.auth-lang-btn { border: none; background: transparent; color: var(--text-3); font-size: 11px; font-weight: 700; padding: 4px 9px; border-radius: 6px; cursor: pointer; font-family: inherit; letter-spacing: .03em; }
.auth-lang-btn.on { background: var(--surface); color: var(--text); box-shadow: var(--shadow-sm); }

/* ocultar saldos: difumina todos los montos */
.hide-amounts .num { filter: blur(8px); transition: filter 0.2s var(--ease); user-select: none; }

/* net balance bars (divergente) */
.netbars { display: flex; gap: 8px; align-items: stretch; width: 100%; }
.netcol { flex: 1; display: flex; flex-direction: column; align-items: center; }
.nethalf { flex: 1; width: 100%; display: flex; justify-content: center; }
.nettop { align-items: flex-end; }
.netbot { align-items: flex-start; }
.netbar { width: 58%; max-width: 30px; transition: height 0.5s var(--ease); }
.netzero { height: 1px; width: 100%; background: var(--border-strong); }
.netlabel { font-size: 10.5px; color: var(--text-3); margin-top: 6px; font-weight: 600; }

/* positions table */
.postable { display: flex; flex-direction: column; }
.postable-head, .postable-row { display: grid; grid-template-columns: 2.2fr 1fr 1fr 1fr 1.2fr; align-items: center; gap: 12px; padding: 13px 18px; }
.postable-head { font-size: 11.5px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-3); padding-top: 4px; padding-bottom: 10px; }
.postable-row { border-top: 1px solid var(--border); cursor: pointer; transition: background 0.14s var(--ease); }
.postable-row:hover { background: var(--hover); }
.postable .r { text-align: right; }
.postable-row .num { font-size: 14px; white-space: nowrap; }

/* tabla avanzada (rendimiento por activo) */
.advtable { display: flex; flex-direction: column; }
.advtable-head, .advtable-row { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.1fr; align-items: center; gap: 10px; padding: 11px 2px; }
.advtable-head { font-size: 11px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-3); padding-bottom: 8px; }
.advtable-row { border-top: 1px solid var(--border); }
.advtable .r { text-align: right; }
.advtable-row .num { white-space: nowrap; }

@media (max-width: 720px) {
  .postable-head { display: none; }
  .postable-row { grid-template-columns: 1fr 1fr; gap: 12px; padding: 14px 16px; align-items: start; }
  .postable-row > .row { grid-column: 1 / -1; }
  .postable-row .r { text-align: left; }
  .postable-row .num[data-l] { min-width: 0; overflow: hidden; text-overflow: ellipsis; }
  .postable-row .num[data-l]::before { content: attr(data-l); display: block; font-size: 10.5px; color: var(--text-3); font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 3px; }

  .advtable-head { display: none; }
  .advtable-row { grid-template-columns: 1fr 1fr 1fr; gap: 6px 10px; padding: 13px 2px; }
  .advtable-row > .row { grid-column: 1 / -1; margin-bottom: 2px; }
  .advtable-row .r { text-align: left; }
  .advtable-row .num[data-l]::before { content: attr(data-l); display: block; font-size: 10px; color: var(--text-3); font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 2px; }
}

@media (max-width: 980px) {
  .acc-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .dash-grid { grid-template-columns: minmax(0,1fr); gap: 14px; }
  .rate-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .rate-grid { grid-template-columns: 1fr; }
  /* franjas de 3 celdas: menos padding en móvil → más lugar para el número */
  .flow-strip > .stack { padding-left: 11px !important; padding-right: 11px !important; }
}
@media (max-width: 460px) {
  .acc-grid { grid-template-columns: 1fr; }
}

/* =================== RESPONSIVE =================== */
@media (max-width: 860px) {
  .sidebar { display: none; }
  .main-inner { padding: 16px 16px 110px; }
  .mobile-header {
    display: flex; align-items: center; justify-content: space-between;
    /* en PWA/standalone con viewport-fit=cover, sumar la safe-area de arriba
       para que el header sólido rellene la zona de la barra de estado (mismo
       color) y el contenido no quede debajo del reloj/notch */
    padding: calc(14px + env(safe-area-inset-top)) 16px 14px;
    position: sticky; top: 0; z-index: 40;
    /* sólido (no translúcido) para que sea una banda continua con la barra de
       estado del sistema y no se "tiña" con el contenido al scrollear */
    background: var(--bg);
    border-bottom: 1px solid var(--border);
  }
  .page-title { font-size: 23px; }
  .topbar { margin-bottom: 18px; }
  /* botón "Salir" compacto en el header móvil (ya no es flotante) */
  .btn-logout-m { padding: 7px 13px; font-size: 12.5px; color: var(--text-2); }

  .bottombar {
    display: flex; position: fixed; bottom: 0; left: 0; right: 0; z-index: 50;
    /* sólido: la franja inferior (incl. la safe-area del gesto) queda del color de
       la app y se integra con la barra de navegación del sistema */
    background: var(--bg);
    border-top: 1px solid var(--border);
    padding: 8px 6px calc(8px + env(safe-area-inset-bottom));
    justify-content: space-around;
  }
  .bnav { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 6px 2px; color: var(--text-3); }
  .bnav svg { width: 22px; height: 22px; }
  .bnav span { font-size: 10.5px; font-weight: 600; }
  .bnav.active { color: var(--accent-text); }

  .fab {
    display: grid; place-items: center;
    position: fixed; right: 18px; bottom: calc(78px + env(safe-area-inset-bottom)); z-index: 55;
    width: 56px; height: 56px; border-radius: 18px;
    background: var(--accent); color: var(--accent-ink);
    box-shadow: 0 8px 24px rgba(0,0,0,0.28);
  }
  .fab svg { width: 26px; height: 26px; }

  .modal { max-width: 100%; border-radius: var(--radius-lg) var(--radius-lg) 0 0; align-self: flex-end; margin-top: auto; }
  .scrim { align-items: flex-end; padding: 0; }
  @keyframes pop { to { transform: translateY(0) scale(1); opacity: 1; } }
}

@media (min-width: 861px) {
  .only-mobile { display: none !important; }
}
@media (max-width: 860px) {
  .only-desktop { display: none !important; }
}

/* ===========================================================
   Auth (login / registro) — diseño moderno de dos paneles
   =========================================================== */
.auth-screen{
  position:relative; min-height:100dvh; display:flex; align-items:center; justify-content:center;
  padding:24px; overflow:hidden;
  background:
    radial-gradient(1200px 600px at 12% -12%, rgba(200,220,0,0.16), transparent 60%),
    radial-gradient(900px 520px at 112% 115%, rgba(59,130,246,0.10), transparent 55%),
    var(--bg);
}
.auth-blob{
  position:absolute; width:540px; height:540px; right:-180px; top:-180px; border-radius:50%;
  background:radial-gradient(circle at center, rgba(200,220,0,0.20), transparent 70%);
  filter:blur(24px); pointer-events:none;
}
.auth-shell{
  position:relative; width:100%; max-width:900px;
  display:grid; grid-template-columns:1.05fr 1fr;
  background:var(--surface); border:1px solid var(--border);
  border-radius:24px; overflow:hidden; box-shadow:var(--shadow-lg);
  animation:auth-rise .5s var(--ease);
}
@keyframes auth-rise{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:none; } }

.auth-brand{
  position:relative; padding:46px 42px; display:flex; flex-direction:column; gap:16px;
  border-right:1px solid var(--border);
  background:
    linear-gradient(155deg, rgba(200,220,0,0.20), rgba(200,220,0,0.02) 58%),
    var(--surface-2);
}
.auth-brand::after{
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(620px 320px at 0% 0%, rgba(200,220,0,0.10), transparent 60%);
}
.auth-brand > *{ position:relative; z-index:1; }
.auth-brand-title{
  font-family:var(--font-display); font-size:32px; line-height:1.08; font-weight:700;
  letter-spacing:-0.025em; color:var(--text); margin:8px 0 0;
}
.auth-brand-sub{ color:var(--text-2); font-size:14px; line-height:1.55; margin:0; max-width:33ch; }
.auth-feats{ list-style:none; margin:14px 0 0; padding:0; display:flex; flex-direction:column; gap:13px; }
.auth-feats li{ display:flex; align-items:center; gap:11px; color:var(--text); font-size:13.5px; }
.auth-feats .dot{
  width:24px; height:24px; border-radius:8px; flex:none;
  background:var(--accent-soft); color:var(--accent-text);
  display:flex; align-items:center; justify-content:center;
}

.auth-logo-img{ width:52px; height:52px; border-radius:14px; box-shadow:var(--shadow-md); }
/* lockup de marca (logo + nombre juntos) en el panel izquierdo */
.auth-brand-lockup{ display:flex; align-items:center; gap:13px; }
/* wordmark "walioo" (logo de texto). Es blanco → en tema claro se oscurece. */
.auth-wordmark{ height:30px; width:auto; display:block; }
[data-theme="light"] .auth-wordmark{ filter:brightness(0); opacity:.85; }

.auth-form{ padding:42px 40px; display:flex; flex-direction:column; }
.auth-formhead{ display:flex; align-items:center; gap:10px; margin-bottom:20px; }
/* el lockup de marca del formulario (logo + nombre) se oculta en desktop:
   en desktop la marca ya está en el panel izquierdo. En móvil ese panel no
   se ve, así que el lockup se muestra acá. El selector de idioma siempre va
   a la derecha. */
.auth-formhead-brand{ display:none; align-items:center; gap:10px; }
.auth-formhead .auth-logo-img{ width:34px; height:34px; border-radius:10px; box-shadow:none; }
.auth-formhead .auth-wordmark{ height:22px; }
.auth-formhead .auth-lang{ margin-left:auto; }

.auth-seg{
  display:flex; gap:4px; padding:4px; margin-bottom:22px;
  background:var(--surface-2); border:1px solid var(--border); border-radius:var(--radius-pill);
}
.auth-seg-btn{
  flex:1; padding:9px 12px; border-radius:var(--radius-pill);
  font-family:var(--font-body); font-weight:600; font-size:13.5px; color:var(--text-2);
  transition:background .2s var(--ease), color .2s var(--ease);
}
.auth-seg-btn.on{ background:var(--accent); color:var(--accent-ink); box-shadow:var(--shadow-sm); }

.auth-h{ font-family:var(--font-display); font-size:22px; font-weight:600; letter-spacing:-0.02em; color:var(--text); margin:0 0 4px; }
.auth-p{ color:var(--text-2); font-size:13px; margin:0 0 12px; }

.auth-label{ display:block; font-size:11px; text-transform:uppercase; letter-spacing:0.04em; color:var(--text-2); margin:14px 0 7px; }
.auth-input{
  width:100%; padding:13px 14px; border-radius:12px; box-sizing:border-box;
  border:1px solid var(--border-strong); background:var(--surface-2); color:var(--text);
  font-size:15px; font-family:inherit;
  transition:border-color .18s var(--ease), box-shadow .18s var(--ease);
}
.auth-input::placeholder{ color:var(--text-3); }
.auth-input:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft); }

/* Slot único de alto fijo: aloja hint / error / éxito sin reflujo.
   min-height cubre hasta 2 líneas, así la tarjeta nunca se redimensiona. */
.auth-helper{ margin-top:11px; min-height:40px; font-size:13px; line-height:1.4; }
.auth-hint{ color:var(--text-3); font-size:11.5px; line-height:1.5; }
.auth-err{ color:var(--neg); display:flex; gap:7px; align-items:flex-start; }
.auth-ok{ color:var(--pos); }

.auth-btn{
  width:100%; margin-top:22px; padding:14px 16px; border-radius:var(--radius-pill);
  background:var(--accent); color:var(--accent-ink); font-weight:700; font-size:15px; font-family:inherit;
  transition:transform .12s var(--ease), filter .2s var(--ease);
}
.auth-btn:hover:not(:disabled){ filter:brightness(1.05); transform:translateY(-1px); }
.auth-btn:active:not(:disabled){ transform:translateY(0); }
.auth-btn:disabled{ opacity:.65; cursor:wait; }

.auth-foot{ margin-top:16px; text-align:center; color:var(--text-3); font-size:11.5px; }

/* Badge oficial de Google Play (imagen) en el login */
.play-badge-img{ display:inline-flex; transition:transform .15s var(--ease), filter .2s var(--ease); }
.play-badge-img:hover{ transform:translateY(-1px); filter:brightness(1.06); }
.play-badge-img img{ height:70px; width:auto; display:block; }
.auth-play-mobile{ display:none; }
@media (max-width:760px){ .auth-play-mobile{ display:block; } }

@media (max-width:760px){
  .auth-screen{ padding:16px; overflow-x:hidden; }
  .auth-shell{ grid-template-columns:1fr; width:100%; min-width:0; max-width:min(440px, calc(100vw - 32px)); }
  .auth-brand{ display:none; }
  .auth-form{ padding:28px 22px; min-width:0; }
  /* en móvil el panel de marca se oculta → mostramos el lockup del formulario */
  .auth-formhead-brand{ display:flex; }
  .auth-play-mobile .play-badge-img img{ height:60px; }
}

/* ===== Premium / freemium ===== */
.pr-hl{ display:flex; align-items:center; gap:8px; background:var(--accent-soft); color:var(--accent-text); border:1px solid var(--accent); border-radius:12px; padding:10px 13px; font-size:13.5px; font-weight:600; }
.pr-preview{ background:linear-gradient(160deg, var(--accent-soft), var(--bg-2)); border:1px solid var(--border); border-radius:16px; padding:14px 16px 12px; }
.pr-preview-art{ background:var(--surface); border:1px solid var(--border); border-radius:12px; padding:8px 10px; }
.pr-preview-cap{ margin-top:10px; text-align:center; font-weight:700; font-size:15px; }
.pr-locked-blur{ position:relative; }
.pr-locked-blur > .pr-blur-content{ filter:blur(6px); opacity:.55; pointer-events:none; user-select:none; }
.pr-locked-over{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; text-align:center; padding:16px; z-index:2; }
.pr-lock-ico{ width:44px; height:44px; border-radius:50%; background:var(--accent); color:var(--accent-ink); display:inline-flex; align-items:center; justify-content:center; box-shadow:0 6px 20px rgba(200,220,0,0.3); }
/* free: blurea SOLO los números de una sección (se ve la estructura, no los valores) */
.pr-blur-nums{ position:relative; }
.pr-blur-nums .num{ filter:blur(7px); user-select:none; }
.pr-nums-unlock{ position:absolute; top:12px; right:12px; z-index:3; display:inline-flex; align-items:center; gap:6px; background:var(--accent); color:var(--accent-ink); font-weight:700; font-size:11.5px; padding:5px 11px; border-radius:999px; border:none; cursor:pointer; box-shadow:0 4px 14px rgba(0,0,0,0.20); }

/* Tour guiado (recorrido por las secciones) */
.tour-scrim{ position:fixed; inset:0; z-index:3000; background:rgba(0,0,0,0.42); display:flex; align-items:flex-end; justify-content:center; padding:16px; padding-bottom:calc(16px + env(safe-area-inset-bottom)); }
.tour-card{ width:100%; max-width:460px; background:var(--surface); border:1px solid var(--border-strong); border-radius:18px; box-shadow:var(--shadow-lg); padding:18px; animation:tourIn .28s var(--ease); }
@keyframes tourIn{ from{ opacity:0; transform:translateY(18px); } to{ opacity:1; transform:none; } }
.tour-top{ display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.tour-ico{ width:34px; height:34px; border-radius:10px; background:var(--accent-soft); color:var(--accent-text); display:grid; place-items:center; flex:none; }
.tour-count{ font-size:12px; color:var(--text-3); font-weight:700; letter-spacing:.02em; }
.tour-x{ margin-left:auto; background:var(--bg-2); border:none; color:var(--text-3); width:30px; height:30px; border-radius:8px; display:grid; place-items:center; cursor:pointer; }
.tour-x:hover{ color:var(--text); }
.tour-title{ font-family:var(--font-display); font-weight:700; font-size:19px; margin-bottom:6px; letter-spacing:-.01em; }
.tour-body{ font-size:14px; line-height:1.55; color:var(--text-2); }
.tour-dots{ display:flex; gap:6px; justify-content:center; margin:16px 0 14px; }
.tour-dot{ width:6px; height:6px; border-radius:50%; background:var(--border-strong); transition:width .2s, background .2s; }
.tour-dot.on{ background:var(--accent); width:18px; border-radius:3px; }
.tour-actions{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.pr-perks{ display:grid; gap:9px; }
.pr-perk{ display:flex; align-items:flex-start; gap:10px; font-size:14px; }
.pr-check{ flex:none; width:22px; height:22px; border-radius:50%; background:var(--accent); color:var(--accent-ink); display:inline-flex; align-items:center; justify-content:center; margin-top:1px; }
.pr-plans{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width:480px){ .pr-plans{ grid-template-columns:1fr; } }
.pr-plan{ position:relative; text-align:left; background:var(--bg-2); border:1.5px solid var(--border); border-radius:16px; padding:16px; cursor:pointer; transition:border-color .15s, transform .15s; display:flex; flex-direction:column; gap:6px; font-family:inherit; }
.pr-plan:hover{ transform:translateY(-2px); border-color:var(--accent); }
.pr-plan.best{ border-color:var(--accent); box-shadow:0 8px 26px rgba(200,220,0,0.16); }
.pr-plan-name{ font-size:13px; color:var(--text-2); font-weight:700; text-transform:uppercase; letter-spacing:.04em; }
.pr-plan-price{ display:flex; align-items:baseline; gap:6px; }
.pr-plan-price b{ font-size:24px; font-weight:800; letter-spacing:-0.02em; }
.pr-plan-price small{ color:var(--text-3); font-size:12px; }
.pr-plan-cta{ margin-top:6px; text-align:center; background:var(--accent); color:var(--accent-ink); font-weight:700; border-radius:10px; padding:9px; font-size:14px; }
.pr-plan:not(.best) .pr-plan-cta{ background:var(--surface-2); color:var(--text); }
.pr-badge-best{ position:absolute; top:-10px; right:12px; background:var(--accent); color:var(--accent-ink); font-size:10.5px; font-weight:800; text-transform:uppercase; letter-spacing:.04em; padding:3px 9px; border-radius:999px; }
/* badge "Premium" para controles bloqueados */
.pr-badge{ display:inline-flex; align-items:center; gap:4px; background:linear-gradient(90deg,var(--accent),#7bd88f); color:#0b0c0a; font-size:10.5px; font-weight:800; text-transform:uppercase; letter-spacing:.03em; padding:2px 8px; border-radius:999px; }
.pr-locked-card{ position:relative; }
/* fila/control bloqueado: atenuado + candado */
.pr-gated{ opacity:.6; }
.sub-card{ display:flex; align-items:center; gap:14px; }
.sub-ico{ flex:none; width:46px; height:46px; border-radius:13px; display:inline-flex; align-items:center; justify-content:center; }
.sub-ico.free{ background:var(--surface-2); color:var(--text-2); }
.sub-ico.prem{ background:linear-gradient(135deg,var(--accent),#7bd88f); color:#0b0c0a; }
