:root{--bg: #f3f4f6;--card: #ffffff;--border: #e5e7eb;--text: #111827;--muted: #6b7280;--primary: #2563eb}.dashboard-page{background:transparent;min-height:100vh;padding:24px 0;font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,sans-serif}.dashboard-shell{max-width:1200px;margin:0 auto;background:var(--card);border-radius:18px;padding:24px;box-shadow:0 20px 40px #0f172a14}.dashboard-shell.wide{max-width:none;width:100%}.dashboard-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.dashboard-hero{background:linear-gradient(135deg,#eef2ff,#f8fafc 60%,#fff);border:1px solid #e2e8f0;border-radius:18px;padding:18px 20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:14px}.dashboard-hero-title{font-size:22px;font-weight:700;color:#0f172a;margin:0}.dashboard-hero-subtitle{margin:4px 0 0;color:#475569;font-size:14px}.dashboard-hero-actions{margin-left:auto;display:flex;gap:10px;align-items:center}.coach-btn{padding:10px 16px;border-radius:999px;border:1px solid #c7d2fe;background:#eef2ff;color:#4338ca;font-weight:600;cursor:pointer;box-shadow:0 8px 16px #4338ca1f}.coach-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.coach-modal{width:min(720px,95vw);max-height:90vh;overflow-y:auto;background:#fff;border-radius:24px;box-shadow:0 20px 60px #0f172a40;padding:20px;display:flex;flex-direction:column;gap:12px;border:1px solid #e2e8f0}.coach-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;border-bottom:1px solid #e2e8f0;padding-bottom:8px}.coach-chip{display:inline-flex;padding:6px 10px;border-radius:999px;background:#eef2ff;color:#4338ca;font-weight:600;font-size:12px}.coach-section{border:1px solid #e2e8f0;border-radius:14px;padding:12px;background:#f8fafc}.coach-section h4{margin:0 0 6px;font-size:14px;color:#0f172a}.coach-section p{margin:4px 0;color:#334155;font-size:13px}.debt-btn{padding:12px 18px;border-radius:999px;border:none;background:#4f46e5;color:#fff;font-weight:600;cursor:pointer;box-shadow:0 10px 20px #4f46e533}.period-summary{margin:12px 0;border-radius:16px;border:1px solid #e0e7ff;background:#f8fafc;padding:14px 16px}.period-summary h4{margin:0 0 6px;font-size:13px;letter-spacing:.5px;color:#4338ca;text-transform:uppercase}.period-summary p{margin:0;font-size:15px;color:#0f172a;line-height:1.5}.dashboard-header-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.dashboard-title{display:flex;flex-direction:column}.dashboard-heading{margin:0;font-size:26px;font-weight:600;color:var(--text)}.dashboard-subtitle{margin:4px 0 0;color:var(--muted);font-size:13px}.btn-primary{padding:10px 18px;border:none;border-radius:999px;background:var(--primary);color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease;box-shadow:0 8px 20px #2563eb2e}.btn-primary:active{transform:translateY(1px) scale(.99);box-shadow:0 4px 12px #2563eb33}.btn-primary.btn-press{transform:translateY(1px) scale(.99);box-shadow:0 6px 14px #2563eb40}.btn-primary.btn-success{background:#16a34a;box-shadow:0 8px 20px #16a34a38}.btn-primary:disabled{opacity:.8;cursor:not-allowed}.btn-secondary{padding:10px 18px;border-radius:999px;border:1px solid rgba(37,99,235,.4);background:#2563eb14;color:var(--primary);font-size:14px;font-weight:500;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease,transform .12s ease}.btn-secondary:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-secondary-success{border-color:#10b98199;background:#ecfdf3;color:#047857;box-shadow:0 6px 16px #10b9812e}.btn-tertiary{padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:#fff;color:#dc2626;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease,transform .12s ease}.btn-tertiary:hover{background:#fee2e2;border-color:#fecdd3}.btn-tertiary:active{transform:translateY(1px)}.btn-logout{border-color:#fecdd3;color:#b91c1c;background:#fff5f5}.btn-logout:hover{background:#fee2e2;border-color:#fca5a5}.service-confirm-banner{margin:16px 0;padding:14px 16px;border-radius:14px;background:#f0f9ff;border:1px solid #bfdbfe;display:flex;align-items:center;justifyContent:space-between;gap:12px;flex-wrap:wrap}.service-confirm-title{font-weight:600;color:#0f172a}.service-confirm-number{font-size:20px;font-weight:700;color:#1d4ed8}.sync-status{margin-top:6px;font-size:13px;color:#0f172a}.service-confirm-label{font-size:13px;color:#475569}.service-confirm-actions{display:flex;gap:8px}.filters-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:20px 0 24px;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}.filter-group select{height:36px;border-radius:999px;border:1px solid var(--border);padding:0 12px;background:#f9fafb;color:var(--text);font-size:14px}.period-label{font-size:13px;text-align:right;color:var(--muted)}.summary-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.summary-card{border-radius:12px;border:1px solid var(--border);background:#f9fafb;padding:20px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.summary-card--action{cursor:pointer;transition:box-shadow .2s ease,transform .2s ease}.summary-card--action:focus-visible{outline:2px solid var(--primary);outline-offset:4px}.summary-card--action:hover{box-shadow:0 8px 20px #0f172a26;transform:translateY(-2px)}.summary-card-hint{font-size:12px;color:var(--muted)}.summary-header{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:var(--muted)}.summary-value{margin-top:2px;font-size:22px;font-weight:600;color:var(--text)}.summary-breakdown{margin-top:14px;display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;font-size:12px;color:var(--muted);width:100%}.summary-breakdown-column{min-width:120px;display:flex;flex-direction:column;gap:2px;align-items:center;text-align:center}.gmail-popup-overlay{position:fixed;inset:0;background:#0f172abf;display:flex;align-items:center;justify-content:center;z-index:1000}.gmail-popup{width:min(440px,90%);background:#fff;border-radius:22px;padding:28px 26px;text-align:center;box-shadow:0 20px 40px #0f172a40}.gmail-popup p{margin:0 0 16px;color:#0f172a;font-weight:600}.gmail-popup button{border:none;background:#0ea5e9;color:#fff;border-radius:999px;padding:10px 20px;font-weight:600;cursor:pointer;transition:transform .2s ease}.gmail-popup button:hover{transform:translateY(-1px)}.gmail-popup h3{margin:0 0 8px;color:#0f172a}.summary-breakdown-label{font-weight:500}.summary-breakdown-value{color:var(--text);font-weight:600;font-size:14px}@media(max-width:640px){.summary-breakdown{grid-template-columns:repeat(2,minmax(120px,1fr))}}.banks-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:24px}.bank-card{border-radius:18px;border:1px solid var(--border);padding:22px;background:var(--card);display:flex;flex-direction:column;gap:12px;box-shadow:0 12px 25px -25px #0f172a66;cursor:pointer;transition:transform .2s ease}.bank-card--active{transform:translateY(-2px)}.bank-card__header{display:flex;align-items:center;gap:10px}.bank-card__dot{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-weight:700}.bank-card__metrics{font-size:13px;color:var(--muted)}.bank-card__metrics strong{color:var(--text)}.bank-progress{height:6px;border-radius:999px;background:#94a3b840;overflow:hidden}.health-trend-row{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1.6fr);gap:16px;margin-bottom:24px}.card{border-radius:16px;border:1px solid var(--border);background:var(--card);padding:18px}.inventory-table{width:100%;border-collapse:collapse;font-size:14px;color:var(--text)}.inventory-table.wide-table{width:-moz-max-content;width:max-content;min-width:2000px}.inventory-table thead th,.inventory-table.wide-table th,.inventory-table.wide-table td{white-space:nowrap}.cruce-table{width:-moz-max-content;width:max-content;min-width:-moz-max-content;min-width:max-content;table-layout:auto}.cruce-table th{white-space:nowrap;border-right:1px solid #e5e7eb;border-bottom:1px solid #eef2f7;vertical-align:top;overflow:hidden;text-overflow:ellipsis;max-width:none;position:relative}.cruce-table td{white-space:normal;border-right:1px solid #e5e7eb;border-bottom:1px solid #eef2f7;vertical-align:top;overflow:hidden;text-overflow:initial;max-width:none;overflow-wrap:anywhere;word-break:break-word}.cruce-table th:first-child,.cruce-table td:first-child{border-left:1px solid #e5e7eb}.cruce-table .cuerpo-col{white-space:normal;min-width:360px;max-width:520px;overflow:visible;text-overflow:initial;word-break:break-word}.cruce-table .descripcion-col{white-space:normal;min-width:280px;max-width:520px;word-break:break-word}.cruce-table .th-content{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-right:10px}.cruce-table .col-resizer{position:absolute;right:-4px;top:0;height:100%;width:8px;cursor:col-resize;-webkit-user-select:none;-moz-user-select:none;user-select:none}.cruce-table tbody tr.cruce-row--match{color:#166534!important}.cruce-table tbody tr.cruce-row--no-match{color:#b91c1c!important}.cruce-table tbody tr.cruce-row--match *,.cruce-table tbody tr.cruce-row--no-match *,.cruce-table tbody .cruce-badge{color:inherit!important}.cruce-table .table-separator{color:inherit;background:#f3f4f6}.table-scroll-top{height:12px;overflow-x:auto;overflow-y:hidden;border:1px solid var(--border);border-radius:999px;background:#f1f5f9;margin-bottom:10px}.table-scroll-top>div{height:1px}.table-separator{width:16px;min-width:16px;background:#e5e7eb;border-left:1px solid #d1d5db;border-right:1px solid #d1d5db;padding:0}.inventory-table th,.inventory-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}.inventory-table th:nth-child(2),.inventory-table td:nth-child(2){min-width:220px;width:22%;word-break:break-word}.inventory-table th:nth-child(8),.inventory-table td:nth-child(8){min-width:220px;width:22%;word-break:break-word}.inventory-table th:nth-child(10),.inventory-table td:nth-child(10){min-width:180px;width:16%;word-break:break-word}.table-wrapper{width:100%;overflow-x:auto}.table-wrapper.scroll-x{overflow-x:auto;overflow-y:hidden;max-width:100%}.card-header h3{margin:0;font-size:14px;font-weight:500;color:var(--text);text-align:center;width:100%}.card-header{text-align:center}.trend-card__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.trend-mode-toggle{display:inline-flex;padding:3px;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0;gap:4px}.trend-mode-toggle button{border:none;background:transparent;font-size:12px;font-weight:500;padding:4px 10px;border-radius:999px;color:#475569;cursor:pointer;transition:background .2s ease,color .2s ease}.trend-mode-toggle button.active{background:#fff;box-shadow:0 1px 3px #0f172a26;color:#0f172a}.health-layout{display:flex;gap:16px;align-items:center}.health-text-title{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text)}.health-text-body{margin:0 0 6px;font-size:13px;color:var(--muted)}.donut-card{display:flex;flex-direction:column;gap:16px;margin-bottom:24px;align-items:center;text-align:center}.donut-hint{font-size:12px;color:var(--muted);text-align:center}.donut-layout{display:flex;flex-direction:column;gap:16px;align-items:center;width:100%}.donut-chart-wrapper{display:flex;flex-direction:column;align-items:center;gap:12px}.donut-legend{list-style:none;padding:0;margin:0;width:100%;font-size:12px;color:var(--muted);display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.donut-legend li{flex:1 1 220px;max-width:260px}.donut-legend-btn{width:100%;border:1px solid var(--border);background:#f9fafb;border-radius:12px;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;gap:12px;cursor:pointer;font-size:13px}.donut-legend-btn--active{border-color:#2563eb;background:#eef2ff}.donut-legend-left{display:inline-flex;align-items:center;gap:8px;color:var(--text);font-weight:500}.donut-legend li strong{color:var(--text);font-weight:600}.donut-legend-dot{width:10px;height:10px;border-radius:50%;display:inline-flex}.donut-empty{font-size:13px;color:var(--muted);padding:12px 0}.donut-insight{margin:0;font-size:13px;color:#0f172a;font-weight:500}.category-movements-card{margin-bottom:24px}.category-movements-body{margin-top:12px}.category-movements-scroll{max-height:320px;overflow-y:auto}.category-movements-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.category-movements-list li{display:flex;justify-content:space-between;align-items:center;gap:16px;border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:#f9fafb}.movements-description{margin:0;font-weight:500;color:var(--text);font-size:13px}.movements-date{font-size:12px;color:var(--muted)}.movements-amount{font-weight:600;color:#dc2626}.category-movements-empty{font-size:13px;color:var(--muted)}.category-movements-error{font-size:13px;color:#dc2626}.alerts-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.alerts-card li{border-radius:14px;padding:12px 14px}.alerts-danger{border:1px solid rgba(239,68,68,.45);background:#ef444414}.alerts-warn{border:1px solid rgba(249,115,22,.4);background:#f9731614}@media(max-width:900px){.summary-row{grid-template-columns:repeat(2,minmax(0,1fr))}.health-trend-row{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}}@media(max-width:640px){.dashboard-header{flex-direction:column}.filters-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.period-label{text-align:left}.banks-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}.metric-drawer-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:90}.metric-drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:calc(100% - 32px);background:#fff;box-shadow:-12px 0 40px #0f172a26;z-index:95;display:flex;flex-direction:column;padding:28px;border-radius:18px 0 0 18px}.metric-drawer__header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.metric-drawer__eyebrow{margin:0;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.metric-drawer__header h3{margin:4px 0;font-size:20px;color:var(--text)}.metric-drawer__amount{font-size:22px;font-weight:600;color:var(--text)}.metric-drawer--income .metric-drawer__amount{color:#0f766e}.metric-drawer--expense .metric-drawer__amount{color:#dc2626}.metric-drawer--overdraft .metric-drawer__amount{color:#ea580c}.metric-drawer__close{border:none;background:#f3f4f6;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;line-height:1}.metric-drawer__buckets{margin:18px 0;display:flex;flex-wrap:wrap;gap:10px}.metric-drawer__bucket{border-radius:999px;border:1px solid var(--border);padding:8px 14px;font-size:12px;color:var(--muted);background:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;min-width:150px}.metric-drawer__bucket strong{color:var(--text);font-size:14px}.metric-drawer__bucket--active{background:var(--primary);color:#fff;border-color:transparent}.metric-drawer__bucket--active strong{color:#fff}.metric-drawer__body{flex:1;overflow-y:auto;padding-right:4px}.metric-drawer__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.metric-drawer__item{border:1px solid var(--border);border-radius:14px;padding:14px;display:flex;justify-content:space-between;gap:12px;background:#fff;box-shadow:0 10px 20px #0f172a0f}.metric-drawer__item-main{display:flex;flex-direction:column;gap:4px}.metric-drawer__item-date{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.metric-drawer__item-desc{margin:0;font-size:14px;color:var(--text);font-weight:500}.metric-drawer__item-tags{font-size:11px;color:var(--muted)}.metric-drawer__item-amount{font-weight:600;font-size:16px;white-space:nowrap}.metric-drawer__item-amount--income{color:#0f766e}.metric-drawer__item-amount--expense{color:#dc2626}.metric-drawer__item-amount--overdraft{color:#ea580c}.metric-drawer__empty{text-align:center;color:var(--muted);margin-top:40px}@media(max-width:768px){.metric-drawer{width:100%;border-radius:24px 24px 0 0;bottom:0;top:auto}}
