*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;width:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f7;-webkit-tap-highlight-color:transparent}#root{height:100%;display:flex;flex-direction:column}.portal-header{background:linear-gradient(135deg,#1f4e78,#2d6fab);padding:14px 16px;padding-top:calc(14px + env(safe-area-inset-top));display:flex;align-items:center;gap:10px;flex-shrink:0}.logo-square{width:38px;height:38px;border-radius:10px;background:#ffffff2e;border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff}.header-title{font-size:15px;font-weight:600;color:#fff}.header-subtitle{font-size:12px;color:#ffffffbf}.portal-content{flex:1;overflow-y:auto;padding:12px;padding-bottom:calc(70px + env(safe-area-inset-bottom))}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e0e0e0;display:flex;padding-bottom:env(safe-area-inset-bottom);z-index:100}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px 6px;cursor:pointer;text-decoration:none;color:#888}.nav-item.active{color:#1f4e78}.nav-icon{font-size:22px;line-height:1;margin-bottom:2px}.nav-label{font-size:10px;font-weight:500}.stat-card{background:#fff;border-radius:12px;padding:14px;box-shadow:0 1px 3px #0000000f;margin-bottom:8px}.stat-label{font-size:11px;color:#666;text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;font-weight:600}.stat-value{font-size:24px;font-weight:700;color:#111;letter-spacing:-.5px}.stat-value.positivo{color:#1e7e34}.stat-value.negativo{color:#c82828}.stat-sub{font-size:12px;color:#888;margin-top:2px}.admin-actions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.admin-action-btn{background:#1f4e78;border-radius:10px;padding:12px 4px;text-align:center;text-decoration:none;color:#fff;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;border:none;font-family:inherit}.action-icon{font-size:20px;line-height:1}.action-label{font-size:11px;font-weight:500}.admin-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.mov-card{background:#fff;border-radius:10px;padding:11px 12px;margin-bottom:6px;box-shadow:0 1px 2px #0000000d;display:flex;align-items:center;border-left:3px solid transparent}.mov-card.mov-abono{border-left-color:#2e7d32}.mov-card.mov-gasto{border-left-color:#c62828}.mov-icon{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0;margin-right:10px}.mov-abono .mov-icon{background:#e8f5e9;color:#2e7d32}.mov-gasto .mov-icon{background:#fdecea;color:#c62828}.mov-body{flex:1;min-width:0}.mov-tipo{font-size:13px;font-weight:600;color:#333}.mov-desc{font-size:11px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mov-fecha{font-size:11px;color:#aaa}.mov-right{text-align:right}.mov-monto{font-size:14px;font-weight:700}.mov-monto.positivo{color:#2e7d32}.mov-monto.negativo{color:#c62828}.section-title{font-size:13px;font-weight:700;color:#333;margin:14px 0 8px;display:flex;justify-content:space-between;align-items:center}.section-link{font-size:12px;color:#1f4e78;text-decoration:none;font-weight:500}.loader-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f2a44;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:999}.loader-logo{width:64px;height:64px;background:#fff;color:#0f2a44;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;margin-bottom:12px}.loader-badge{background:#f59e0b;color:#fff;font-size:11px;font-weight:700;padding:4px 12px;border-radius:12px;margin-bottom:24px}.spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-card{background:#fdecea;color:#c62828;border-radius:10px;padding:12px;margin-bottom:8px;font-size:13px}.placeholder-card{background:#fff;border-radius:10px;padding:20px;text-align:center;color:#888;font-size:13px}.access-screen{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0f2a44;padding:24px;text-align:center}.access-logo{width:80px;height:80px;background:#fff;color:#0f2a44;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;margin-bottom:12px}.access-badge{background:#f59e0b;color:#fff;font-size:11px;font-weight:700;padding:4px 12px;border-radius:12px;margin-bottom:20px}.access-title{font-size:22px;color:#fff;font-weight:600;margin-bottom:8px}.access-text{font-size:14px;color:#fffc;line-height:1.5}.resumen-panel{background:#fff;border-radius:12px;padding:14px;margin-bottom:12px;box-shadow:0 1px 3px #0000000f}
