/* ============================ */
/* ESTILOS GLOBALES Y DE NAVEGACIÓN */
/* ============================ */
body, html {
    margin: 0; padding: 0; width: 100%; height: 100%; overflow: hidden;
    font-family: 'Poppins', sans-serif; background-color: #000;
}
.main-section {
    display: none; width: 100%; height: 100%; overflow: hidden;
    position: absolute; top: 0; left: 0;
}
#seccion-menu { display: flex; }

/* ============================ */
/* ESTILOS PARA: #seccion-menu (Detonación Visual) */
/* ============================ */
#seccion-menu {
    --bg-color: #000000; --text-color: #e0e0e0; --quote-color: #ffffff;
    --author-color: #c0c0c0; --nav-bg-gradient: linear-gradient(180deg, rgba(8, 8, 12, 0.2), rgba(8, 8, 12, 0.7));
    --nav-border-color: rgba(255, 255, 255, 0.1); --accent-agenda: #ffb74d; --accent-cuentas: #64b5f6;
    --accent-salir: #e57373; --font-quote: 'Cormorant Garamond', serif; --font-main: 'Poppins', sans-serif;
    --nebula-violet: #3a1a5a; --nebula-magenta: #9a229a; --nebula-cyan: #176e8a;
    color: var(--text-color); font-family: var(--font-main);
}
#seccion-menu .screen { position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; opacity: 0; pointer-events: none; transition: opacity 1.2s ease-in-out; z-index: 10; }
#seccion-menu .screen.active { opacity: 1; pointer-events: auto; z-index: 20; }
#seccion-menu .starry-background { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #000; overflow: hidden; z-index: 1; animation: bg-subtle-breathing 40s infinite alternate ease-in-out; }
@keyframes bg-subtle-breathing { from { transform: scale(1); } to { transform: scale(1.03); } }
#seccion-menu .stars, #seccion-menu .stars2, #seccion-menu .stars3, #seccion-menu .stars4 { position: absolute; width: 100%; height: 100%; background: transparent; background-image: var(--star-image); animation: var(--star-anim); will-change: transform; }
#seccion-menu .stars  { --star-image: radial-gradient(0.4px 0.4px at 15% 35%, white, transparent), radial-gradient(0.4px 0.4px at 80% 60%, #ccc, transparent); background-size: 80px 80px; --star-anim: move-stars-far 300s linear infinite; }
#seccion-menu .stars2 { --star-image: radial-gradient(0.6px 0.6px at 50% 100%, white, transparent), radial-gradient(0.5px 0.5px at 20% 80%, #eee, transparent), radial-gradient(0.6px 0.6px at 90% 20%, #fff, transparent); background-size: 120px 120px; --star-anim: move-stars-mid 200s linear infinite; }
#seccion-menu .stars3 { --star-image: radial-gradient(1px 1px at 10% 90%, white, transparent), radial-gradient(0.8px 0.8px at 85% 45%, #fafafa, transparent), radial-gradient(0.8px 0.8px at 40% 20%, #ddd, transparent); background-size: 200px 200px; --star-anim: move-stars-near 120s linear infinite; animation-delay: -5s; }
#seccion-menu .stars4 { --star-image: radial-gradient(1.2px 1.2px at 40% 50%, white, transparent), radial-gradient(1.2px 1.2px at 95% 75%, #fafafa, transparent), radial-gradient(1px 1px at 60% 90%, #eee, transparent); background-size: 300px 300px; --star-anim: move-stars-closest 80s linear infinite; animation-delay: -10s; }
@keyframes move-stars-far { from { transform: translateY(0px) rotate(0deg); } to { transform: translateY(-800px) rotate(1deg); } }
@keyframes move-stars-mid { from { transform: translateY(0px) rotate(0deg); } to { transform: translateY(-1200px) rotate(-2deg); } }
@keyframes move-stars-near { from { transform: translateY(0px) rotate(0deg); } to { transform: translateY(-2000px) rotate(3deg); } }
@keyframes move-stars-closest { from { transform: translateY(0px) rotate(0deg); } to { transform: translateY(-2800px) rotate(-4deg); } }
#seccion-menu .nebula-background, #seccion-menu .nebula-foreground { position: absolute; top: -50%; left: -50%; width: 200%; height: 200%; background-repeat: no-repeat; opacity: 0.4; mix-blend-mode: hard-light; will-change: transform; }
#seccion-menu .nebula-background { background-image: radial-gradient(ellipse at 30% 70%, var(--nebula-violet) 0%, transparent 60%), radial-gradient(ellipse at 75% 40%, var(--nebula-cyan) 0%, transparent 55%); animation: drift-nebula-bg 180s linear infinite alternate; }
#seccion-menu .nebula-foreground { background-image: radial-gradient(ellipse at 60% 30%, var(--nebula-magenta) 0%, transparent 50%), radial-gradient(ellipse at 20% 80%, var(--nebula-cyan) 0%, transparent 60%); opacity: 0.25; animation: drift-nebula-fg 120s linear infinite alternate; }
@keyframes drift-nebula-bg { from { transform: rotate(0deg) scale(1) translateX(0%) translateY(0%); } to { transform: rotate(15deg) scale(1.1) translateX(10%) translateY(5%); } }
@keyframes drift-nebula-fg { from { transform: rotate(0deg) scale(1.2) translateX(0%) translateY(0%); } to { transform: rotate(-10deg) scale(1.3) translateX(-8%) translateY(-12%); } }
#seccion-menu .planet { position: absolute; top: 0; left: 0; border-radius: 50%; z-index: 2; will-change: transform; }
#seccion-menu .gas-giant { width: 100px; height: 100px; background: radial-gradient(circle at 25% 35%, #89cff0, #4682b4, #1e3f66, #0b1a33); box-shadow: inset -15px -15px 30px rgba(0,0,0,0.6), 0 0 40px rgba(137, 207, 240, 0.2); animation: planet-orbit-1 45s linear infinite; }
#seccion-menu .rocky-planet { width: 60px; height: 60px; background: radial-gradient(circle at 20% 30%, #ff8c69, #cd5c5c, #a52a2a, #5e1919); box-shadow: inset -10px -10px 20px rgba(0,0,0,0.5), 0 0 30px rgba(255, 140, 105, 0.15); animation: planet-orbit-2 32.5s linear infinite; }
@keyframes planet-orbit-1 { from { transform: translate3d(110vw, 10vh, 0) scale(1) rotate(0deg); } to { transform: translate3d(-20vw, 25vh, 0) scale(1.1) rotate(15deg); } }
@keyframes planet-orbit-2 { from { transform: translate3d(20vw, 120vh, 0) scale(1) rotate(0deg); } to { transform: translate3d(70vw, -20vh, 0) scale(0.9) rotate(-20deg); } }
#seccion-menu #menu-intro-screen { z-index: 30; }
#seccion-menu #menu-intro-container { position: relative; will-change: transform; }
#seccion-menu #menu-intro-logo-wrapper { will-change: transform, opacity, filter; }
#seccion-menu .cosmic-logo { width: 150px; height: auto; animation: charge-up 5.5s ease-in-out forwards; }
@keyframes charge-up { 0% { transform: scale(0.1); opacity: 0; filter: brightness(20) blur(20px); } 35% { transform: scale(1); opacity: 1; filter: brightness(4) blur(1px) drop-shadow(0 0 15px white); } 50% { filter: brightness(5) drop-shadow(0 0 25px white) drop-shadow(0 0 50px var(--accent-cuentas)); } 70% { transform: scale(0.95); filter: brightness(4) drop-shadow(0 0 20px white) drop-shadow(0 0 40px var(--accent-agenda)); } 88% { transform: scale(6); filter: brightness(15) drop-shadow(0 0 30px white) drop-shadow(0 0 60px var(--accent-salir)); } 100% { transform: scale(5.5); opacity: 1; filter: brightness(20) drop-shadow(0 0 30px white); } }
#seccion-menu #menu-flash-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: white; z-index: 50; opacity: 0; pointer-events: none; }
#seccion-menu #menu-flash-overlay.active { animation: flash-bang 0.6s ease-out; }
@keyframes flash-bang { 0% { opacity: 1; } 100% { opacity: 0; } }
#seccion-menu #menu-explosion-container { position: absolute; width: 1px; height: 1px; z-index: 40; opacity: 0; pointer-events: none; left: 50%; top: 50%; }
#seccion-menu .shard { position: absolute; top: 0; left: 0; width: 4px; height: 4px; background: white; border-radius: 50%; will-change: transform, opacity; filter: drop-shadow(0 0 6px white); }
@keyframes shatter { from { transform: translate(0, 0) scale(1); opacity: 1; } to { transform: var(--transform-to); opacity: 0; } }
#seccion-menu #menu-main-screen { justify-content: space-between; }
#seccion-menu #menu-quote-container { flex-grow: 1; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; padding: 20px 30px; perspective: 1000px; touch-action: pan-y; }
#seccion-menu #menu-quote-text { font-family: var(--font-quote); font-size: clamp(1.8rem, 5.5vw, 2.5rem); font-weight: 500; color: var(--quote-color); line-height: 1.5; margin-bottom: 25px; text-shadow: 0 0 8px rgba(255,255,255,0.8), 0 0 20px rgba(170, 204, 255, 0.6); transition: opacity 0.5s ease-out, transform 0.6s cubic-bezier(0.19, 1, 0.22, 1); transform-origin: center bottom; }
#seccion-menu #menu-quote-author { font-size: clamp(0.9rem, 3vw, 1.1rem); font-weight: 500; color: var(--author-color); align-self: flex-end; transition: opacity 0.5s ease-out 0.1s, transform 0.6s cubic-bezier(0.19, 1, 0.22, 1); transform-origin: center bottom; }
#seccion-menu #menu-quote-container.fading #menu-quote-text, #seccion-menu #menu-quote-container.fading #menu-quote-author { opacity: 0; transform: rotateX(25deg) translateY(50px); }
#seccion-menu #menu-bottom-nav { position: absolute; bottom: 0; left: 0; width: 100%; flex-shrink: 0; display: flex; justify-content: space-around; align-items: center; padding: 15px 0 25px 0; background: var(--nav-bg-gradient); backdrop-filter: blur(15px); -webkit-backdrop-filter: blur(15px); border-top: 1px solid var(--nav-border-color); box-shadow: 0 -5px 15px rgba(0,0,0,0.3); padding-bottom: calc(25px + env(safe-area-inset-bottom)); }
#seccion-menu .nav-button { display: flex; flex-direction: column; align-items: center; gap: 5px; cursor: pointer; border: none; background: none; color: var(--text-color); transition: transform 0.2s cubic-bezier(0.22, 1, 0.36, 1), color 0.2s ease, text-shadow 0.2s ease; }
#seccion-menu .nav-button:hover { transform: translateY(-4px); }
#seccion-menu .nav-button:active { transform: translateY(-2px) scale(0.95); transition-duration: 0.05s; }
#seccion-menu .nav-button .icon { width: 26px; height: 26px; stroke-width: 1.5; transition: stroke 0.2s ease; }
#seccion-menu .nav-button .label { font-size: 0.7rem; font-weight: 500; letter-spacing: 0.5px; }
#seccion-menu #menu-agenda-btn:hover, #seccion-menu #menu-agenda-btn:active { color: var(--accent-agenda); text-shadow: 0 0 8px var(--accent-agenda); }
#seccion-menu #menu-agenda-btn:hover .icon, #seccion-menu #menu-agenda-btn:active .icon { stroke: var(--accent-agenda); }
#seccion-menu #menu-cuentas-btn:hover, #seccion-menu #menu-cuentas-btn:active { color: var(--accent-cuentas); text-shadow: 0 0 8px var(--accent-cuentas); }
#seccion-menu #menu-cuentas-btn:hover .icon, #seccion-menu #menu-cuentas-btn:active .icon { stroke: var(--accent-cuentas); }
#seccion-menu #menu-salir-btn:hover, #seccion-menu #menu-salir-btn:active { color: var(--accent-salir); text-shadow: 0 0 8px var(--accent-salir); }
#seccion-menu #menu-salir-btn:hover .icon, #seccion-menu #menu-salir-btn:active .icon { stroke: var(--accent-salir); }
#seccion-menu #menu-exit-screen { z-index: 30; background-color: var(--bg-color); }
#seccion-menu #menu-exit-message { font-size: 1.6rem; animation: fade-in-up 1s ease-out; text-shadow: 0 0 10px rgba(255,255,255,0.3); }
@keyframes fade-in-up { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

/* ============================ */
/* ESTILOS PARA: #seccion-agenda (Agenda aiDANaI) */
/* ============================ */
#seccion-agenda {
    --primary-color: #7B68EE; --primary-variant: #5A4CAD; --secondary-color: #9E9EAD;
    --background: #F8F8FA; --surface: #FFFFFF; --surface-variant: #F0F0F5;
    --on-primary: #FFFFFF; --on-background: #1A1C20; --on-surface: #1A1C20;
    --outline: #E0E0E6; --accent-task: #4CAF50; --accent-event-normal: #2196F3;
    --accent-event-important: #F44336; --accent-delete: #E53935; --accent-complete: #43A047;
    --accent-edit: #1E88E5; --font-main: 'Archivo Narrow', 'Roboto', sans-serif;
    --shadow-layered: 0px 4px 8px rgba(26, 28, 32, 0.04), 0px 8px 24px rgba(26, 28, 32, 0.08);
    --ease-out-quint: cubic-bezier(0.22, 1, 0.36, 1);
    font-family: var(--font-main); background-color: var(--background); color: var(--on-background); 
    line-height: 1.5; overflow: hidden; height: 100vh; 
    transition: background-color 0.3s, color 0.3s; font-size: 15px;
}
#seccion-agenda[data-theme="dark"] {
    --primary-color: #A78BFA; --primary-variant: #7B68EE; --secondary-color: #9E9EAD;
    --background: #000000; --surface: #121212; --surface-variant: #1E1E24;
    --on-primary: #000000; --on-background: #EAEAEA; --on-surface: #F5F5F5;
    --outline: #2A2A32; --shadow-layered: 0px 8px 24px rgba(0, 0, 0, 0.2);
}
#seccion-agenda * { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
#seccion-agenda *:focus-visible { outline: 2px solid var(--primary-color); outline-offset: 2px; border-radius: 6px; }
#seccion-agenda #agenda-app-root { display: none; max-width: 420px; margin: 0 auto; height: 100vh; background: var(--background); position: relative; flex-direction: column; opacity: 0; transition: opacity 0.5s ease-out; padding-bottom: calc(52px + env(safe-area-inset-bottom)); }
#seccion-agenda #agenda-app-root.visible { display: flex; opacity: 1; }
#seccion-agenda .main-content { flex: 1; display: flex; position: relative; overflow: hidden; }
#seccion-agenda .view { display: none; width: 100%; flex-direction: column; animation: agenda-slideAndFadeIn 0.4s var(--ease-out-quint); height: 100%; overflow-y: auto; padding: 16px; }
#seccion-agenda #agenda-calendarView { padding: 0; overflow-y: auto; } 
#seccion-agenda .view.active { display: flex; }
@keyframes agenda-slideAndFadeIn { from { opacity: 0; transform: translateY(15px); } to { opacity: 1; transform: translateY(0); } }
#seccion-agenda .bottom-nav { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 100%; max-width: 420px; background: rgba(28, 28, 28, 0.7); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-top: 1px solid rgba(56, 56, 66, 0.5); display: flex; padding: 2px 0 calc(2px + env(safe-area-inset-bottom)) 0; z-index: 100; }
#seccion-agenda[data-theme="light"] .bottom-nav { background: rgba(255, 255, 255, 0.7); border-top: 1px solid rgba(224, 224, 230, 0.5); }
#seccion-agenda .nav-item { flex: 1; display: flex; align-items: center; justify-content: center; padding: 10px 0; cursor: pointer; transition: color 0.2s, background-color 0.2s; color: var(--secondary-color); border: none; background: transparent; border-radius: 8px; }
#seccion-agenda .nav-item.active { color: var(--primary-color); }
#seccion-agenda .nav-item .material-icons { font-size: 24px; margin: 0; }
#seccion-agenda .nav-label { display: none; }
#seccion-agenda .calendar-container { flex-shrink: 0; padding: 8px 16px; border-bottom: 1px solid var(--outline); }
#seccion-agenda .calendar-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
#seccion-agenda .calendar-title-container { position: relative; display: inline-flex; align-items: center; }
#seccion-agenda #agenda-calendar-title-btn { font-size: 16px; font-weight: 700; background: none; border: none; color: var(--on-background); padding: 4px 6px; border-radius: 8px; cursor: pointer; transition: background-color 0.2s; }
#seccion-agenda #agenda-calendar-title-btn:hover { background-color: var(--surface-variant); }
#seccion-agenda .calendar-nav { display: flex; align-items: center; gap: 2px; }
#seccion-agenda .icon-button { background: none; border: none; color: var(--secondary-color); cursor: pointer; width: 32px; height: 32px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; transition: all 0.2s; }
#seccion-agenda .icon-button .material-icons { font-size: 22px; }
#seccion-agenda .icon-button:hover { background-color: var(--surface-variant); color: var(--on-surface); }
#seccion-agenda #agenda-sync-status-indicator { position: absolute; top: 2px; right: -20px; width: 20px; height: 20px; display: flex; align-items: center; justify-content: center; }
#seccion-agenda #agenda-sync-status-indicator .material-icons { font-size: 14px; transition: color 0.3s; }
#seccion-agenda #agenda-sync-status-indicator.online .material-icons { color: var(--accent-complete); }
#seccion-agenda #agenda-sync-status-indicator.offline .material-icons { color: var(--secondary-color); }
#seccion-agenda .view-toggle { display: flex; background-color: var(--surface-variant); border-radius: 10px; overflow: hidden; margin: 0 8px; }
#seccion-agenda .view-toggle .btn-toggle { background: none; border: none; color: var(--secondary-color); padding: 6px 10px; cursor: pointer; transition: all 0.2s; font-size: 14px; display: flex; align-items: center; justify-content: center; }
#seccion-agenda .view-toggle .btn-toggle.active { background-color: var(--primary-color); color: var(--on-primary); box-shadow: 0 2px 6px rgba(123, 104, 238, 0.2); }
#seccion-agenda .view-toggle .btn-toggle:first-child { border-top-left-radius: 8px; border-bottom-left-radius: 8px; }
#seccion-agenda .view-toggle .btn-toggle:last-child { border-top-right-radius: 8px; border-bottom-right-radius: 8px; }
#seccion-agenda .view-toggle .btn-toggle .material-icons { font-size: 20px; }
#seccion-agenda #agenda-calendarView[data-display-mode="month"] #agenda-weekly-view-container { display: none; }
#seccion-agenda #agenda-calendarView[data-display-mode="month"] #agenda-calendar-grid { display: block; }
#seccion-agenda #agenda-calendarView[data-display-mode="month"] #agenda-agendaListContainer { display: block; }
#seccion-agenda #agenda-calendarView[data-display-mode="week"] #agenda-calendar-grid { display: none; }
#seccion-agenda #agenda-calendarView[data-display-mode="week"] #agenda-agendaListContainer { display: none; }
#seccion-agenda #agenda-calendarView[data-display-mode="week"] #agenda-weekly-view-container { display: flex; flex-direction: column; }
#seccion-agenda .calendar-grid { background: var(--surface); border-radius: 12px; padding: 6px; box-shadow: var(--shadow-layered); }
#seccion-agenda .calendar-weekdays { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; margin-bottom: 4px; }
#seccion-agenda .weekday { text-align: center; font-size: 12px; font-weight: 500; color: var(--secondary-color); padding: 4px; }
#seccion-agenda .calendar-days { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
#seccion-agenda .calendar-day { display: flex; flex-direction: column; align-items: center; justify-content: center; border-radius: 10px; cursor: pointer; position: relative; font-size: 14px; transition: all 0.2s; padding: 4px 0; }
#seccion-agenda .day-number { width: 22px; height: 22px; display: flex; align-items: center; justify-content: center; border-radius: 50%; }
#seccion-agenda .calendar-day.today .day-number { background: var(--primary-color); color: var(--on-primary); font-weight: 700; }
#seccion-agenda .calendar-day.selected .day-number { background: var(--primary-variant); color: var(--on-primary); }
#seccion-agenda .calendar-day.other-month { color: var(--outline); pointer-events: none; }
#seccion-agenda .calendar-day .event-dots-container { position: absolute; bottom: 4px; left: 0; right: 0; display: flex; justify-content: center; gap: 3px; }
#seccion-agenda .event-dot { width: 4px; height: 4px; border-radius: 50%; }
#seccion-agenda .event-dot.important { background-color: var(--accent-event-important); }
#seccion-agenda .event-dot.normal { background-color: var(--accent-event-normal); }
#seccion-agenda .agenda-list-container { flex-grow: 1; overflow-y: auto; padding: 8px 16px 80px 16px; }
#seccion-agenda .agenda-date-header { font-weight: 700; letter-spacing: 0.3px; font-size: 12px; color: var(--primary-color); padding: 8px 12px; background-color: var(--surface-variant); position: sticky; top: 0; z-index: 1; border-radius: 8px; margin-top: 8px; margin-bottom: 4px; }
#seccion-agenda #agenda-today-greeting { font-size: 22px; font-weight: 700; margin-bottom: 24px; }
#seccion-agenda .section-title { font-size: 16px; font-weight: 500; margin-bottom: 12px; display: flex; align-items: center; gap: 8px; letter-spacing: 0.2px; margin-top: 24px; }
#seccion-agenda .weekly-view-container { flex-grow: 1; padding: 8px 16px 80px 16px; overflow-y: auto; height: 100%; }
#seccion-agenda .weekly-day-section { margin-bottom: 16px; background: var(--surface); border-radius: 12px; box-shadow: var(--shadow-layered); padding-bottom: 8px; }
#seccion-agenda .weekly-day-header { font-weight: 700; letter-spacing: 0.3px; font-size: 14px; color: var(--primary-color); padding: 12px 16px; background-color: var(--surface-variant); border-top-left-radius: 12px; border-top-right-radius: 12px; margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
#seccion-agenda .weekly-day-header .material-icons { font-size: 18px; }
#seccion-agenda .weekly-day-events { padding: 0 16px; }
#seccion-agenda .weekly-day-events .empty-state { padding: 12px; font-size: 13px; }
#seccion-agenda #agenda-search-container { padding: 4px 16px 8px; transition: max-height 0.4s ease-out, opacity 0.4s ease-out; max-height: 0; opacity: 0; overflow: hidden; }
#seccion-agenda #agenda-search-container.active { max-height: 60px; opacity: 1; }
#seccion-agenda #agenda-search-form { display: flex; gap: 8px; align-items: center; }
#seccion-agenda #agenda-search-input { flex-grow: 1; padding: 10px 16px; border: 1.5px solid var(--outline); border-radius: 24px; background: var(--surface-variant); color: var(--on-surface); font-size: 14px; }
#seccion-agenda #agenda-search-input:focus { outline: none; border-color: var(--primary-color); }
#seccion-agenda .fab { position: absolute; bottom: calc(65px + env(safe-area-inset-bottom)); right: 20px; width: 56px; height: 56px; border-radius: 50%; background-color: var(--primary-color); color: var(--on-primary); border: none; box-shadow: var(--shadow-layered); display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 150; transition: background-color 0.2s, transform 0.2s var(--ease-out-quint); }
#seccion-agenda .fab:hover { background-color: var(--primary-variant); transform: scale(1.05); }
#seccion-agenda .fab:active { transform: scale(0.9); }
#seccion-agenda .fab .material-icons { font-size: 28px; }
#seccion-agenda .list-item-swipe-container { display: flex; align-items: flex-start; background: var(--surface); border-radius: 8px; margin-bottom: 6px; box-shadow: var(--shadow-layered); transition: transform 0.3s var(--ease-out-quint), opacity 0.3s, border-left-color 0.3s; user-select: none; position: relative; padding: 8px 10px; border-left: 4px solid transparent; }
#seccion-agenda .list-item-swipe-container .item-icon { color: var(--secondary-color); margin-right: 8px; padding-top: 2px; font-size: 22px; display: flex; align-items: center; justify-content: center; z-index: 2; position: relative; }
#seccion-agenda .list-item-swipe-container .item-checkbox .material-icons { font-size: 24px; cursor: pointer; transition: color 0.2s; color: var(--secondary-color); }
#seccion-agenda .list-item-swipe-container.completed .item-checkbox .material-icons { color: var(--accent-complete); }
#seccion-agenda .list-item-swipe-container .item-content { flex: 1; cursor: pointer; min-width: 0; display: flex; flex-direction: column; justify-content: center; z-index: 2; position: relative; }
#seccion-agenda .item-card-swipe-background { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-radius: 8px; display: flex; align-items: center; justify-content: space-between; padding: 0 24px; color: white; opacity: 0; transition: opacity 0.2s; z-index: 1; pointer-events: none; }
#seccion-agenda .list-item-swipe-container.swiping-right.type-task .item-card-swipe-background { background-color: var(--accent-complete); justify-content: flex-start; opacity: 1; }
#seccion-agenda .list-item-swipe-container.swiping-right.type-agenda .item-card-swipe-background { background-color: var(--accent-complete); justify-content: flex-start; opacity: 1; }
#seccion-agenda .list-item-swipe-container.swiping-left .item-card-swipe-background { background-color: var(--accent-delete); justify-content: flex-end; opacity: 1; }
#seccion-agenda .list-item-swipe-container.swiping-right .item-card-swipe-background .material-icons:first-child,
#seccion-agenda .list-item-swipe-container.swiping-left .item-card-swipe-background .material-icons:last-child { animation: agenda-bounceIn 0.3s ease-out; }
@keyframes agenda-bounceIn { 0% { transform: scale(0.5); opacity: 0; } 70% { transform: scale(1.1); opacity: 1; } 100% { transform: scale(1); } }
#seccion-agenda .list-item-swipe-container.completed { opacity: 0.6; }
#seccion-agenda .list-item-swipe-container.completed .item-title { text-decoration: line-through; text-decoration-color: var(--secondary-color); }
#seccion-agenda .item-title { font-weight: 500; font-size: 14px; white-space: normal; word-break: break-word; line-height: 1.3; font-family: var(--font-main); }
#seccion-agenda .event-time { font-size: 13px; font-weight: 700; color: var(--secondary-color); padding-top: 1px; }
#seccion-agenda .event-meta-icon { font-size: 16px; color: var(--secondary-color); flex-shrink: 0; }
#seccion-agenda .item-metadata-container { display: flex; align-items: center; gap: 8px; margin-top: 2px; color: var(--secondary-color); }
#seccion-agenda .task-progress-container { margin-top: 8px; }
#seccion-agenda .progress-bar-wrapper { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--secondary-color); }
#seccion-agenda .progress-bar { flex-grow: 1; background: var(--outline); border-radius: 4px; height: 4px; overflow: hidden; }
#seccion-agenda .progress-bar-fill { width: 0%; height: 100%; background: var(--primary-color); transition: width 0.3s; }
#seccion-agenda .subtasks-list-view { margin-top: 6px; padding-left: 4px; display: flex; flex-direction: column; gap: 4px; }
#seccion-agenda .subtask-list-view-item { display: flex; align-items: center; gap: 8px; font-size: 13px; cursor: pointer; padding: 2px 4px; border-radius: 4px; transition: background-color 0.2s; }
#seccion-agenda .subtask-list-view-item:hover { background-color: var(--surface-variant); }
#seccion-agenda .subtask-list-view-item .material-icons { font-size: 18px; color: var(--secondary-color); transition: color 0.2s; }
#seccion-agenda .subtask-list-view-item.completed { text-decoration: line-through; color: var(--secondary-color); }
#seccion-agenda .subtask-list-view-item.completed .material-icons { color: var(--accent-complete); }
#seccion-agenda .modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.3); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); display: flex; align-items: flex-end; justify-content: center; z-index: 1000; opacity: 0; pointer-events: none; transition: opacity 0.4s var(--ease-out-quint); }
#seccion-agenda .modal-overlay.active { opacity: 1; pointer-events: auto; }
#seccion-agenda .modal { background: var(--surface); border-radius: 24px 24px 0 0; padding: 16px 24px 24px 24px; width: 100%; max-width: 420px; max-height: 95vh; overflow-y: auto; box-shadow: var(--shadow-layered); transform: translateY(100%); transition: transform 0.4s var(--ease-out-quint); }
#seccion-agenda .modal-overlay.active .modal { transform: translateY(0); }
#seccion-agenda .modal-grabber { width: 40px; height: 5px; background-color: var(--outline); border-radius: 2.5px; margin: 0 auto 16px; flex-shrink: 0; }
#seccion-agenda .form-group { margin-bottom: 16px; }
#seccion-agenda .form-label { display: block; font-size: 13px; font-weight: 500; margin-bottom: 8px; color: var(--secondary-color); }
#seccion-agenda .form-input, #seccion-agenda .form-select, #seccion-agenda .form-textarea { width: 100%; padding: 12px; border: 1.5px solid var(--outline); border-radius: 10px; background: var(--surface); color: var(--on-surface); font-size: 14px; font-family: var(--font-main); }
#seccion-agenda .form-input:focus, #seccion-agenda .form-select:focus, #seccion-agenda .form-textarea:focus { outline: none; border-color: var(--primary-color); box-shadow: 0 0 0 3px rgba(123, 104, 238, 0.2); }
#seccion-agenda .form-actions { display: flex; align-items: center; justify-content: space-between; margin-top: 24px; }
#seccion-agenda .btn-icon { width: 44px; height: 44px; border-radius: 50%; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.2s; }
#seccion-agenda .btn-icon .material-icons { font-size: 24px; }
#seccion-agenda #agenda-delete-item-btn { background-color: transparent; color: var(--accent-delete); }
#seccion-agenda #agenda-delete-item-btn:hover { background-color: rgba(229, 57, 53, 0.1); }
#seccion-agenda #agenda-save-item-btn { background-color: var(--primary-color); color: var(--on-primary); box-shadow: 0 4px 12px rgba(123, 104, 238, 0.3); }
#seccion-agenda #agenda-save-item-btn:hover { background-color: var(--primary-variant); }
#seccion-agenda .btn { padding: 10px 20px; border: none; border-radius: 24px; font-size: 14px; font-weight: 500; cursor: pointer; transition: all 0.2s; display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-main); }
#seccion-agenda .btn-primary { background: var(--primary-color); color: var(--on-primary); }
#seccion-agenda .btn-secondary { background: transparent; color: var(--secondary-color); border: 1.5px solid var(--outline); }
#seccion-agenda .btn-link { background: none; border: none; color: var(--primary-color); font-weight: 500; cursor: pointer; }
#seccion-agenda .form-group-datetime, #seccion-agenda #agenda-task-options-group { display: none; }
#seccion-agenda .subtask-item { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
#seccion-agenda .subtask-item input[type="checkbox"] { flex-shrink: 0; width: 20px; height: 20px; accent-color: var(--primary-color); }
#seccion-agenda .subtask-item input[type="text"] { flex-grow: 1; font-size: 14px; border: none; background: transparent; border-bottom: 1px solid var(--outline); border-radius: 0; padding: 4px 0; color: var(--on-surface); }
#seccion-agenda .subtask-item input[type="text"]:focus { outline: none; border-bottom-color: var(--primary-color); }
#seccion-agenda .subtask-item .delete-subtask-btn { color: var(--secondary-color); font-size: 20px; }
#seccion-agenda .empty-state { text-align: center; padding: 40px 24px; color: var(--secondary-color); }
#seccion-agenda .empty-state .material-icons { font-size: 48px; margin-bottom: 8px; }
#seccion-agenda .intro-screen { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 9999; display: none; align-items: center; justify-content: center; flex-direction: column; background-color: #000; transition: opacity 0.5s ease-out; }
#seccion-agenda .intro-screen.visible { display: flex; }
#seccion-agenda #agenda-welcomeImage { width: 250px; height: auto; opacity: 0; animation: agenda-growAndFade 2.5s ease-in-out forwards; }
@keyframes agenda-growAndFade { 0% { transform: scale(0.5); opacity: 0; } 70% { transform: scale(1.1); opacity: 1; } 100% { transform: scale(8); opacity: 0; } }
#seccion-agenda #agenda-quoteScreen { text-align: center; color: #FFF; padding: 20px; opacity: 0; transition: opacity 1.5s; background-color: #000; }
#seccion-agenda #agenda-quoteText { font-size: 22px; font-style: italic; font-weight: 300; max-width: 600px; }
#seccion-agenda #agenda-quoteAuthor { display: block; font-size: 16px; margin-top: 12px; font-weight: 500; }
#seccion-agenda .login-view { position: absolute; inset: 0; z-index: 1040; display: none; flex-direction: column; justify-content: center; align-items: center; padding: 1rem; opacity: 0; transition: opacity .5s; background-color: var(--background); }
#seccion-agenda .login-view--visible { display: flex; opacity: 1; }
#seccion-agenda .login-view__card { background-color: var(--surface); padding: 1.25rem; border-radius: 18px; box-shadow: var(--shadow-layered); width: 100%; max-width: 340px; text-align: center; animation: agenda-pop-in 0.3s ease-out; }
@keyframes agenda-pop-in { from { transform: scale(0.95); opacity: 0; } to { transform: scale(1); opacity: 1; } }
#seccion-agenda #agenda-toast-container { position: fixed; bottom: calc(60px + env(safe-area-inset-bottom)); left: 50%; transform: translateX(-50%); z-index: 2000; display: flex; flex-direction: column; align-items: center; gap: 8px; }
#seccion-agenda .toast { background-color: rgba(30, 30, 36, 0.8); backdrop-filter: blur(5px); color: white; padding: 10px 18px; border-radius: 12px; box-shadow: var(--shadow-layered); display: flex; align-items: center; animation: agenda-toastFadeIn 0.4s var(--ease-out-quint), agenda-toastFadeOut 0.4s 2.6s var(--ease-out-quint); font-size: 14px; }
@keyframes agenda-toastFadeIn { from { opacity: 0; transform: translateY(20px) scale(0.95); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes agenda-toastFadeOut { from { opacity: 1; transform: translateY(0) scale(1); } to { opacity: 0; transform: translateY(10px) scale(0.95); } }
#seccion-agenda .tasks-header { display: flex; align-items: center; justify-content: space-between; padding: 0 0 16px 0; }
#seccion-agenda .tasks-header .form-select { flex-grow: 1; }
#seccion-agenda .tasks-header .icon-button { flex-shrink: 0; margin-left: 8px; }
#seccion-agenda .help-section details { background: var(--surface); padding: 12px; border-radius: 10px; margin-bottom: 8px; border: 1px solid var(--outline); }
#seccion-agenda .help-section summary { font-weight: 700; cursor: pointer; display: flex; justify-content: space-between; align-items: center; list-style: none; }
#seccion-agenda .help-section summary::-webkit-details-marker { display: none; }
#seccion-agenda .help-section summary .material-icons { transition: transform 0.2s; }
#seccion-agenda .help-section details[open] summary .material-icons { transform: rotate(180deg); }
#seccion-agenda .help-section .details-content { padding-top: 12px; }
#seccion-agenda .help-section ul { padding-left: 20px; } #seccion-agenda .help-section li { margin-bottom: 10px; }
@media (min-width: 768px) { #seccion-agenda #agenda-app-root { max-width: 720px; } #seccion-agenda .bottom-nav { max-width: 720px; } #seccion-agenda { font-size: 16px; } #seccion-agenda .modal-overlay { align-items: center; } #seccion-agenda .modal { border-radius: 24px; transform: translateY(0); max-height: 80vh; } }
@media (min-width: 1024px) { #seccion-agenda { overflow-y: auto; } #seccion-agenda #agenda-app-root { flex-direction: row; max-width: 100%; height: 100vh; padding-bottom: 0; } #seccion-agenda .bottom-nav { position: static; transform: none; flex-direction: column; width: auto; max-width: none; height: 100vh; border-top: none; border-right: 1px solid var(--outline); padding: 24px 8px; justify-content: flex-start; gap: 8px; background: var(--surface); backdrop-filter: none; } #seccion-agenda[data-theme="light"] .bottom-nav { background: var(--surface); } #seccion-agenda .nav-item { flex: 0; flex-direction: row; justify-content: center; width: 100%; padding: 12px; } #seccion-agenda .nav-item:hover { background-color: var(--surface-variant); } #seccion-agenda .nav-item.active { background-color: var(--primary-color); color: var(--on-primary); } #seccion-agenda[data-theme="dark"] .nav-item.active { background-color: var(--primary-variant); } #seccion-agenda .nav-item .material-icons { margin: 0; } #seccion-agenda #agenda-toast-container { bottom: 24px; left: calc(50% + 70px); } #seccion-agenda .main-content { height: 100vh; overflow-y: auto; } #seccion-agenda #agenda-calendarView { flex-direction: row; align-items: flex-start; gap: 24px; padding: 24px; overflow-y: hidden; } #seccion-agenda .calendar-container { flex: 0 0 400px; border-bottom: none; padding: 0; position: sticky; top: 0; height: auto; } #seccion-agenda #agenda-calendar-grid { flex-shrink: 0; } #seccion-agenda #agenda-agendaListContainer { flex-grow: 1; padding: 0; height: calc(100vh - 48px); overflow-y: auto; } #seccion-agenda #agenda-weekly-view-container { flex-grow: 1; height: calc(100vh - 48px); overflow-y: auto; } #seccion-agenda .view#agenda-todayView, #seccion-agenda .view#agenda-tasksView, #seccion-agenda .view#agenda-helpView, #seccion-agenda .view#agenda-searchView { max-width: 800px; margin: 0 auto; padding: 32px; } #seccion-agenda .fab { bottom: 32px; right: 32px; } }

/* ============================ */
/* ESTILOS PARA: #seccion-cuentas (Cuentas Personales) */
/* ============================ */
#seccion-cuentas {
    --c-primary: #0A84FF; --c-primary-hover: #0076e6; --c-background: #F2F2F7; --c-surface: #FFFFFF;
    --c-surface-variant: #E9E9EB; --c-on-surface: #000000; --c-on-surface-secondary: #8A8A8E; --c-outline: #D1D1D6;
    --c-success: #34C759; --c-danger: #FF3B30; --c-warning: #FF9500; --c-info: #5AC8FA; --c-white: #FFFFFF; --c-black: #000000;
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05); --shadow-md: 0 6px 20px 0 rgba(0, 0, 0, 0.1); --font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', 'Roboto', 'Helvetica Neue', Arial, sans-serif;
    --fs-xs: 0.7rem; --fs-sm: 0.825rem; --fs-base: 0.95rem; --fs-lg: 1.05rem; --fs-xl: 1.15rem;
    --sp-1: 0.2rem; --sp-2: 0.4rem; --sp-3: 0.6rem; --sp-4: 0.8rem; --sp-5: 1rem; --sp-6: 1.25rem;
    --border-radius-md: 8px; --border-radius-lg: 14px;
    font-family: var(--font-family); background-color: var(--c-background); color: var(--c-on-surface); line-height: 1.4;
    transition: background-color 0.3s, color 0.3s; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; 
    overflow: hidden; font-weight: 400; height: 100vh;
}
#seccion-cuentas * { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
#seccion-cuentas[data-theme="dark"] {
    --c-primary: #0A84FF; --c-primary-hover: #339aff; --c-background: #000000; --c-surface: #1C1C1E; --c-surface-variant: #2C2C2E;
    --c-on-surface: #FFFFFF; --c-on-surface-secondary: #8D8D93; --c-outline: #38383A; --c-success: #30D158; --c-danger: #FF453A;
    --c-warning: #FF9F0A; --c-info: #64D2FF; --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.15); --shadow-md: 0 6px 20px 0 rgba(0, 0, 0, 0.25);
}
#seccion-cuentas *:focus-visible { outline: 2px solid var(--c-primary); outline-offset: 2px; border-radius: var(--sp-2); }
#seccion-cuentas .highlight-animation { animation: cuentas-highlight-card 1.5s ease-out; }
@keyframes cuentas-highlight-card { 0% { background-color: color-mix(in srgb, var(--c-primary) 15%, transparent); } 100% { background-color: transparent; } }
#seccion-cuentas .skeleton { background-color: var(--c-surface-variant); background-image: linear-gradient(90deg, var(--c-surface-variant), color-mix(in srgb, var(--c-outline) 20%, var(--c-surface-variant)), var(--c-surface-variant)); background-size: 200% 100%; animation: cuentas-shimmer 1.5s infinite linear; border-radius: var(--sp-2); color: transparent !important; user-select: none; }
@keyframes cuentas-shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
#seccion-cuentas .skeleton > * { visibility: hidden; }
#seccion-cuentas .intro-screen { position: absolute; inset: 0; z-index: 9999; display: flex; justify-content: center; align-items: center; background-color: #111827; transition: opacity 0.75s ease-in-out; }
#seccion-cuentas .starry-background { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: radial-gradient(1px 1px at 10% 20%,#fff,transparent),radial-gradient(1px 1px at 80% 30%,#fff,transparent),radial-gradient(2px 2px at 50% 50%,#fff,transparent),radial-gradient(1px 1px at 30% 80%,#fff,transparent),radial-gradient(2px 2px at 90% 90%,#fff,transparent); background-size: 300px 300px; animation: cuentas-twinkle 15s linear infinite; }
@keyframes cuentas-twinkle { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
#seccion-cuentas .intro-screen__logo { width: 250px; height: auto; border-radius: 24px; opacity: 0; position: absolute; animation: cuentas-logoExplode 2.5s cubic-bezier(0.5, 0, 0.5, 1) forwards; }
@keyframes cuentas-logoExplode { 0% { transform: scale(0.2) rotate(-25deg); opacity: 0; } 30% { transform: scale(1.1) rotate(10deg); opacity: 1; } 50% { transform: scale(0.95) rotate(-8deg); opacity: 1; } 80% { transform: scale(1.5) rotate(5deg); opacity: 1; } 100% { transform: scale(12) rotate(20deg); opacity: 0; } }
#seccion-cuentas .intro-screen__quote-container { text-align: center; color: var(--c-white); padding: var(--sp-5); max-width: 800px; z-index: 1; opacity: 0; transition: opacity 1.5s ease-in-out; }
#seccion-cuentas .intro-screen__quote-container.visible { opacity: 1; }
#seccion-cuentas .intro-screen__quote-text { font-size: clamp(1.2rem, 4vw, 1.8rem); font-style: italic; font-weight: 400; line-height: 1.4; margin-bottom: 16px; text-shadow: 0 0 15px rgba(255, 255, 255, 0.5); }
#seccion-cuentas .intro-screen__quote-author { display: block; font-size: clamp(0.8rem, 2.4vw, 1rem); color: var(--c-on-surface-secondary); font-weight: 500; }
#seccion-cuentas .app-layout { display: none; max-width: 500px; margin: 0 auto; height: 100vh; background-color: var(--c-background); flex-direction: column; opacity: 0; transition: opacity 0.5s ease-out; }
#seccion-cuentas .app-layout--visible { display: flex; opacity: 1; }
#seccion-cuentas .app-layout__main { flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch; padding: 44px 0 48px 0; }
#seccion-cuentas .view { display: none; flex-direction: column; width: 100%; padding: 0 var(--sp-4); gap: var(--sp-4); }
#seccion-cuentas .view--active { display: flex; animation: cuentas-fade-in 0.3s ease-in-out; }
@keyframes cuentas-fade-in { from { opacity: 0; } to { opacity: 1; } }
#seccion-cuentas .top-bar { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-2) var(--sp-4); background-color: color-mix(in srgb, var(--c-surface) 80%, transparent); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-bottom: 1px solid var(--c-outline); z-index: 200; height: 44px; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 100%; max-width: 500px; transition: background-color 0.3s ease-in-out; }
#seccion-cuentas .top-bar__title { font-size: var(--fs-lg); font-weight: 700; margin-right: auto; padding-left: var(--sp-2); }
#seccion-cuentas .top-bar__actions { display: flex; align-items: center; gap: var(--sp-1); }
#seccion-cuentas .top-bar__left-button { min-width: 85px; }
#seccion-cuentas .bottom-nav { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 100%; max-width: 500px; background-color: var(--c-surface); border-top: 1px solid var(--c-outline); display: flex; padding-bottom: env(safe-area-inset-bottom); z-index: 200; box-shadow: 0 -2px 8px rgba(0,0,0,0.05); height: 48px; }
#seccion-cuentas .bottom-nav__item { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: var(--sp-1) var(--sp-2); cursor: pointer; transition: color 0.2s; color: var(--c-on-surface-secondary); border: none; background: none; }
#seccion-cuentas .bottom-nav__item--active { color: var(--c-primary); }
#seccion-cuentas .bottom-nav__item .material-icons { font-size: 22px; } 
#seccion-cuentas .bottom-nav__label { display: none; font-size: var(--fs-xs); margin-top: 2px; }
#seccion-cuentas .fab { position: absolute; bottom: calc(56px + env(safe-area-inset-bottom)); right: var(--sp-5); width: 56px; height: 56px; background-color: var(--c-primary); color: var(--c-white); border: none; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-md); z-index: 50; transform: scale(0); opacity: 0; transition: transform 0.2s ease-out, opacity 0.2s ease-out; }
#seccion-cuentas .fab--visible { transform: scale(1); opacity: 1; }
#seccion-cuentas .fab:hover { transform: scale(1.08) !important; } #seccion-cuentas .fab .material-icons { font-size: 28px; }
#seccion-cuentas .modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); backdrop-filter: blur(4px); display: flex; align-items: flex-end; justify-content: center; z-index: 1050; opacity: 0; transition: opacity 0.3s; pointer-events: none; }
#seccion-cuentas .modal-overlay--active { opacity: 1; pointer-events: auto; }
#seccion-cuentas .modal { background: var(--c-surface); border-radius: var(--border-radius-lg) var(--border-radius-lg) 0 0; padding: var(--sp-5); width: 100%; max-width: 420px; max-height: 90vh; display: flex; flex-direction: column; box-shadow: var(--shadow-md); transform: translateY(100%); transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); animation: cuentas-pop-in 0.4s cubic-bezier(0.4, 0, 0.2, 1); }
@keyframes cuentas-pop-in { from { transform: scale(0.95); opacity: 0; } to { transform: scale(1); opacity: 1; } }
#seccion-cuentas .modal-overlay--active .modal { transform: translateY(0); }
#seccion-cuentas .card { background: var(--c-surface); border: none; box-shadow: var(--shadow-sm); padding: 0; border-radius: var(--border-radius-lg); overflow: hidden; }
#seccion-cuentas .card__title { font-size: var(--fs-lg); font-weight: 600; margin-bottom: var(--sp-3); display: flex; align-items: center; gap: var(--sp-2); color: var(--c-primary); padding: var(--sp-4) var(--sp-4) 0 var(--sp-4); }
#seccion-cuentas .card__content { padding: 0 var(--sp-4) var(--sp-4) var(--sp-4); }
#seccion-cuentas .card__title .material-icons { font-size: var(--fs-lg); }
#seccion-cuentas .card--no-bg { background: none; border: none; box-shadow: none; padding: 0; border-radius: 0; }
#seccion-cuentas .chart-container { position: relative; height: 220px; width: 100%; margin-bottom: var(--sp-4); }
#seccion-cuentas .kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: var(--sp-3); }
#seccion-cuentas .kpi-item { background: var(--c-surface); border-radius: var(--border-radius-lg); padding: var(--sp-3); text-align: center; transition: background-color 0.3s; }
#seccion-cuentas .kpi-item__label { font-size: var(--fs-xs); font-weight: 500; color: var(--c-on-surface-secondary); margin-bottom: var(--sp-1); text-transform: uppercase; }
#seccion-cuentas .kpi-item__value { font-size: var(--fs-base); font-weight: 700; }
#seccion-cuentas .kpi-item__comparison { font-size: var(--fs-xs); font-weight: 500; margin-top: var(--sp-1); height: 14px; }
#seccion-cuentas #cuentas-movimientos-list-container { position: relative; padding: 0 var(--sp-4); }
#seccion-cuentas #cuentas-virtual-list-sizer { position: relative; width: 100%; }
#seccion-cuentas #cuentas-virtual-list-content { position: absolute; top: 0; left: 0; width: 100%; }
#seccion-cuentas .transaction-card { display: flex; align-items: flex-start; padding: var(--sp-2) 0; cursor: pointer; border-bottom: 1px solid var(--c-outline); line-height: 1.25; min-height: 0; }
#seccion-cuentas .transaction-card:last-child { border-bottom: none; }
#seccion-cuentas .transaction-card__indicator { flex-shrink: 0; width: 3px; align-self: stretch; border-radius: 99px; margin-right: var(--sp-2); }
#seccion-cuentas .transaction-card__indicator--income { background-color: var(--c-success); }
#seccion-cuentas .transaction-card__indicator--expense { background-color: var(--c-danger); }
#seccion-cuentas .transaction-card__indicator--transfer { background-color: var(--c-info); }
#seccion-cuentas .transaction-card__content { flex-grow: 1; display: flex; justify-content: space-between; align-items: center; min-width: 0; }
#seccion-cuentas .transaction-card__details { flex-grow: 1; min-width: 0; padding-right: var(--sp-2); }
#seccion-cuentas .transaction-card__row-1, #seccion-cuentas .transaction-card__concept { font-size: var(--fs-sm); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#seccion-cuentas .transaction-card__row-2, #seccion-cuentas .transaction-card__description { font-size: var(--fs-xs); color: var(--c-on-surface-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#seccion-cuentas .transaction-card__figures { flex-shrink: 0; text-align: right; }
#seccion-cuentas .transaction-card__amount { font-size: var(--fs-sm); font-weight: 600; display: block; }
#seccion-cuentas .transaction-card__balance { font-size: 0.7rem; color: var(--c-on-surface-secondary); display: block; }
#seccion-cuentas .transaction-card__transfer-details { display: flex; flex-direction: column; gap: 0; margin: 2px 0 0 0; }
#seccion-cuentas .transaction-card__transfer-row { display: flex; justify-content: space-between; align-items: center; color: var(--c-on-surface-secondary); font-size: 0.75rem; }
#seccion-cuentas .transaction-card__transfer-row .material-icons { font-size: 11px; vertical-align: middle; margin-right: var(--sp-1); }
#seccion-cuentas .transaction-card__transfer-row > span:first-child { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#seccion-cuentas #cuentas-movimiento-modal .modal__actions { justify-content: space-between; align-items: center; padding: var(--sp-2) 0; }
#seccion-cuentas #cuentas-movimiento-modal .modal__actions .icon-btn { width: 44px; height: 44px; }
#seccion-cuentas #cuentas-movimiento-modal .modal__actions .icon-btn .material-icons { font-size: 24px; }
#seccion-cuentas #cuentas-movimiento-modal .modal__actions .btn--danger { background: none; color: var(--c-danger); }
#seccion-cuentas #cuentas-movimiento-modal .modal__actions .btn--secondary { background: none; color: var(--c-on-surface-secondary); }
#seccion-cuentas #cuentas-save-movimiento-btn { width: 56px; height: 56px; border-radius: 50%; padding: 0; }
#seccion-cuentas #cuentas-save-movimiento-btn .material-icons { font-size: 28px; }
#seccion-cuentas .accordion { margin-bottom: 0; background-color: var(--c-surface); overflow: hidden; }
#seccion-cuentas .accordion-wrapper > .accordion:first-child { border-top-left-radius: var(--border-radius-lg); border-top-right-radius: var(--border-radius-lg); }
#seccion-cuentas .accordion-wrapper > .accordion:last-child { border-bottom-left-radius: var(--border-radius-lg); border-bottom-right-radius: var(--border-radius-lg); }
#seccion-cuentas .accordion-wrapper > .accordion:not(:last-child) { border-bottom: 1px solid var(--c-outline); border-radius: 0; }
#seccion-cuentas .accordion-wrapper > .accordion:not(:last-child) > summary { border-bottom: none; }
#seccion-cuentas .accordion[open] > summary { border-bottom: 1px solid var(--c-outline); }
#seccion-cuentas .accordion > summary { font-weight: 600; cursor: pointer; padding: var(--sp-3) var(--sp-4); display: flex; align-items: center; justify-content: space-between; list-style: none; font-size: var(--fs-base); }
#seccion-cuentas .accordion > summary::-webkit-details-marker { display: none; }
#seccion-cuentas .accordion > summary .accordion__icon { transition: transform 0.2s; color: var(--c-on-surface-secondary); }
#seccion-cuentas .accordion[open] > summary .accordion__icon { transform: rotate(180deg); }
#seccion-cuentas .accordion__content { padding: 0 var(--sp-4) var(--sp-4) var(--sp-4); }
#seccion-cuentas .card > .accordion { border-radius: 0; }
#seccion-cuentas .account-group { background: var(--c-surface); border-radius: var(--border-radius-lg); margin-bottom: var(--sp-3); overflow: hidden; }
#seccion-cuentas .account-group__header { display: flex; justify-content: space-between; align-items: center; padding: var(--sp-2) var(--sp-4); border-bottom: 1px solid var(--c-outline); }
#seccion-cuentas .account-group__name { font-size: var(--fs-base); font-weight: 600; }
#seccion-cuentas .account-group__balance { font-size: var(--fs-sm); font-weight: 500; }
#seccion-cuentas .account-group .modal__list-item { padding: var(--sp-2) var(--sp-4); }
#seccion-cuentas .form-group { margin-bottom: var(--sp-3); position: relative; }
#seccion-cuentas .form-label { display: block; font-size: var(--fs-sm); font-weight: 500; margin-bottom: var(--sp-2); color: var(--c-on-surface-secondary); }
#seccion-cuentas .form-input, #seccion-cuentas .form-select { width: 100%; padding: var(--sp-3); border: 1px solid var(--c-outline); border-radius: var(--border-radius-md); background: var(--c-surface-variant); color: var(--c-on-surface); font-size: var(--fs-base); appearance: none; transition: border-color 0.2s, box-shadow 0.2s, background-color 0.2s; }
#seccion-cuentas .form-input:focus, #seccion-cuentas .form-select:focus { outline: none; border-color: var(--c-primary); background-color: var(--c-surface); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 20%, transparent); }
#seccion-cuentas .form-select { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23333' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e"); background-repeat: no-repeat; background-position: right 12px center; background-size: 14px; padding-right: 36px; }
#seccion-cuentas[data-theme=dark] .form-select { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23FFF' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e"); }
#seccion-cuentas .form-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-3); }
#seccion-cuentas .form-group-addon { display: flex; align-items: flex-end; gap: var(--sp-2); }
#seccion-cuentas .form-group-addon .form-group { flex-grow: 1; margin-bottom: 0; }
#seccion-cuentas .form-error { color: var(--c-danger); font-size: var(--fs-xs); margin-top: var(--sp-1); min-height: 14px; display: block; }
#seccion-cuentas .form-input--invalid { border-color: var(--c-danger) !important; }
#seccion-cuentas .form-checkbox-group { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: var(--sp-2); }
#seccion-cuentas .form-checkbox-group label { margin-bottom: 0; font-weight: normal; }
#seccion-cuentas .form-checkbox-group input[type="radio"], #seccion-cuentas .form-checkbox-group input[type="checkbox"] { accent-color: var(--c-primary); }
#seccion-cuentas .form-switch-group { display: flex; align-items: center; justify-content: space-between; }
#seccion-cuentas .form-switch { position: relative; display: inline-block; width: 44px; height: 26px; }
#seccion-cuentas .form-switch input { opacity: 0; width: 0; height: 0; }
#seccion-cuentas .form-switch .slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: var(--c-surface-variant); transition: .4s; border-radius: 34px; }
#seccion-cuentas .form-switch .slider:before { position: absolute; content: ""; height: 20px; width: 20px; left: 3px; bottom: 3px; background-color: white; transition: .4s; border-radius: 50%; }
#seccion-cuentas .form-switch input:checked + .slider { background-color: var(--c-success); }
#seccion-cuentas .form-switch input:checked + .slider:before { transform: translateX(18px); }
#seccion-cuentas .btn { padding: var(--sp-3) var(--sp-4); border: 1px solid transparent; border-radius: var(--border-radius-md); font-size: var(--fs-sm); font-weight: 600; cursor: pointer; transition: all 0.2s; display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2); -webkit-user-select: none; user-select: none; }
#seccion-cuentas .btn:active { transform: scale(0.97); }
#seccion-cuentas .btn--primary { background-color: var(--c-primary); color: var(--c-white); } #seccion-cuentas .btn--primary:hover { background-color: var(--c-primary-hover); }
#seccion-cuentas .btn--secondary { background-color: var(--c-surface-variant); color: var(--c-on-surface); } #seccion-cuentas .btn--secondary:hover { background-color: color-mix(in srgb, var(--c-outline) 20%, var(--c-surface-variant)); }
#seccion-cuentas .btn--danger { background-color: var(--c-danger); color: var(--c-white); } #seccion-cuentas .btn--full { width: 100%; } #seccion-cuentas .btn--loading { pointer-events: none; opacity: .8; }
#seccion-cuentas .icon-btn { background: none; border: none; color: var(--c-on-surface-secondary); cursor: pointer; width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; transition: background-color 0.2s, color 0.2s, transform 0.2s; }
#seccion-cuentas .icon-btn .material-icons { font-size: 20px; }
#seccion-cuentas .icon-btn:hover { background-color: var(--c-surface-variant); color: var(--c-on-surface); }
#seccion-cuentas .icon-btn:active { transform: scale(0.9); }
#seccion-cuentas .modal__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-3); flex-shrink: 0;}
#seccion-cuentas .modal__title { font-size: var(--fs-lg); font-weight: 600; }
#seccion-cuentas .modal__body { overflow-y: auto; flex-grow: 1; -webkit-overflow-scrolling: touch; padding-right: var(--sp-2); margin-right: calc(-1 * var(--sp-2)); }
#seccion-cuentas .modal__list-item { display:flex; justify-content:space-between; align-items:center; padding: var(--sp-3) 0; border-bottom:1px solid var(--c-outline); gap: var(--sp-2); }
#seccion-cuentas .modal__list-item:last-child { border-bottom: none; }
#seccion-cuentas .modal__actions { margin-top: var(--sp-4); display: flex; justify-content: flex-end; gap: var(--sp-2); width: 100%;}
#seccion-cuentas #cuentas-generic-modal-body h3, #seccion-cuentas #cuentas-generic-modal-body h4 { margin-top: 1.2em; margin-bottom: 0.6em; color: var(--c-primary); } 
#seccion-cuentas #cuentas-generic-modal-body h4 { font-size: var(--fs-base); font-weight: 600; } 
#seccion-cuentas #cuentas-generic-modal-body p, #seccion-cuentas #cuentas-generic-modal-body li, #seccion-cuentas #cuentas-generic-modal-body small { color: var(--c-on-surface-secondary); line-height: 1.5; } 
#seccion-cuentas #cuentas-generic-modal-body ul, #seccion-cuentas #cuentas-generic-modal-body ol { list-style-position: inside; padding-left: var(--sp-2); } 
#seccion-cuentas #cuentas-generic-modal-body ul li, #seccion-cuentas #cuentas-generic-modal-body ol li { margin-bottom: 6px; }
#seccion-cuentas #cuentas-generic-modal-body ul ul { margin-top: 6px; }
#seccion-cuentas #cuentas-generic-modal-body a { color: var(--c-primary); text-decoration: none; }
#seccion-cuentas #cuentas-generic-modal-body a:hover { text-decoration: underline; }
#seccion-cuentas .login-view { position: absolute; inset: 0; z-index: 1040; display: none; flex-direction: column; justify-content: center; align-items: center; padding: var(--sp-4); opacity: 0; transition: opacity .5s; background-color: var(--c-background); }
#seccion-cuentas .login-view--visible { display: flex; opacity: 1; }
#seccion-cuentas .login-view__card { background-color: var(--c-surface); padding: var(--sp-5); border-radius: var(--border-radius-lg); box-shadow: var(--shadow-md); width: 100%; max-width: 340px; text-align: center; animation: cuentas-pop-in 0.3s ease-out; }
#seccion-cuentas .login-view__title { margin-bottom: var(--sp-4); font-size: var(--fs-lg); }
#seccion-cuentas .empty-state { text-align: center; padding: var(--sp-5) 0; color: var(--c-on-surface-secondary); animation: cuentas-fade-in 0.3s; background: var(--c-surface); border-radius: var(--border-radius-lg); }
#seccion-cuentas .empty-state .material-icons { font-size: 40px; margin-bottom: var(--sp-2); }
#seccion-cuentas .empty-state h3 { font-size: var(--fs-lg); font-weight: 600; color: var(--c-on-surface); margin-bottom: var(--sp-2); }
#seccion-cuentas .filter-pills { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
#seccion-cuentas .filter-pill { padding: var(--sp-1) var(--sp-3); border: none; border-radius: 99px; font-size: var(--fs-xs); font-weight: 500; background-color: var(--c-surface-variant); color: var(--c-on-surface); cursor: pointer; transition: all 0.2s; }
#seccion-cuentas .filter-pill:hover { opacity: 0.8; }
#seccion-cuentas .filter-pill--active { background-color: var(--c-primary); color: var(--c-white); font-weight: 600; }
#seccion-cuentas #cuentas-movimiento-modal .modal__body { padding-right: var(--sp-1); margin-right: calc(-1 * var(--sp-1)); }
#seccion-cuentas #cuentas-movimiento-modal .form-group { margin-bottom: var(--sp-1); }
#seccion-cuentas #cuentas-movimiento-modal .form-label { margin-bottom: 2px; font-size: var(--fs-xs); }
#seccion-cuentas #cuentas-movimiento-modal .form-input, #seccion-cuentas #cuentas-movimiento-modal .form-select { padding: var(--sp-2); font-size: var(--fs-sm); }
#seccion-cuentas #cuentas-movimiento-modal .form-select { background-position: right 8px center; padding-right: 32px; }
#seccion-cuentas #cuentas-movimiento-modal .form-group-addon .icon-btn { height: 36px; width: 36px; align-self: flex-end; margin-bottom: 0; }
#seccion-cuentas #cuentas-movimiento-modal .form-group-addon .form-group { margin-bottom: 0; }
#seccion-cuentas .toast-container { position: fixed; bottom: 70px; left: 50%; transform: translateX(-50%); z-index: 9999; display: flex; flex-direction: column; align-items: center; gap: var(--sp-2); pointer-events: none;}
#seccion-cuentas .toast { background-color: var(--c-black); color: var(--c-white); padding: var(--sp-2) var(--sp-4); border-radius: var(--border-radius-md); box-shadow: var(--shadow-md); pointer-events: all;}
#seccion-cuentas .toast--danger { background-color: var(--c-danger); }
#seccion-cuentas .toast--warning { background-color: var(--c-warning); }
#seccion-cuentas .toast--info { background-color: var(--c-info); }
#seccion-cuentas .text-positive { color: var(--c-success); } #seccion-cuentas .text-negative { color: var(--c-danger); } #seccion-cuentas .text-warning { color: var(--c-warning); } #seccion-cuentas .text-info { color: var(--c-info); }
#seccion-cuentas .hidden { display: none !important; }
#seccion-cuentas .spinner { display: inline-block; width: 1em; height: 1em; border: .15em solid currentColor; border-radius: 50%; border-top-color: transparent; animation: spin .8s linear infinite; vertical-align: middle; }
@keyframes spin { to { transform:rotate(360deg); } }
#seccion-cuentas #cuentas-description-suggestions { display: none; position: absolute; top: 100%; left: 0; right: 0; background-color: var(--c-surface); border-radius: var(--border-radius-md); box-shadow: var(--shadow-md); z-index: 1060; max-height: 150px; overflow-y: auto; border: 1px solid var(--c-outline); }
#seccion-cuentas .suggestion-item { padding: var(--sp-2) var(--sp-3); cursor: pointer; font-size: var(--fs-sm); }
#seccion-cuentas .suggestion-item:hover { background-color: var(--c-surface-variant); }
#seccion-cuentas .suggestion-item small { color: var(--c-on-surface-secondary); font-size: var(--fs-xs); }
#seccion-cuentas .budget-track-item { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: var(--sp-3); padding: var(--sp-2) 0; border-bottom: 1px solid var(--c-outline); }
#seccion-cuentas .budget-track-item:last-child { border-bottom: none; }
#seccion-cuentas .budget-track-item__main { display: flex; flex-direction: column; gap: var(--sp-1); min-width: 0; }
#seccion-cuentas .budget-track-item__concept-name { font-weight: 600; font-size: var(--fs-sm); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#seccion-cuentas .budget-track-item__figures { display: flex; flex-direction: column; align-items: flex-end; text-align: right; font-size: var(--fs-xs); }
#seccion-cuentas .budget-track-item__amount { color: var(--c-on-surface-secondary); }
#seccion-cuentas .budget-track-item__amount strong { color: var(--c-on-surface); font-weight: 500;}
#seccion-cuentas .budget-track-item__difference { font-weight: 600; }
#seccion-cuentas .budget-item__progress { width: 100%; -webkit-appearance: none; appearance: none; height: 6px; border-radius: 99px; overflow: hidden; background-color: var(--c-surface-variant); }
#seccion-cuentas .budget-item__progress::-webkit-progress-bar { background-color: var(--c-surface-variant); }
#seccion-cuentas .budget-item__progress::-webkit-progress-value { background-color: var(--c-primary); transition: width 0.3s ease; }
#seccion-cuentas .budget-item__progress.budget-item__progress--danger::-webkit-progress-value { background-color: var(--c-danger); }
#seccion-cuentas .budget-item__progress.budget-item__progress--warning::-webkit-progress-value { background-color: var(--c-warning); }
#seccion-cuentas .investment-asset-card { background-color: var(--c-surface); border-radius: var(--border-radius-lg); padding: var(--sp-3); margin-bottom: var(--sp-2); cursor: pointer; transition: transform 0.2s, box-shadow 0.2s; }
#seccion-cuentas .investment-asset-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
#seccion-cuentas .investment-asset-card__header { display: grid; grid-template-columns: 1fr auto; align-items: flex-start; gap: var(--sp-2); }
#seccion-cuentas .investment-asset-card__name { font-size: var(--fs-base); font-weight: 600; }
#seccion-cuentas .investment-asset-card__value { font-size: var(--fs-lg); font-weight: 700; text-align: right; }
#seccion-cuentas .investment-asset-card__pnl { font-size: var(--fs-xs); font-weight: 500; text-align: right; }
#seccion-cuentas .investment-timeline-item { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-2) 0; border-bottom: 1px solid var(--c-outline); }
#seccion-cuentas .investment-timeline-item:last-child { border-bottom: none; }
#seccion-cuentas .investment-timeline-item__icon { flex-shrink: 0; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; background-color: var(--c-surface-variant); border-radius: 50%; }
#seccion-cuentas .investment-timeline-item__icon .material-icons { font-size: 18px; }
#seccion-cuentas .investment-timeline-item__details { flex-grow: 1; }
#seccion-cuentas .investment-timeline-item__description { font-weight: 500; font-size: var(--fs-sm); }
#seccion-cuentas .investment-timeline-item__date { font-size: var(--fs-xs); color: var(--c-on-surface-secondary); }
#seccion-cuentas .investment-timeline-item__amount { font-weight: 600; font-size: var(--fs-sm); }
#seccion-cuentas #cuentas-exit-screen { display: none; opacity: 0; position: absolute; inset: 0; background-color: var(--c-background); color: var(--c-on-surface); flex-direction: column; align-items: center; justify-content: center; z-index: 9999; font-size: 1.5rem; text-align: center; transition: opacity 0.5s ease; }
#seccion-cuentas .calculator-overlay { align-items: flex-end; background: rgba(0,0,0,0.3); }
#seccion-cuentas .calculator-ui { width: 100%; max-width: 500px; margin: 0 auto; background-color: var(--c-surface-variant); color: var(--c-on-surface); border-top-left-radius: var(--border-radius-lg); border-top-right-radius: var(--border-radius-lg); padding: var(--sp-4) var(--sp-4) env(safe-area-inset-bottom) var(--sp-4); box-shadow: 0 -5px 20px rgba(0,0,0,0.1); transform: translateY(100%); transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); }
#seccion-cuentas .modal-overlay--active .calculator-ui { transform: translateY(0); }
#seccion-cuentas .calculator-display { font-size: 2.5rem; font-weight: 300; text-align: right; padding: var(--sp-2) var(--sp-3); margin-bottom: var(--sp-3); min-height: 60px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#seccion-cuentas .calculator-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-3); }
#seccion-cuentas .calculator-btn { font-family: var(--font-family); font-size: 1.5rem; font-weight: 400; height: 64px; border-radius: 99px; border: none; background-color: var(--c-surface); color: var(--c-on-surface); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background-color 0.2s, transform 0.1s; }
#seccion-cuentas .calculator-btn:active { transform: scale(0.95); }
#seccion-cuentas .calculator-btn.btn-operator { background-color: var(--c-surface-variant); color: var(--c-on-surface); font-weight: 500; }
#seccion-cuentas[data-theme="light"] .calculator-btn.btn-operator { background-color: #D1D1D6; }
#seccion-cuentas .calculator-btn.btn-confirm { background-color: var(--c-primary); color: var(--c-white); font-weight: 500; }
#seccion-cuentas .calculator-btn.zero { grid-column: span 2; }
#seccion-cuentas .material-icons.backspace-icon { font-size: 1.5rem; }
#seccion-cuentas[data-ledger-mode="A"] .top-bar { background-color: color-mix(in srgb, var(--c-primary) 85%, transparent); }
#seccion-cuentas[data-ledger-mode="B"] .top-bar { background-color: color-mix(in srgb, var(--c-danger) 85%, transparent); }
#seccion-cuentas[data-ledger-mode="B"] .bottom-nav__item--active { color: var(--c-danger); }
#seccion-cuentas #cuentas-ledger-toggle-btn { font-weight: 600; padding: 6px 10px; font-size: 0.8rem; min-width: 40px; text-align: center; }
#seccion-cuentas #cuentas-global-search-modal .modal { max-width: 600px; height: 70vh; border-radius: var(--border-radius-lg); }
#seccion-cuentas #cuentas-global-search-modal .modal__body { padding: 0; margin-right: 0; }
#seccion-cuentas #cuentas-global-search-input-wrapper { padding: 0 var(--sp-4) var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--c-outline); display: flex; align-items: center; gap: var(--sp-3); }
#seccion-cuentas #cuentas-global-search-input { width: 100%; font-size: var(--fs-lg); border: none; background: transparent; color: var(--c-on-surface); padding: var(--sp-2) 0; }
#seccion-cuentas #cuentas-global-search-input:focus { outline: none; }
#seccion-cuentas #cuentas-global-search-results { padding: var(--sp-2) 0; }
#seccion-cuentas .search-result-group__title { font-size: var(--fs-xs); font-weight: 600; text-transform: uppercase; color: var(--c-on-surface-secondary); padding: var(--sp-2) var(--sp-4); background-color: var(--c-surface-variant); }
#seccion-cuentas .search-result-item { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-2) var(--sp-4); cursor: pointer; border: none; background: none; width: 100%; text-align: left; }
#seccion-cuentas .search-result-item:hover { background-color: var(--c-surface-variant); }
#seccion-cuentas .search-result-item__icon { color: var(--c-on-surface-secondary); }
#seccion-cuentas .search-result-item__details p { font-size: var(--fs-sm); font-weight: 500; color: var(--c-on-surface); }
#seccion-cuentas .search-result-item__details small { font-size: var(--fs-xs); color: var(--c-on-surface-secondary); }
#seccion-cuentas .inline-edit-form { width: 100%; display: flex; flex-direction: column; gap: var(--sp-2); padding: var(--sp-2) 0; }
#seccion-cuentas .inline-edit-form .form-input { padding: var(--sp-2); }
#seccion-cuentas .inline-edit-form .form-label { font-size: var(--fs-xs); margin-bottom: 4px; }
#seccion-cuentas .widget-config-item { display: flex; align-items: center; gap: var(--sp-3); background-color: var(--c-surface-variant); padding: var(--sp-2) var(--sp-3); border-radius: var(--border-radius-md); margin-bottom: var(--sp-2); }
#seccion-cuentas .widget-config-item.dragging { opacity: 0.5; background: var(--c-primary); }
#seccion-cuentas .widget-config-item .drag-handle { cursor: grab; color: var(--c-on-surface-secondary); }
#seccion-cuentas .widget-config-item .drag-handle:active { cursor: grabbing; }
#seccion-cuentas .widget-config-item__details { flex-grow: 1; }
#seccion-cuentas .widget-config-item__title { font-weight: 600; font-size: var(--fs-sm); }
#seccion-cuentas .widget-config-item__desc { font-size: var(--fs-xs); color: var(--c-on-surface-secondary); }
#seccion-cuentas .onboarding-overlay { position: fixed; inset: 0; background-color: rgba(0, 0, 0, 0.6); backdrop-filter: blur(3px); z-index: 2000; opacity: 0; transition: opacity 0.3s ease-in-out; pointer-events: none; }
#seccion-cuentas .onboarding-overlay--visible { opacity: 1; pointer-events: auto; }
#seccion-cuentas .onboarding-highlight { position: absolute; box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.6); border-radius: var(--border-radius-md); z-index: 2001; pointer-events: none; transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); }
#seccion-cuentas .onboarding-step-box { position: absolute; z-index: 2002; background-color: var(--c-surface); color: var(--c-on-surface); padding: var(--sp-4); border-radius: var(--border-radius-lg); width: 90%; max-width: 350px; box-shadow: var(--shadow-md); opacity: 0; transform: translateY(20px); transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); }
#seccion-cuentas .onboarding-overlay--visible .onboarding-step-box { opacity: 1; transform: translateY(0); }
#seccion-cuentas .onboarding-step-box__title { font-size: var(--fs-lg); font-weight: 700; margin-bottom: var(--sp-2); color: var(--c-primary); }
#seccion-cuentas .onboarding-step-box__content { font-size: var(--fs-sm); line-height: 1.5; margin-bottom: var(--sp-4); }
#seccion-cuentas .onboarding-step-box__footer { display: flex; justify-content: space-between; align-items: center; }
#seccion-cuentas .onboarding-step-box__dots { display: flex; gap: var(--sp-2); }
#seccion-cuentas .onboarding-step-box__dot { width: 8px; height: 8px; background-color: var(--c-outline); border-radius: 50%; transition: background-color 0.3s; }
#seccion-cuentas .onboarding-step-box__dot--active { background-color: var(--c-primary); }
@media (min-width: 768px) { #seccion-cuentas .app-layout { max-width: 95%; } #seccion-cuentas .top-bar, #seccion-cuentas .bottom-nav { max-width: 100%; } #seccion-cuentas .modal-overlay { align-items: center; } #seccion-cuentas .modal { border-radius: var(--border-radius-lg); transform: translateY(0) scale(0.95); transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s; } #seccion-cuentas .modal-overlay--active .modal { transform: translateY(0) scale(1); } #seccion-cuentas .view { padding: 0 var(--sp-5); } #seccion-cuentas .kpi-grid { grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--sp-4); } #seccion-cuentas .form-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { #seccion-cuentas { overflow-y: auto; } #seccion-cuentas .app-layout { flex-direction: row; max-width: 100%; height: 100vh; } #seccion-cuentas .bottom-nav { position: fixed; flex-direction: column; width: 240px; height: 100vh; left: 0; top: 0; transform: none; border-top: none; border-right: 1px solid var(--c-outline); padding: var(--sp-5) var(--sp-3); justify-content: flex-start; gap: var(--sp-2); box-shadow: none; } #seccion-cuentas .bottom-nav__item { flex: 0 0 auto; flex-direction: row; justify-content: flex-start; width: 100%; height: auto; padding: var(--sp-2) var(--sp-3); border-radius: var(--border-radius-md); } #seccion-cuentas .bottom-nav__item:hover { background-color: var(--c-surface-variant); } #seccion-cuentas .bottom-nav__item--active { background-color: var(--c-primary); color: var(--c-white); } #seccion-cuentas[data-ledger-mode="B"] .bottom-nav__item--active { background-color: var(--c-danger); color: var(--c-white); } #seccion-cuentas .bottom-nav__item--active:hover { background-color: var(--c-primary-hover); } #seccion-cuentas .bottom-nav__item .material-icons { margin-right: var(--sp-3); font-size: 20px; } #seccion-cuentas .bottom-nav__label { display: inline-block; font-size: var(--fs-sm); font-weight: 500; margin-top: 0; } #seccion-cuentas .app-layout__main { margin-left: 240px; width: calc(100% - 240px); height: 100vh; padding: 60px var(--sp-6) var(--sp-6) var(--sp-6); } #seccion-cuentas .view { max-width: 1100px; margin: 0 auto; padding: 0; } #seccion-cuentas .top-bar { max-width: none; width: calc(100% - 240px); left: auto; right: 0; transform: none; padding-left: var(--sp-6); padding-right: var(--sp-6); } #seccion-cuentas .toast-container { bottom: var(--sp-4); left: auto; right: calc(240px / 2); transform: translateX(50%); } }